summaryrefslogtreecommitdiff
path: root/Linux/spim/include/fpuctl.h
blob: ad5dcba7c0d9d419b409016b0150e7f977a2f8ea (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/* FCR */
#define	FCRBITS	0x00000F83
#define	FPINEX	(1<<7)
#define	FPUNFL	(1<<8)
#define	FPOVFL	(1<<9)
#define	FPZDIV	(1<<10)
#define	FPINVAL	(1<<11)
#define	FPRNR	(0<<0)
#define	FPRZ	(1<<0)
#define	FPRPINF	(2<<0)
#define	FPRNINF	(3<<0)
#define	FPRMASK	(3<<0)
#define	FPPEXT	0
#define	FPPSGL	0
#define	FPPDBL	0
#define	FPPMASK	0
/* FSR */
#define	FSRBITS	0x0003F07C
#define	FPAINEX	(1<<2)
#define	FPAOVFL	(1<<4)
#define	FPAUNFL	(1<<3)
#define	FPAZDIV	(1<<5)
#define	FPAINVAL	(1<<6)

/*
 * Linux mips fpu support
 * Mimic Plan9 floating point support
 */

static void
setfcr(ulong fcr)
{
	__asm__("ctc1	%0,$31\n"
			: :"r" (fcr)
	);
}

static ulong
getfcr(void)
{
	ulong fcr = 0;
	__asm__("cfc1	%0,$31\n"
			: "=r" (fcr)
	);
	fcr &= FCRBITS;
	return fcr; 
}

static ulong
getfsr(void)
{
	ulong fsr = 0;
	__asm__("cfc1	%0,$31\n"
			: "=r" (fsr)
	);
	fsr &= FSRBITS;
	return fsr;
}

static void
setfsr(ulong fsr)
{
	fsr |= getfcr();
	setfcr(getfcr()|fsr);
}