| #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\n", __func__, FM, frB, __FPU_FPSCR); | 
 | #endif | 
 |  | 
 | 	return 0; | 
 | } |