unsigned int PerformSFM(const unsigned int opcode) { unsigned int __user *pBase, *pAddress, *pFinal; unsigned int i, Fd, write_back = WRITE_BACK(opcode); pBase = (unsigned int __user *) readRegister(getRn(opcode)); if (REG_PC == getRn(opcode)) { pBase += 2; write_back = 0; } pFinal = pBase; if (BIT_UP_SET(opcode)) pFinal += getOffset(opcode); else pFinal -= getOffset(opcode); if (PREINDEXED(opcode)) pAddress = pFinal; else pAddress = pBase; Fd = getFd(opcode); for (i = getRegisterCount(opcode); i > 0; i--) { storeMultiple(Fd, pAddress); pAddress += 3; Fd++; if (Fd == 8) Fd = 0; } if (write_back) writeRegister(getRn(opcode), (unsigned long) pFinal); return 1; }
unsigned int PerformSTF(const unsigned int opcode) { unsigned int *pBase, *pAddress, *pFinal, nRc = 1, write_back = WRITE_BACK(opcode); //printk("PerformSTF(0x%08x), Fd = 0x%08x\n",opcode,getFd(opcode)); SetRoundingMode(ROUND_TO_NEAREST); pBase = (unsigned int*)readRegister(getRn(opcode)); if (REG_PC == getRn(opcode)) { pBase += 2; write_back = 0; } pFinal = pBase; if (BIT_UP_SET(opcode)) pFinal += getOffset(opcode); else pFinal -= getOffset(opcode); if (PREINDEXED(opcode)) pAddress = pFinal; else pAddress = pBase; switch (opcode & MASK_TRANSFER_LENGTH) { case TRANSFER_SINGLE : storeSingle(getFd(opcode),pAddress); break; case TRANSFER_DOUBLE : storeDouble(getFd(opcode),pAddress); break; case TRANSFER_EXTENDED: storeExtended(getFd(opcode),pAddress); break; default: nRc = 0; } if (write_back) writeRegister(getRn(opcode),(unsigned int)pFinal); return nRc; }
static unsigned int PerformSFM(const unsigned int opcode) { unsigned int i, Fd, write_back = WRITE_BACK(opcode); target_ulong pBase, pAddress, pFinal; pBase = readRegister(getRn(opcode)); if (ARM_REG_PC == getRn(opcode)) { pBase += 8; write_back = 0; } pFinal = pBase; if (BIT_UP_SET(opcode)) pFinal += getOffset(opcode) * 4; else pFinal -= getOffset(opcode) * 4; if (PREINDEXED(opcode)) pAddress = pFinal; else pAddress = pBase; Fd = getFd(opcode); for (i=getRegisterCount(opcode);i>0;i--) { storeMultiple(Fd,pAddress); pAddress += 12; Fd++; if (Fd == 8) Fd = 0; } if (write_back) writeRegister(getRn(opcode),(unsigned int)pFinal); return 1; }
static unsigned int PerformLDF(const unsigned int opcode) { target_ulong pBase, pAddress, pFinal; unsigned int nRc = 1, write_back = WRITE_BACK(opcode); //printk("PerformLDF(0x%08x), Fd = 0x%08x\n",opcode,getFd(opcode)); pBase = readRegister(getRn(opcode)); if (ARM_REG_PC == getRn(opcode)) { pBase += 8; write_back = 0; } pFinal = pBase; if (BIT_UP_SET(opcode)) pFinal += getOffset(opcode) * 4; else pFinal -= getOffset(opcode) * 4; if (PREINDEXED(opcode)) pAddress = pFinal; else pAddress = pBase; switch (opcode & MASK_TRANSFER_LENGTH) { case TRANSFER_SINGLE : loadSingle(getFd(opcode),pAddress); break; case TRANSFER_DOUBLE : loadDouble(getFd(opcode),pAddress); break; case TRANSFER_EXTENDED: loadExtended(getFd(opcode),pAddress); break; default: nRc = 0; } if (write_back) writeRegister(getRn(opcode),(unsigned int)pFinal); return nRc; }
unsigned int PerformLFM(const unsigned int opcode) { unsigned int i, Fd, *pBase, *pAddress, *pFinal; pBase = (unsigned int*)readRegister(getRn(opcode)); if (REG_PC == getRn(opcode)) pBase += 2; pFinal = pBase; if (BIT_UP_SET(opcode)) pFinal += getOffset(opcode); else pFinal -= getOffset(opcode); if (PREINDEXED(opcode)) pAddress = pFinal; else pAddress = pBase; Fd = getFd(opcode); for (i=getRegisterCount(opcode);i>0;i--) { loadMultiple(Fd,pAddress); pAddress += 3; Fd++; if (Fd == 8) Fd = 0; } if (WRITE_BACK(opcode)) writeRegister(getRn(opcode),(unsigned int)pFinal); return 1; }
unsigned int PerformLDF(const unsigned int opcode) { unsigned int *pBase, *pAddress, *pFinal, nRc = 1; //fp_printk("PerformLDF(0x%08x), Fd = 0x%08x\n",opcode,getFd(opcode)); pBase = (unsigned int*)readRegister(getRn(opcode)); if (REG_PC == getRn(opcode)) pBase += 2; pFinal = pBase; if (BIT_UP_SET(opcode)) pFinal += getOffset(opcode); else pFinal -= getOffset(opcode); if (PREINDEXED(opcode)) pAddress = pFinal; else pAddress = pBase; switch (opcode & MASK_TRANSFER_LENGTH) { case TRANSFER_SINGLE : loadSingle(getFd(opcode),pAddress); break; case TRANSFER_DOUBLE : loadDouble(getFd(opcode),pAddress); break; case TRANSFER_EXTENDED: loadExtended(getFd(opcode),pAddress); break; default: nRc = 0; } if (WRITE_BACK(opcode)) writeRegister(getRn(opcode),(unsigned int)pFinal); return nRc; }
unsigned int PerformSTF(const unsigned int opcode) { unsigned int __user *pBase, *pAddress, *pFinal; unsigned int nRc = 1, write_back = WRITE_BACK(opcode); struct roundingData roundData; roundData.mode = SetRoundingMode(opcode); roundData.precision = SetRoundingPrecision(opcode); roundData.exception = 0; pBase = (unsigned int __user *) readRegister(getRn(opcode)); if (REG_PC == getRn(opcode)) { pBase += 2; write_back = 0; } pFinal = pBase; if (BIT_UP_SET(opcode)) pFinal += getOffset(opcode); else pFinal -= getOffset(opcode); if (PREINDEXED(opcode)) pAddress = pFinal; else pAddress = pBase; switch (opcode & MASK_TRANSFER_LENGTH) { case TRANSFER_SINGLE: storeSingle(&roundData, getFd(opcode), pAddress); break; case TRANSFER_DOUBLE: storeDouble(&roundData, getFd(opcode), pAddress); break; #ifdef CONFIG_FPE_NWFPE_XP case TRANSFER_EXTENDED: storeExtended(getFd(opcode), pAddress); break; #endif default: nRc = 0; } if (roundData.exception) float_raise(roundData.exception); if (write_back) writeRegister(getRn(opcode), (unsigned long) pFinal); return nRc; }
unsigned int PerformLDF(const unsigned int opcode) { unsigned int __user *pBase, *pAddress, *pFinal; unsigned int nRc = 1, write_back = WRITE_BACK(opcode); pBase = (unsigned int __user *) readRegister(getRn(opcode)); if (REG_PC == getRn(opcode)) { pBase += 2; write_back = 0; } pFinal = pBase; if (BIT_UP_SET(opcode)) pFinal += getOffset(opcode); else pFinal -= getOffset(opcode); if (PREINDEXED(opcode)) pAddress = pFinal; else pAddress = pBase; switch (opcode & MASK_TRANSFER_LENGTH) { case TRANSFER_SINGLE: loadSingle(getFd(opcode), pAddress); break; case TRANSFER_DOUBLE: loadDouble(getFd(opcode), pAddress); break; #ifdef CONFIG_FPE_NWFPE_XP case TRANSFER_EXTENDED: loadExtended(getFd(opcode), pAddress); break; #endif default: nRc = 0; } if (write_back) writeRegister(getRn(opcode), (unsigned long) pFinal); return nRc; }