diff options
author | Gabe Black <gblack@eecs.umich.edu> | 2010-06-02 12:58:17 -0500 |
---|---|---|
committer | Gabe Black <gblack@eecs.umich.edu> | 2010-06-02 12:58:17 -0500 |
commit | 9223725973d5c5b7082bae2550f3c2111fbb3501 (patch) | |
tree | 368333b8fe42b816d4eb2234fab3dd98da9d5eba /src/arch | |
parent | b6c2548a27181049f7bc250a16a5e868306a356f (diff) | |
download | gem5-9223725973d5c5b7082bae2550f3c2111fbb3501.tar.xz |
ARM: Move the ISA "clear" function into isa.cc.
Diffstat (limited to 'src/arch')
-rw-r--r-- | src/arch/arm/isa.cc | 77 | ||||
-rw-r--r-- | src/arch/arm/isa.hh | 79 |
2 files changed, 78 insertions, 78 deletions
diff --git a/src/arch/arm/isa.cc b/src/arch/arm/isa.cc index be9e19844..25e616e8e 100644 --- a/src/arch/arm/isa.cc +++ b/src/arch/arm/isa.cc @@ -43,6 +43,83 @@ namespace ArmISA { +void +ISA::clear() +{ + SCTLR sctlr_rst = miscRegs[MISCREG_SCTLR_RST]; + + memset(miscRegs, 0, sizeof(miscRegs)); + CPSR cpsr = 0; + cpsr.mode = MODE_USER; + miscRegs[MISCREG_CPSR] = cpsr; + updateRegMap(cpsr); + + SCTLR sctlr = 0; + sctlr.nmfi = (bool)sctlr_rst.nmfi; + sctlr.v = (bool)sctlr_rst.v; + sctlr.u = 1; + sctlr.xp = 1; + sctlr.rao2 = 1; + sctlr.rao3 = 1; + sctlr.rao4 = 1; + miscRegs[MISCREG_SCTLR] = sctlr; + miscRegs[MISCREG_SCTLR_RST] = sctlr_rst; + + + /* + * Technically this should be 0, but we don't support those + * settings. + */ + CPACR cpacr = 0; + // Enable CP 10, 11 + cpacr.cp10 = 0x3; + cpacr.cp11 = 0x3; + miscRegs[MISCREG_CPACR] = cpacr; + + /* Start with an event in the mailbox */ + miscRegs[MISCREG_SEV_MAILBOX] = 1; + + /* + * Implemented = '5' from "M5", + * Variant = 0, + */ + miscRegs[MISCREG_MIDR] = + (0x35 << 24) | //Implementor is '5' from "M5" + (0 << 20) | //Variant + (0xf << 16) | //Architecture from CPUID scheme + (0 << 4) | //Primary part number + (0 << 0) | //Revision + 0; + + // Separate Instruction and Data TLBs. + miscRegs[MISCREG_TLBTR] = 1; + + MVFR0 mvfr0 = 0; + mvfr0.advSimdRegisters = 2; + mvfr0.singlePrecision = 2; + mvfr0.doublePrecision = 2; + mvfr0.vfpExceptionTrapping = 0; + mvfr0.divide = 1; + mvfr0.squareRoot = 1; + mvfr0.shortVectors = 1; + mvfr0.roundingModes = 1; + miscRegs[MISCREG_MVFR0] = mvfr0; + + MVFR1 mvfr1 = 0; + mvfr1.flushToZero = 1; + mvfr1.defaultNaN = 1; + mvfr1.advSimdLoadStore = 1; + mvfr1.advSimdInteger = 1; + mvfr1.advSimdSinglePrecision = 1; + mvfr1.advSimdHalfPrecision = 1; + mvfr1.vfpHalfPrecision = 1; + miscRegs[MISCREG_MVFR1] = mvfr1; + + miscRegs[MISCREG_MPIDR] = 0; + + //XXX We need to initialize the rest of the state. +} + MiscReg ISA::readMiscRegNoEffect(int misc_reg) { diff --git a/src/arch/arm/isa.hh b/src/arch/arm/isa.hh index 5952dc11f..0d83853b6 100644 --- a/src/arch/arm/isa.hh +++ b/src/arch/arm/isa.hh @@ -91,88 +91,11 @@ namespace ArmISA } public: - void clear() - { - SCTLR sctlr_rst = miscRegs[MISCREG_SCTLR_RST]; - - memset(miscRegs, 0, sizeof(miscRegs)); - CPSR cpsr = 0; - cpsr.mode = MODE_USER; - miscRegs[MISCREG_CPSR] = cpsr; - updateRegMap(cpsr); - - SCTLR sctlr = 0; - sctlr.nmfi = (bool)sctlr_rst.nmfi; - sctlr.v = (bool)sctlr_rst.v; - sctlr.u = 1; - sctlr.xp = 1; - sctlr.rao2 = 1; - sctlr.rao3 = 1; - sctlr.rao4 = 1; - miscRegs[MISCREG_SCTLR] = sctlr; - miscRegs[MISCREG_SCTLR_RST] = sctlr_rst; - - - /* - * Technically this should be 0, but we don't support those - * settings. - */ - CPACR cpacr = 0; - // Enable CP 10, 11 - cpacr.cp10 = 0x3; - cpacr.cp11 = 0x3; - miscRegs[MISCREG_CPACR] = cpacr; - - /* Start with an event in the mailbox */ - miscRegs[MISCREG_SEV_MAILBOX] = 1; - - /* - * Implemented = '5' from "M5", - * Variant = 0, - */ - miscRegs[MISCREG_MIDR] = - (0x35 << 24) | //Implementor is '5' from "M5" - (0 << 20) | //Variant - (0xf << 16) | //Architecture from CPUID scheme - (0 << 4) | //Primary part number - (0 << 0) | //Revision - 0; - - // Separate Instruction and Data TLBs. - miscRegs[MISCREG_TLBTR] = 1; - - MVFR0 mvfr0 = 0; - mvfr0.advSimdRegisters = 2; - mvfr0.singlePrecision = 2; - mvfr0.doublePrecision = 2; - mvfr0.vfpExceptionTrapping = 0; - mvfr0.divide = 1; - mvfr0.squareRoot = 1; - mvfr0.shortVectors = 1; - mvfr0.roundingModes = 1; - miscRegs[MISCREG_MVFR0] = mvfr0; - - MVFR1 mvfr1 = 0; - mvfr1.flushToZero = 1; - mvfr1.defaultNaN = 1; - mvfr1.advSimdLoadStore = 1; - mvfr1.advSimdInteger = 1; - mvfr1.advSimdSinglePrecision = 1; - mvfr1.advSimdHalfPrecision = 1; - mvfr1.vfpHalfPrecision = 1; - miscRegs[MISCREG_MVFR1] = mvfr1; - - miscRegs[MISCREG_MPIDR] = 0; - - //XXX We need to initialize the rest of the state. - } + void clear(); MiscReg readMiscRegNoEffect(int misc_reg); - MiscReg readMiscReg(int misc_reg, ThreadContext *tc); - void setMiscRegNoEffect(int misc_reg, const MiscReg &val); - void setMiscReg(int misc_reg, const MiscReg &val, ThreadContext *tc); int |