2005-04-17 06:20:36 +08:00
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/errno.h>
|
|
|
|
#include <asm/uaccess.h>
|
|
|
|
|
|
|
|
#include "soft-fp.h"
|
|
|
|
|
|
|
|
int
|
|
|
|
mtfsfi(unsigned int crfD, unsigned int IMM)
|
|
|
|
{
|
|
|
|
u32 mask = 0xf;
|
|
|
|
|
|
|
|
if (!crfD)
|
|
|
|
mask = 9;
|
|
|
|
|
|
|
|
__FPU_FPSCR &= ~(mask << ((7 - crfD) << 2));
|
|
|
|
__FPU_FPSCR |= (IMM & 0xf) << ((7 - crfD) << 2);
|
|
|
|
|
|
|
|
#ifdef DEBUG
|
2008-03-29 05:21:07 +08:00
|
|
|
printk("%s: %d %x: %08lx\n", __func__, crfD, IMM, __FPU_FPSCR);
|
2005-04-17 06:20:36 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|