diff options
-rw-r--r-- | src/arch/alpha/ev5.cc | 2 | ||||
-rw-r--r-- | src/arch/arm/tracers/tarmac_record.cc | 2 | ||||
-rw-r--r-- | src/arch/arm/utility.cc | 2 | ||||
-rw-r--r-- | src/arch/mips/utility.cc | 4 | ||||
-rw-r--r-- | src/cpu/base_dyn_inst.hh | 6 | ||||
-rw-r--r-- | src/cpu/checker/cpu.hh | 16 | ||||
-rw-r--r-- | src/cpu/checker/cpu_impl.hh | 2 | ||||
-rw-r--r-- | src/cpu/checker/thread_context.hh | 15 | ||||
-rw-r--r-- | src/cpu/exec_context.hh | 7 | ||||
-rw-r--r-- | src/cpu/kvm/x86_cpu.cc | 5 | ||||
-rw-r--r-- | src/cpu/minor/exec_context.hh | 19 | ||||
-rw-r--r-- | src/cpu/o3/cpu.cc | 42 | ||||
-rw-r--r-- | src/cpu/o3/cpu.hh | 12 | ||||
-rw-r--r-- | src/cpu/o3/dyn_inst.hh | 11 | ||||
-rw-r--r-- | src/cpu/o3/regfile.hh | 24 | ||||
-rw-r--r-- | src/cpu/o3/thread_context.hh | 13 | ||||
-rw-r--r-- | src/cpu/o3/thread_context_impl.hh | 20 | ||||
-rw-r--r-- | src/cpu/simple/base.cc | 2 | ||||
-rw-r--r-- | src/cpu/simple/exec_context.hh | 19 | ||||
-rw-r--r-- | src/cpu/simple_thread.hh | 22 | ||||
-rw-r--r-- | src/cpu/thread_context.hh | 19 |
21 files changed, 17 insertions, 247 deletions
diff --git a/src/arch/alpha/ev5.cc b/src/arch/alpha/ev5.cc index ae8efa4e6..6a5d6afdc 100644 --- a/src/arch/alpha/ev5.cc +++ b/src/arch/alpha/ev5.cc @@ -88,7 +88,7 @@ zeroRegisters(CPU *cpu) // (no longer very clean due to the change in setIntReg() in the // cpu model. Consider changing later.) cpu->thread->setIntReg(ZeroReg, 0); - cpu->thread->setFloatReg(ZeroReg, 0.0); + cpu->thread->setFloatRegBits(ZeroReg, 0); } //////////////////////////////////////////////////////////////////////// diff --git a/src/arch/arm/tracers/tarmac_record.cc b/src/arch/arm/tracers/tarmac_record.cc index 7034d2586..5dbb847e5 100644 --- a/src/arch/arm/tracers/tarmac_record.cc +++ b/src/arch/arm/tracers/tarmac_record.cc @@ -235,7 +235,7 @@ TarmacTracerRecord::TraceRegEntry::updateFloat( regValid = true; regName = "f" + std::to_string(regRelIdx); - valueLo = thread->readFloatReg(regRelIdx); + valueLo = bitsToFloat32(thread->readFloatRegBits(regRelIdx)); } void diff --git a/src/arch/arm/utility.cc b/src/arch/arm/utility.cc index d30d54a40..1dc7fc047 100644 --- a/src/arch/arm/utility.cc +++ b/src/arch/arm/utility.cc @@ -152,7 +152,7 @@ copyRegs(ThreadContext *src, ThreadContext *dest) dest->setIntRegFlat(i, src->readIntRegFlat(i)); for (int i = 0; i < NumFloatRegs; i++) - dest->setFloatRegFlat(i, src->readFloatRegFlat(i)); + dest->setFloatRegBitsFlat(i, src->readFloatRegBitsFlat(i)); for (int i = 0; i < NumVecRegs; i++) dest->setVecRegFlat(i, src->readVecRegFlat(i)); diff --git a/src/arch/mips/utility.cc b/src/arch/mips/utility.cc index 2a9a8d83c..c8163b752 100644 --- a/src/arch/mips/utility.cc +++ b/src/arch/mips/utility.cc @@ -225,7 +225,7 @@ zeroRegisters(CPU *cpu) // (no longer very clean due to the change in setIntReg() in the // cpu model. Consider changing later.) cpu->thread->setIntReg(ZeroReg, 0); - cpu->thread->setFloatReg(ZeroReg, 0.0); + cpu->thread->setFloatRegBits(ZeroReg, 0); } void @@ -247,7 +247,7 @@ copyRegs(ThreadContext *src, ThreadContext *dest) // Then loop through the floating point registers. for (int i = 0; i < NumFloatRegs; i++) - dest->setFloatRegFlat(i, src->readFloatRegFlat(i)); + dest->setFloatRegBitsFlat(i, src->readFloatRegBitsFlat(i)); // Would need to add condition-code regs if implemented assert(NumCCRegs == 0); diff --git a/src/cpu/base_dyn_inst.hh b/src/cpu/base_dyn_inst.hh index b4431da1f..ae2911c2d 100644 --- a/src/cpu/base_dyn_inst.hh +++ b/src/cpu/base_dyn_inst.hh @@ -660,12 +660,6 @@ class BaseDynInst : public ExecContext, public RefCounted setScalarResult(val); } - /** Records an fp register being set to a value. */ - void setFloatRegOperand(const StaticInst *si, int idx, FloatReg val) - { - setScalarResult(val); - } - /** Record a vector register being set to a value */ void setVecRegOperand(const StaticInst *si, int idx, const VecRegContainer& val) diff --git a/src/cpu/checker/cpu.hh b/src/cpu/checker/cpu.hh index cb87f622a..5673641aa 100644 --- a/src/cpu/checker/cpu.hh +++ b/src/cpu/checker/cpu.hh @@ -196,13 +196,6 @@ class CheckerCPU : public BaseCPU, public ExecContext return thread->readIntReg(reg.index()); } - FloatReg readFloatRegOperand(const StaticInst *si, int idx) override - { - const RegId& reg = si->srcRegIdx(idx); - assert(reg.isFloatReg()); - return thread->readFloatReg(reg.index()); - } - FloatRegBits readFloatRegOperandBits(const StaticInst *si, int idx) override { @@ -353,15 +346,6 @@ class CheckerCPU : public BaseCPU, public ExecContext setScalarResult(val); } - void setFloatRegOperand(const StaticInst *si, int idx, - FloatReg val) override - { - const RegId& reg = si->destRegIdx(idx); - assert(reg.isFloatReg()); - thread->setFloatReg(reg.index(), val); - setScalarResult(val); - } - void setFloatRegOperandBits(const StaticInst *si, int idx, FloatRegBits val) override { diff --git a/src/cpu/checker/cpu_impl.hh b/src/cpu/checker/cpu_impl.hh index 4fa59564a..f6c35439b 100644 --- a/src/cpu/checker/cpu_impl.hh +++ b/src/cpu/checker/cpu_impl.hh @@ -208,7 +208,7 @@ Checker<Impl>::verify(const DynInstPtr &completed_inst) // maintain $r0 semantics thread->setIntReg(ZeroReg, 0); #if THE_ISA == ALPHA_ISA - thread->setFloatReg(ZeroReg, 0.0); + thread->setFloatRegBits(ZeroReg, 0); #endif // Check if any recent PC changes match up with anything we diff --git a/src/cpu/checker/thread_context.hh b/src/cpu/checker/thread_context.hh index 975bd9f96..85053dfa6 100644 --- a/src/cpu/checker/thread_context.hh +++ b/src/cpu/checker/thread_context.hh @@ -209,9 +209,6 @@ class CheckerThreadContext : public ThreadContext uint64_t readIntReg(int reg_idx) { return actualTC->readIntReg(reg_idx); } - FloatReg readFloatReg(int reg_idx) - { return actualTC->readFloatReg(reg_idx); } - FloatRegBits readFloatRegBits(int reg_idx) { return actualTC->readFloatRegBits(reg_idx); } @@ -273,12 +270,6 @@ class CheckerThreadContext : public ThreadContext checkerTC->setIntReg(reg_idx, val); } - void setFloatReg(int reg_idx, FloatReg val) - { - actualTC->setFloatReg(reg_idx, val); - checkerTC->setFloatReg(reg_idx, val); - } - void setFloatRegBits(int reg_idx, FloatRegBits val) { actualTC->setFloatRegBits(reg_idx, val); @@ -382,12 +373,6 @@ class CheckerThreadContext : public ThreadContext void setIntRegFlat(int idx, uint64_t val) { actualTC->setIntRegFlat(idx, val); } - FloatReg readFloatRegFlat(int idx) - { return actualTC->readFloatRegFlat(idx); } - - void setFloatRegFlat(int idx, FloatReg val) - { actualTC->setFloatRegFlat(idx, val); } - FloatRegBits readFloatRegBitsFlat(int idx) { return actualTC->readFloatRegBitsFlat(idx); } diff --git a/src/cpu/exec_context.hh b/src/cpu/exec_context.hh index bc9b486fe..89efe8415 100644 --- a/src/cpu/exec_context.hh +++ b/src/cpu/exec_context.hh @@ -104,18 +104,11 @@ class ExecContext { * @name Floating Point Register Interfaces */ - /** Reads a floating point register of single register width. */ - virtual FloatReg readFloatRegOperand(const StaticInst *si, int idx) = 0; - /** Reads a floating point register in its binary format, instead * of by value. */ virtual FloatRegBits readFloatRegOperandBits(const StaticInst *si, int idx) = 0; - /** Sets a floating point register of single width to a value. */ - virtual void setFloatRegOperand(const StaticInst *si, - int idx, FloatReg val) = 0; - /** Sets the bits of a floating point register of single width * to a binary value. */ virtual void setFloatRegOperandBits(const StaticInst *si, diff --git a/src/cpu/kvm/x86_cpu.cc b/src/cpu/kvm/x86_cpu.cc index 012cccd20..c7625bcc6 100644 --- a/src/cpu/kvm/x86_cpu.cc +++ b/src/cpu/kvm/x86_cpu.cc @@ -840,7 +840,8 @@ updateKvmStateFPUCommon(ThreadContext *tc, T &fpu) const unsigned top((fpu.fsw >> 11) & 0x7); for (int i = 0; i < 8; ++i) { const unsigned reg_idx((i + top) & 0x7); - const double value(tc->readFloatReg(FLOATREG_FPR(reg_idx))); + const double value(bitsToFloat64( + tc->readFloatRegBits(FLOATREG_FPR(reg_idx)))); DPRINTF(KvmContext, "Setting KVM FP reg %i (st[%i]) := %f\n", reg_idx, i, value); X86ISA::storeFloat80(fpu.fpr[i], value); @@ -1055,7 +1056,7 @@ updateThreadContextFPUCommon(ThreadContext *tc, const T &fpu) const double value(X86ISA::loadFloat80(fpu.fpr[i])); DPRINTF(KvmContext, "Setting gem5 FP reg %i (st[%i]) := %f\n", reg_idx, i, value); - tc->setFloatReg(FLOATREG_FPR(reg_idx), value); + tc->setFloatRegBits(FLOATREG_FPR(reg_idx), floatToBits64(value)); } // TODO: We should update the MMX state diff --git a/src/cpu/minor/exec_context.hh b/src/cpu/minor/exec_context.hh index 238d11352..19bae74bf 100644 --- a/src/cpu/minor/exec_context.hh +++ b/src/cpu/minor/exec_context.hh @@ -99,7 +99,7 @@ class ExecContext : public ::ExecContext setPredicate(true); thread.setIntReg(TheISA::ZeroReg, 0); #if THE_ISA == ALPHA_ISA - thread.setFloatReg(TheISA::ZeroReg, 0.0); + thread.setFloatRegBits(TheISA::ZeroReg, 0); #endif } @@ -129,14 +129,6 @@ class ExecContext : public ::ExecContext return thread.readIntReg(reg.index()); } - TheISA::FloatReg - readFloatRegOperand(const StaticInst *si, int idx) override - { - const RegId& reg = si->srcRegIdx(idx); - assert(reg.isFloatReg()); - return thread.readFloatReg(reg.index()); - } - TheISA::FloatRegBits readFloatRegOperandBits(const StaticInst *si, int idx) override { @@ -178,15 +170,6 @@ class ExecContext : public ::ExecContext } void - setFloatRegOperand(const StaticInst *si, int idx, - TheISA::FloatReg val) override - { - const RegId& reg = si->destRegIdx(idx); - assert(reg.isFloatReg()); - thread.setFloatReg(reg.index(), val); - } - - void setFloatRegOperandBits(const StaticInst *si, int idx, TheISA::FloatRegBits val) override { diff --git a/src/cpu/o3/cpu.cc b/src/cpu/o3/cpu.cc index 2f793453d..e5b8103ab 100644 --- a/src/cpu/o3/cpu.cc +++ b/src/cpu/o3/cpu.cc @@ -1284,14 +1284,6 @@ FullO3CPU<Impl>::readIntReg(PhysRegIdPtr phys_reg) } template <class Impl> -FloatReg -FullO3CPU<Impl>::readFloatReg(PhysRegIdPtr phys_reg) -{ - fpRegfileReads++; - return regFile.readFloatReg(phys_reg); -} - -template <class Impl> FloatRegBits FullO3CPU<Impl>::readFloatRegBits(PhysRegIdPtr phys_reg) { @@ -1343,14 +1335,6 @@ FullO3CPU<Impl>::setIntReg(PhysRegIdPtr phys_reg, uint64_t val) template <class Impl> void -FullO3CPU<Impl>::setFloatReg(PhysRegIdPtr phys_reg, FloatReg val) -{ - fpRegfileWrites++; - regFile.setFloatReg(phys_reg, val); -} - -template <class Impl> -void FullO3CPU<Impl>::setFloatRegBits(PhysRegIdPtr phys_reg, FloatRegBits val) { fpRegfileWrites++; @@ -1393,19 +1377,8 @@ FullO3CPU<Impl>::readArchIntReg(int reg_idx, ThreadID tid) } template <class Impl> -float -FullO3CPU<Impl>::readArchFloatReg(int reg_idx, ThreadID tid) -{ - fpRegfileReads++; - PhysRegIdPtr phys_reg = commitRenameMap[tid].lookup( - RegId(FloatRegClass, reg_idx)); - - return regFile.readFloatReg(phys_reg); -} - -template <class Impl> uint64_t -FullO3CPU<Impl>::readArchFloatRegInt(int reg_idx, ThreadID tid) +FullO3CPU<Impl>::readArchFloatRegBits(int reg_idx, ThreadID tid) { fpRegfileReads++; PhysRegIdPtr phys_reg = commitRenameMap[tid].lookup( @@ -1468,18 +1441,7 @@ FullO3CPU<Impl>::setArchIntReg(int reg_idx, uint64_t val, ThreadID tid) template <class Impl> void -FullO3CPU<Impl>::setArchFloatReg(int reg_idx, float val, ThreadID tid) -{ - fpRegfileWrites++; - PhysRegIdPtr phys_reg = commitRenameMap[tid].lookup( - RegId(FloatRegClass, reg_idx)); - - regFile.setFloatReg(phys_reg, val); -} - -template <class Impl> -void -FullO3CPU<Impl>::setArchFloatRegInt(int reg_idx, uint64_t val, ThreadID tid) +FullO3CPU<Impl>::setArchFloatRegBits(int reg_idx, uint64_t val, ThreadID tid) { fpRegfileWrites++; PhysRegIdPtr phys_reg = commitRenameMap[tid].lookup( diff --git a/src/cpu/o3/cpu.hh b/src/cpu/o3/cpu.hh index 19b9a34e0..4c4677615 100644 --- a/src/cpu/o3/cpu.hh +++ b/src/cpu/o3/cpu.hh @@ -401,8 +401,6 @@ class FullO3CPU : public BaseO3CPU uint64_t readIntReg(PhysRegIdPtr phys_reg); - TheISA::FloatReg readFloatReg(PhysRegIdPtr phys_reg); - TheISA::FloatRegBits readFloatRegBits(PhysRegIdPtr phys_reg); const VecRegContainer& readVecReg(PhysRegIdPtr reg_idx) const; @@ -449,8 +447,6 @@ class FullO3CPU : public BaseO3CPU void setIntReg(PhysRegIdPtr phys_reg, uint64_t val); - void setFloatReg(PhysRegIdPtr phys_reg, TheISA::FloatReg val); - void setFloatRegBits(PhysRegIdPtr phys_reg, TheISA::FloatRegBits val); void setVecReg(PhysRegIdPtr reg_idx, const VecRegContainer& val); @@ -461,9 +457,7 @@ class FullO3CPU : public BaseO3CPU uint64_t readArchIntReg(int reg_idx, ThreadID tid); - float readArchFloatReg(int reg_idx, ThreadID tid); - - uint64_t readArchFloatRegInt(int reg_idx, ThreadID tid); + uint64_t readArchFloatRegBits(int reg_idx, ThreadID tid); const VecRegContainer& readArchVecReg(int reg_idx, ThreadID tid) const; /** Read architectural vector register for modification. */ @@ -502,9 +496,7 @@ class FullO3CPU : public BaseO3CPU */ void setArchIntReg(int reg_idx, uint64_t val, ThreadID tid); - void setArchFloatReg(int reg_idx, float val, ThreadID tid); - - void setArchFloatRegInt(int reg_idx, uint64_t val, ThreadID tid); + void setArchFloatRegBits(int reg_idx, uint64_t val, ThreadID tid); void setArchVecReg(int reg_idx, const VecRegContainer& val, ThreadID tid); diff --git a/src/cpu/o3/dyn_inst.hh b/src/cpu/o3/dyn_inst.hh index 47dc830e0..d4fbc78f9 100644 --- a/src/cpu/o3/dyn_inst.hh +++ b/src/cpu/o3/dyn_inst.hh @@ -273,11 +273,6 @@ class BaseO3DynInst : public BaseDynInst<Impl> return this->cpu->readIntReg(this->_srcRegIdx[idx]); } - FloatReg readFloatRegOperand(const StaticInst *si, int idx) - { - return this->cpu->readFloatReg(this->_srcRegIdx[idx]); - } - FloatRegBits readFloatRegOperandBits(const StaticInst *si, int idx) { return this->cpu->readFloatRegBits(this->_srcRegIdx[idx]); @@ -380,12 +375,6 @@ class BaseO3DynInst : public BaseDynInst<Impl> BaseDynInst<Impl>::setIntRegOperand(si, idx, val); } - void setFloatRegOperand(const StaticInst *si, int idx, FloatReg val) - { - this->cpu->setFloatReg(this->_destRegIdx[idx], val); - BaseDynInst<Impl>::setFloatRegOperand(si, idx, val); - } - void setFloatRegOperandBits(const StaticInst *si, int idx, FloatRegBits val) { diff --git a/src/cpu/o3/regfile.hh b/src/cpu/o3/regfile.hh index 7feec933f..2f874213f 100644 --- a/src/cpu/o3/regfile.hh +++ b/src/cpu/o3/regfile.hh @@ -187,18 +187,6 @@ class PhysRegFile return intRegFile[phys_reg->index()]; } - /** Reads a floating point register (double precision). */ - FloatReg readFloatReg(PhysRegIdPtr phys_reg) const - { - assert(phys_reg->isFloatPhysReg()); - - DPRINTF(IEW, "RegFile: Access to float register %i, has " - "data %#x\n", phys_reg->index(), - floatRegFile[phys_reg->index()].q); - - return floatRegFile[phys_reg->index()].d; - } - FloatRegBits readFloatRegBits(PhysRegIdPtr phys_reg) const { assert(phys_reg->isFloatPhysReg()); @@ -298,18 +286,6 @@ class PhysRegFile intRegFile[phys_reg->index()] = val; } - /** Sets a double precision floating point register to the given value. */ - void setFloatReg(PhysRegIdPtr phys_reg, FloatReg val) - { - assert(phys_reg->isFloatPhysReg()); - - DPRINTF(IEW, "RegFile: Setting float register %i to %#x\n", - phys_reg->index(), (uint64_t)val); - - if (!phys_reg->isZeroReg()) - floatRegFile[phys_reg->index()].d = val; - } - void setFloatRegBits(PhysRegIdPtr phys_reg, FloatRegBits val) { assert(phys_reg->isFloatPhysReg()); diff --git a/src/cpu/o3/thread_context.hh b/src/cpu/o3/thread_context.hh index 2256a8a14..1fbf565f5 100644 --- a/src/cpu/o3/thread_context.hh +++ b/src/cpu/o3/thread_context.hh @@ -184,11 +184,6 @@ class O3ThreadContext : public ThreadContext reg_idx)).index()); } - virtual FloatReg readFloatReg(int reg_idx) { - return readFloatRegFlat(flattenRegId(RegId(FloatRegClass, - reg_idx)).index()); - } - virtual FloatRegBits readFloatRegBits(int reg_idx) { return readFloatRegBitsFlat(flattenRegId(RegId(FloatRegClass, reg_idx)).index()); @@ -268,11 +263,6 @@ class O3ThreadContext : public ThreadContext setIntRegFlat(flattenRegId(RegId(IntRegClass, reg_idx)).index(), val); } - virtual void setFloatReg(int reg_idx, FloatReg val) { - setFloatRegFlat(flattenRegId(RegId(FloatRegClass, - reg_idx)).index(), val); - } - virtual void setFloatRegBits(int reg_idx, FloatRegBits val) { setFloatRegBitsFlat(flattenRegId(RegId(FloatRegClass, reg_idx)).index(), val); @@ -364,9 +354,6 @@ class O3ThreadContext : public ThreadContext virtual uint64_t readIntRegFlat(int idx); virtual void setIntRegFlat(int idx, uint64_t val); - virtual FloatReg readFloatRegFlat(int idx); - virtual void setFloatRegFlat(int idx, FloatReg val); - virtual FloatRegBits readFloatRegBitsFlat(int idx); virtual void setFloatRegBitsFlat(int idx, FloatRegBits val); diff --git a/src/cpu/o3/thread_context_impl.hh b/src/cpu/o3/thread_context_impl.hh index d9f84fb52..f4b5cb4f4 100644 --- a/src/cpu/o3/thread_context_impl.hh +++ b/src/cpu/o3/thread_context_impl.hh @@ -200,17 +200,10 @@ O3ThreadContext<Impl>::readIntRegFlat(int reg_idx) } template <class Impl> -TheISA::FloatReg -O3ThreadContext<Impl>::readFloatRegFlat(int reg_idx) -{ - return cpu->readArchFloatReg(reg_idx, thread->threadId()); -} - -template <class Impl> TheISA::FloatRegBits O3ThreadContext<Impl>::readFloatRegBitsFlat(int reg_idx) { - return cpu->readArchFloatRegInt(reg_idx, thread->threadId()); + return cpu->readArchFloatRegBits(reg_idx, thread->threadId()); } template <class Impl> @@ -253,18 +246,9 @@ O3ThreadContext<Impl>::setIntRegFlat(int reg_idx, uint64_t val) template <class Impl> void -O3ThreadContext<Impl>::setFloatRegFlat(int reg_idx, FloatReg val) -{ - cpu->setArchFloatReg(reg_idx, val, thread->threadId()); - - conditionalSquash(); -} - -template <class Impl> -void O3ThreadContext<Impl>::setFloatRegBitsFlat(int reg_idx, FloatRegBits val) { - cpu->setArchFloatRegInt(reg_idx, val, thread->threadId()); + cpu->setArchFloatRegBits(reg_idx, val, thread->threadId()); conditionalSquash(); } diff --git a/src/cpu/simple/base.cc b/src/cpu/simple/base.cc index 825d3103f..c597ac904 100644 --- a/src/cpu/simple/base.cc +++ b/src/cpu/simple/base.cc @@ -493,7 +493,7 @@ BaseSimpleCPU::preExecute() // maintain $r0 semantics thread->setIntReg(ZeroReg, 0); #if THE_ISA == ALPHA_ISA - thread->setFloatReg(ZeroReg, 0.0); + thread->setFloatRegBits(ZeroReg, 0); #endif // ALPHA_ISA // check for instruction-count-based events diff --git a/src/cpu/simple/exec_context.hh b/src/cpu/simple/exec_context.hh index 8ff18dd60..1aababf35 100644 --- a/src/cpu/simple/exec_context.hh +++ b/src/cpu/simple/exec_context.hh @@ -191,15 +191,6 @@ class SimpleExecContext : public ExecContext { thread->setIntReg(reg.index(), val); } - /** Reads a floating point register of single register width. */ - FloatReg readFloatRegOperand(const StaticInst *si, int idx) override - { - numFpRegReads++; - const RegId& reg = si->srcRegIdx(idx); - assert(reg.isFloatReg()); - return thread->readFloatReg(reg.index()); - } - /** Reads a floating point register in its binary format, instead * of by value. */ FloatRegBits readFloatRegOperandBits(const StaticInst *si, int idx) override @@ -210,16 +201,6 @@ class SimpleExecContext : public ExecContext { return thread->readFloatRegBits(reg.index()); } - /** Sets a floating point register of single width to a value. */ - void setFloatRegOperand(const StaticInst *si, int idx, - FloatReg val) override - { - numFpRegWrites++; - const RegId& reg = si->destRegIdx(idx); - assert(reg.isFloatReg()); - thread->setFloatReg(reg.index(), val); - } - /** Sets the bits of a floating point register of single width * to a binary value. */ void setFloatRegOperandBits(const StaticInst *si, int idx, diff --git a/src/cpu/simple_thread.hh b/src/cpu/simple_thread.hh index 3c64082b8..601aa7c07 100644 --- a/src/cpu/simple_thread.hh +++ b/src/cpu/simple_thread.hh @@ -253,16 +253,6 @@ class SimpleThread : public ThreadState return regVal; } - FloatReg readFloatReg(int reg_idx) - { - int flatIndex = isa->flattenFloatIndex(reg_idx); - assert(flatIndex < TheISA::NumFloatRegs); - FloatReg regVal(readFloatRegFlat(flatIndex)); - DPRINTF(FloatRegs, "Reading float reg %d (%d) as %f, %#x.\n", - reg_idx, flatIndex, regVal, floatRegs.i[flatIndex]); - return regVal; - } - FloatRegBits readFloatRegBits(int reg_idx) { int flatIndex = isa->flattenFloatIndex(reg_idx); @@ -390,15 +380,6 @@ class SimpleThread : public ThreadState setIntRegFlat(flatIndex, val); } - void setFloatReg(int reg_idx, FloatReg val) - { - int flatIndex = isa->flattenFloatIndex(reg_idx); - assert(flatIndex < TheISA::NumFloatRegs); - setFloatRegFlat(flatIndex, val); - DPRINTF(FloatRegs, "Setting float reg %d (%d) to %f, %#x.\n", - reg_idx, flatIndex, val, floatRegs.i[flatIndex]); - } - void setFloatRegBits(int reg_idx, FloatRegBits val) { int flatIndex = isa->flattenFloatIndex(reg_idx); @@ -537,9 +518,6 @@ class SimpleThread : public ThreadState uint64_t readIntRegFlat(int idx) { return intRegs[idx]; } void setIntRegFlat(int idx, uint64_t val) { intRegs[idx] = val; } - FloatReg readFloatRegFlat(int idx) { return floatRegs.f[idx]; } - void setFloatRegFlat(int idx, FloatReg val) { floatRegs.f[idx] = val; } - FloatRegBits readFloatRegBitsFlat(int idx) { return floatRegs.i[idx]; } void setFloatRegBitsFlat(int idx, FloatRegBits val) { floatRegs.i[idx] = val; diff --git a/src/cpu/thread_context.hh b/src/cpu/thread_context.hh index 1e3064956..f9dfd8345 100644 --- a/src/cpu/thread_context.hh +++ b/src/cpu/thread_context.hh @@ -210,8 +210,6 @@ class ThreadContext // virtual uint64_t readIntReg(int reg_idx) = 0; - virtual FloatReg readFloatReg(int reg_idx) = 0; - virtual FloatRegBits readFloatRegBits(int reg_idx) = 0; virtual const VecRegContainer& readVecReg(const RegId& reg) const = 0; @@ -252,8 +250,6 @@ class ThreadContext virtual void setIntReg(int reg_idx, uint64_t val) = 0; - virtual void setFloatReg(int reg_idx, FloatReg val) = 0; - virtual void setFloatRegBits(int reg_idx, FloatRegBits val) = 0; virtual void setVecReg(const RegId& reg, const VecRegContainer& val) = 0; @@ -337,9 +333,6 @@ class ThreadContext virtual uint64_t readIntRegFlat(int idx) = 0; virtual void setIntRegFlat(int idx, uint64_t val) = 0; - virtual FloatReg readFloatRegFlat(int idx) = 0; - virtual void setFloatRegFlat(int idx, FloatReg val) = 0; - virtual FloatRegBits readFloatRegBitsFlat(int idx) = 0; virtual void setFloatRegBitsFlat(int idx, FloatRegBits val) = 0; @@ -464,9 +457,6 @@ class ProxyThreadContext : public ThreadContext uint64_t readIntReg(int reg_idx) { return actualTC->readIntReg(reg_idx); } - FloatReg readFloatReg(int reg_idx) - { return actualTC->readFloatReg(reg_idx); } - FloatRegBits readFloatRegBits(int reg_idx) { return actualTC->readFloatRegBits(reg_idx); } @@ -522,9 +512,6 @@ class ProxyThreadContext : public ThreadContext void setIntReg(int reg_idx, uint64_t val) { actualTC->setIntReg(reg_idx, val); } - void setFloatReg(int reg_idx, FloatReg val) - { actualTC->setFloatReg(reg_idx, val); } - void setFloatRegBits(int reg_idx, FloatRegBits val) { actualTC->setFloatRegBits(reg_idx, val); } @@ -584,12 +571,6 @@ class ProxyThreadContext : public ThreadContext void setIntRegFlat(int idx, uint64_t val) { actualTC->setIntRegFlat(idx, val); } - FloatReg readFloatRegFlat(int idx) - { return actualTC->readFloatRegFlat(idx); } - - void setFloatRegFlat(int idx, FloatReg val) - { actualTC->setFloatRegFlat(idx, val); } - FloatRegBits readFloatRegBitsFlat(int idx) { return actualTC->readFloatRegBitsFlat(idx); } |