import of upstream 2.4.34.4 from kernel.org
[linux-2.4.git] / arch / s390x / kernel / ieee.h
1 /*
2  *  arch/s390/kernel/ieee.h
3  *
4  *  S390 version
5  *    Copyright (C) 1999 IBM Deutschland Entwicklung GmbH, IBM Corporation
6  *    Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com),
7  */
8
9 #include <linux/sched.h>
10
11 static    inline void _adddf(int R1,int R2)
12 {
13   current->tss.fprs[R1].fd = current->tss.fprs[R1].fd +
14                              current->tss.fprs[R2].fd;
15 }
16
17 static    inline void _subdf(int R1,int R2)
18 {
19   current->tss.fprs[R1].fd = current->tss.fprs[R1].fd -
20                              current->tss.fprs[R2].fd;
21 }
22
23 static    inline void _muldf(int R1,int R2)
24 {
25   current->tss.fprs[R1].fd = current->tss.fprs[R1].fd *
26                              current->tss.fprs[R2].fd;
27 }
28
29 static    inline void _divdf(int R1,int R2)
30 {
31   current->tss.fprs[R1].fd = current->tss.fprs[R1].fd /
32                              current->tss.fprs[R2].fd;
33 }
34
35 static    inline void _negdf(int R1,int R2)
36 {
37   current->tss.fprs[R1].fd = -current->tss.fprs[R1].fd;
38 }
39
40 static    inline void _fixdfsi(int R1,int R2)
41 {
42   current->tss.regs->gprs[R1] = (__u32) current->tss.fprs[R2].fd;
43 }
44
45 static    inline void _extendsidf(int R1,int R2)
46 {
47   current->tss.fprs[R1].fd = (double) current->tss.regs->gprs[R2];
48 }
49
50
51 static    inline  void _addsf(int R1,int R2)
52 {
53   current->tss.fprs[R1].ff = current->tss.fprs[R1].ff +
54                              current->tss.fprs[R2].ff;
55 }
56
57 static    inline  void _subsf(int R1,int R2)
58 {
59   current->tss.fprs[R1].ff = current->tss.fprs[R1].ff -
60                              current->tss.fprs[R2].ff;
61 }
62
63 static    inline void _mulsf(int R1,int R2)
64 {
65   current->tss.fprs[R1].ff = current->tss.fprs[R1].ff *
66                              current->tss.fprs[R2].ff;
67 }
68
69 static    inline void _divsf(int R1,int R2)
70 {
71   current->tss.fprs[R1].ff = current->tss.fprs[R1].ff /
72                              current->tss.fprs[R2].ff;
73 }
74
75 static    inline void _negsf(int R1,int R2)
76 {
77   current->tss.fprs[R1].ff = -current->tss.fprs[R1].ff;
78 }
79
80 static    inline void _fixsfsi(int R1,int R2)
81 {
82   current->tss.regs->gprs[R1] = (__u32) current->tss.fprs[R2].ff;
83 }
84
85 static    inline void _extendsisf(int R1,int R2)
86 {
87   current->tss.fprs[R1].ff = (double) current->tss.regs->gprs[R2];
88 }
89
90