Blame view

kernel/linux-imx6_3.14.28/arch/powerpc/math-emu/mtfsf.c 1.33 KB
6b13f685e   김민수   BSP 최초 추가
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
  #include <linux/types.h>
  #include <linux/errno.h>
  #include <asm/uaccess.h>
  
  #include <asm/sfp-machine.h>
  #include <math-emu/soft-fp.h>
  
  int
  mtfsf(unsigned int FM, u32 *frB)
  {
  	u32 mask;
  	u32 fpscr;
  
  	if (FM == 0)
  		return 0;
  
  	if (FM == 0xff)
  		mask = 0x9fffffff;
  	else {
  		mask = 0;
  		if (FM & (1 << 0))
  			mask |= 0x90000000;
  		if (FM & (1 << 1))
  			mask |= 0x0f000000;
  		if (FM & (1 << 2))
  			mask |= 0x00f00000;
  		if (FM & (1 << 3))
  			mask |= 0x000f0000;
  		if (FM & (1 << 4))
  			mask |= 0x0000f000;
  		if (FM & (1 << 5))
  			mask |= 0x00000f00;
  		if (FM & (1 << 6))
  			mask |= 0x000000f0;
  		if (FM & (1 << 7))
  			mask |= 0x0000000f;
  	}
  
  	__FPU_FPSCR &= ~(mask);
  	__FPU_FPSCR |= (frB[1] & mask);
  
  	__FPU_FPSCR &= ~(FPSCR_VX);
  	if (__FPU_FPSCR & (FPSCR_VXSNAN | FPSCR_VXISI | FPSCR_VXIDI |
  		     FPSCR_VXZDZ | FPSCR_VXIMZ | FPSCR_VXVC |
  		     FPSCR_VXSOFT | FPSCR_VXSQRT | FPSCR_VXCVI))
  		__FPU_FPSCR |= FPSCR_VX;
  
  	fpscr = __FPU_FPSCR;
  	fpscr &= ~(FPSCR_FEX);
  	if (((fpscr & FPSCR_VX) && (fpscr & FPSCR_VE)) ||
  	    ((fpscr & FPSCR_OX) && (fpscr & FPSCR_OE)) ||
  	    ((fpscr & FPSCR_UX) && (fpscr & FPSCR_UE)) ||
  	    ((fpscr & FPSCR_ZX) && (fpscr & FPSCR_ZE)) ||
  	    ((fpscr & FPSCR_XX) && (fpscr & FPSCR_XE)))
  		fpscr |= FPSCR_FEX;
  	__FPU_FPSCR = fpscr;
  
  #ifdef DEBUG
  	printk("%s: %02x %p: %08lx
  ", __func__, FM, frB, __FPU_FPSCR);
  #endif
  
  	return 0;
  }