Lines Matching +full:64 +full:- +full:bit
18 * only the performance is affected. Much worse is that such code is non-
30 * option in your user programs - I discourage the use of the software
31 * emulation strongly - use the following code in your userland stuff:
92 #include <asm/unaligned-emul.h>
97 #include "access-helper.h"
121 orig31 = regs->regs[31]; in emulate_load_store_insn()
133 * can assume therefore that the code is MIPS-aware and in emulate_load_store_insn()
177 regs->regs[insn.mxu_lx_format.rd] = value; in emulate_load_store_insn()
186 regs->regs[insn.dsp_format.rd] = value; in emulate_load_store_insn()
195 regs->regs[insn.dsp_format.rd] = value; in emulate_load_store_insn()
215 regs->regs[insn.dsp_format.rd] = value; in emulate_load_store_insn()
224 regs->regs[insn.dsp_format.rd] = value; in emulate_load_store_insn()
245 regs->regs[insn.spec3_format.rt] = value; in emulate_load_store_insn()
254 regs->regs[insn.spec3_format.rt] = value; in emulate_load_store_insn()
263 regs->regs[insn.spec3_format.rt] = value; in emulate_load_store_insn()
269 value = regs->regs[insn.spec3_format.rt]; in emulate_load_store_insn()
278 value = regs->regs[insn.spec3_format.rt]; in emulate_load_store_insn()
301 regs->regs[insn.i_format.rt] = value; in emulate_load_store_insn()
316 regs->regs[insn.i_format.rt] = value; in emulate_load_store_insn()
331 regs->regs[insn.i_format.rt] = value; in emulate_load_store_insn()
337 * A 32-bit kernel might be running on a 64-bit processor. But in emulate_load_store_insn()
338 * if we're on a 32-bit processor and an i-cache incoherency in emulate_load_store_insn()
339 * or race makes us see a 64-bit instruction here the sdl/sdr in emulate_load_store_insn()
340 * would blow up, so for now we don't handle unaligned 64-bit in emulate_load_store_insn()
341 * instructions on 32-bit kernels. in emulate_load_store_insn()
350 regs->regs[insn.i_format.rt] = value; in emulate_load_store_insn()
354 /* Cannot handle 64-bit instructions in 32-bit kernel */ in emulate_load_store_insn()
360 * A 32-bit kernel might be running on a 64-bit processor. But in emulate_load_store_insn()
361 * if we're on a 32-bit processor and an i-cache incoherency in emulate_load_store_insn()
362 * or race makes us see a 64-bit instruction here the sdl/sdr in emulate_load_store_insn()
363 * would blow up, so for now we don't handle unaligned 64-bit in emulate_load_store_insn()
364 * instructions on 32-bit kernels. in emulate_load_store_insn()
373 regs->regs[insn.i_format.rt] = value; in emulate_load_store_insn()
377 /* Cannot handle 64-bit instructions in 32-bit kernel */ in emulate_load_store_insn()
385 value = regs->regs[insn.i_format.rt]; in emulate_load_store_insn()
401 value = regs->regs[insn.i_format.rt]; in emulate_load_store_insn()
415 * A 32-bit kernel might be running on a 64-bit processor. But in emulate_load_store_insn()
416 * if we're on a 32-bit processor and an i-cache incoherency in emulate_load_store_insn()
417 * or race makes us see a 64-bit instruction here the sdl/sdr in emulate_load_store_insn()
418 * would blow up, so for now we don't handle unaligned 64-bit in emulate_load_store_insn()
419 * instructions on 32-bit kernels. in emulate_load_store_insn()
425 value = regs->regs[insn.i_format.rt]; in emulate_load_store_insn()
432 /* Cannot handle 64-bit instructions in 32-bit kernel */ in emulate_load_store_insn()
447 res = fpu_emulator_cop1Handler(regs, ¤t->thread.fpu, 1, in emulate_load_store_insn()
479 fpr = ¤t->thread.fpu.fpr[wd]; in emulate_load_store_insn()
586 regs->cp0_epc = origpc; in emulate_load_store_insn()
587 regs->regs[31] = orig31; in emulate_load_store_insn()
609 /* Recode table from 16-bit register notation to 32-bit GPR. */
612 /* Recode table from 16-bit STORE register notation to 32-bit GPR. */
631 origpc = regs->cp0_epc; in emulate_load_store_microMIPS()
632 orig31 = regs->regs[31]; in emulate_load_store_microMIPS()
639 pc16 = (unsigned short __user *)msk_isa16_mode(regs->cp0_epc); in emulate_load_store_microMIPS()
642 contpc = regs->cp0_epc + 2; in emulate_load_store_microMIPS()
649 contpc = regs->cp0_epc + 4; in emulate_load_store_microMIPS()
699 regs->regs[reg] = value; in emulate_load_store_microMIPS()
704 regs->regs[reg + 1] = value; in emulate_load_store_microMIPS()
715 value = regs->regs[reg]; in emulate_load_store_microMIPS()
720 value = regs->regs[reg + 1]; in emulate_load_store_microMIPS()
738 regs->regs[reg] = value; in emulate_load_store_microMIPS()
743 regs->regs[reg + 1] = value; in emulate_load_store_microMIPS()
758 value = regs->regs[reg]; in emulate_load_store_microMIPS()
763 value = regs->regs[reg + 1]; in emulate_load_store_microMIPS()
786 for (i = 16; rvar; rvar--, i++) { in emulate_load_store_microMIPS()
791 regs->regs[i] = value; in emulate_load_store_microMIPS()
798 regs->regs[30] = value; in emulate_load_store_microMIPS()
804 regs->regs[31] = value; in emulate_load_store_microMIPS()
822 for (i = 16; rvar; rvar--, i++) { in emulate_load_store_microMIPS()
823 value = regs->regs[i]; in emulate_load_store_microMIPS()
830 value = regs->regs[30]; in emulate_load_store_microMIPS()
837 value = regs->regs[31]; in emulate_load_store_microMIPS()
860 for (i = 16; rvar; rvar--, i++) { in emulate_load_store_microMIPS()
865 regs->regs[i] = value; in emulate_load_store_microMIPS()
872 regs->regs[30] = value; in emulate_load_store_microMIPS()
878 regs->regs[31] = value; in emulate_load_store_microMIPS()
901 for (i = 16; rvar; rvar--, i++) { in emulate_load_store_microMIPS()
902 value = regs->regs[i]; in emulate_load_store_microMIPS()
909 value = regs->regs[30]; in emulate_load_store_microMIPS()
916 value = regs->regs[31]; in emulate_load_store_microMIPS()
961 regs->cp0_epc = origpc; in emulate_load_store_microMIPS()
962 regs->regs[31] = orig31; in emulate_load_store_microMIPS()
968 res = fpu_emulator_cop1Handler(regs, ¤t->thread.fpu, 1, in emulate_load_store_microMIPS()
1017 for (i = 16; rvar; rvar--, i++) { in emulate_load_store_microMIPS()
1022 regs->regs[i] = value; in emulate_load_store_microMIPS()
1027 regs->regs[31] = value; in emulate_load_store_microMIPS()
1037 for (i = 16; rvar; rvar--, i++) { in emulate_load_store_microMIPS()
1038 value = regs->regs[i]; in emulate_load_store_microMIPS()
1044 value = regs->regs[31]; in emulate_load_store_microMIPS()
1094 regs->regs[reg] = value; in emulate_load_store_microMIPS()
1104 regs->regs[reg] = value; in emulate_load_store_microMIPS()
1114 regs->regs[reg] = value; in emulate_load_store_microMIPS()
1120 * A 32-bit kernel might be running on a 64-bit processor. But in emulate_load_store_microMIPS()
1121 * if we're on a 32-bit processor and an i-cache incoherency in emulate_load_store_microMIPS()
1122 * or race makes us see a 64-bit instruction here the sdl/sdr in emulate_load_store_microMIPS()
1123 * would blow up, so for now we don't handle unaligned 64-bit in emulate_load_store_microMIPS()
1124 * instructions on 32-bit kernels. in emulate_load_store_microMIPS()
1132 regs->regs[reg] = value; in emulate_load_store_microMIPS()
1136 /* Cannot handle 64-bit instructions in 32-bit kernel */ in emulate_load_store_microMIPS()
1142 * A 32-bit kernel might be running on a 64-bit processor. But in emulate_load_store_microMIPS()
1143 * if we're on a 32-bit processor and an i-cache incoherency in emulate_load_store_microMIPS()
1144 * or race makes us see a 64-bit instruction here the sdl/sdr in emulate_load_store_microMIPS()
1145 * would blow up, so for now we don't handle unaligned 64-bit in emulate_load_store_microMIPS()
1146 * instructions on 32-bit kernels. in emulate_load_store_microMIPS()
1154 regs->regs[reg] = value; in emulate_load_store_microMIPS()
1158 /* Cannot handle 64-bit instructions in 32-bit kernel */ in emulate_load_store_microMIPS()
1165 value = regs->regs[reg]; in emulate_load_store_microMIPS()
1175 value = regs->regs[reg]; in emulate_load_store_microMIPS()
1184 * A 32-bit kernel might be running on a 64-bit processor. But in emulate_load_store_microMIPS()
1185 * if we're on a 32-bit processor and an i-cache incoherency in emulate_load_store_microMIPS()
1186 * or race makes us see a 64-bit instruction here the sdl/sdr in emulate_load_store_microMIPS()
1187 * would blow up, so for now we don't handle unaligned 64-bit in emulate_load_store_microMIPS()
1188 * instructions on 32-bit kernels. in emulate_load_store_microMIPS()
1193 value = regs->regs[reg]; in emulate_load_store_microMIPS()
1200 /* Cannot handle 64-bit instructions in 32-bit kernel */ in emulate_load_store_microMIPS()
1204 regs->cp0_epc = contpc; /* advance or branch */ in emulate_load_store_microMIPS()
1213 regs->cp0_epc = origpc; in emulate_load_store_microMIPS()
1214 regs->regs[31] = orig31; in emulate_load_store_microMIPS()
1249 origpc = regs->cp0_epc; in emulate_load_store_MIPS16e()
1250 orig31 = regs->regs[31]; in emulate_load_store_MIPS16e()
1356 regs->regs[reg] = value; in emulate_load_store_MIPS16e()
1367 regs->regs[reg] = value; in emulate_load_store_MIPS16e()
1380 regs->regs[reg] = value; in emulate_load_store_MIPS16e()
1386 * A 32-bit kernel might be running on a 64-bit processor. But in emulate_load_store_MIPS16e()
1387 * if we're on a 32-bit processor and an i-cache incoherency in emulate_load_store_MIPS16e()
1388 * or race makes us see a 64-bit instruction here the sdl/sdr in emulate_load_store_MIPS16e()
1389 * would blow up, so for now we don't handle unaligned 64-bit in emulate_load_store_MIPS16e()
1390 * instructions on 32-bit kernels. in emulate_load_store_MIPS16e()
1399 regs->regs[reg] = value; in emulate_load_store_MIPS16e()
1403 /* Cannot handle 64-bit instructions in 32-bit kernel */ in emulate_load_store_MIPS16e()
1410 * A 32-bit kernel might be running on a 64-bit processor. But in emulate_load_store_MIPS16e()
1411 * if we're on a 32-bit processor and an i-cache incoherency in emulate_load_store_MIPS16e()
1412 * or race makes us see a 64-bit instruction here the sdl/sdr in emulate_load_store_MIPS16e()
1413 * would blow up, so for now we don't handle unaligned 64-bit in emulate_load_store_MIPS16e()
1414 * instructions on 32-bit kernels. in emulate_load_store_MIPS16e()
1423 regs->regs[reg] = value; in emulate_load_store_MIPS16e()
1427 /* Cannot handle 64-bit instructions in 32-bit kernel */ in emulate_load_store_MIPS16e()
1435 value = regs->regs[reg]; in emulate_load_store_MIPS16e()
1443 case MIPS16e_i8_op: /* actually - MIPS16e_swrasp_func */ in emulate_load_store_MIPS16e()
1448 value = regs->regs[reg]; in emulate_load_store_MIPS16e()
1458 * A 32-bit kernel might be running on a 64-bit processor. But in emulate_load_store_MIPS16e()
1459 * if we're on a 32-bit processor and an i-cache incoherency in emulate_load_store_MIPS16e()
1460 * or race makes us see a 64-bit instruction here the sdl/sdr in emulate_load_store_MIPS16e()
1461 * would blow up, so for now we don't handle unaligned 64-bit in emulate_load_store_MIPS16e()
1462 * instructions on 32-bit kernels. in emulate_load_store_MIPS16e()
1468 value = regs->regs[reg]; in emulate_load_store_MIPS16e()
1475 /* Cannot handle 64-bit instructions in 32-bit kernel */ in emulate_load_store_MIPS16e()
1494 regs->cp0_epc = origpc; in emulate_load_store_MIPS16e()
1495 regs->regs[31] = orig31; in emulate_load_store_MIPS16e()
1524 1, regs, regs->cp0_badvaddr); in do_ade()
1529 * virtual user address and 64bit maximum virtual user address in do_ade()
1532 if ((regs->cp0_badvaddr >= (1UL << cpu_vmbits)) && in do_ade()
1533 (regs->cp0_badvaddr < XKSSEG)) { in do_ade()
1535 current->thread.cp0_baduaddr = regs->cp0_badvaddr; in do_ade()
1545 if (regs->cp0_badvaddr == regs->cp0_epc) in do_ade()
1561 if (get_isa16_mode(regs->cp0_epc)) { in do_ade()
1564 * 16-bit mode? in do_ade()
1566 if (regs->cp0_badvaddr == msk_isa16_mode(regs->cp0_epc)) in do_ade()
1573 (void __user *)regs->cp0_badvaddr); in do_ade()
1579 (void __user *)regs->cp0_badvaddr); in do_ade()
1590 emulate_load_store_insn(regs, (void __user *)regs->cp0_badvaddr, pc); in do_ade()