2006-01-25 01:57:17 +01:00
|
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2003-2005 The Regents of The University of Michigan
|
|
|
|
|
* All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
|
* modification, are permitted provided that the following conditions are
|
|
|
|
|
* met: redistributions of source code must retain the above copyright
|
|
|
|
|
* notice, this list of conditions and the following disclaimer;
|
|
|
|
|
* redistributions in binary form must reproduce the above copyright
|
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
|
* documentation and/or other materials provided with the distribution;
|
|
|
|
|
* neither the name of the copyright holders nor the names of its
|
|
|
|
|
* contributors may be used to endorse or promote products derived from
|
|
|
|
|
* this software without specific prior written permission.
|
|
|
|
|
*
|
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
*/
|
|
|
|
|
|
2006-01-26 22:19:44 +01:00
|
|
|
|
#ifndef __ARCH_MIPS_ISA_TRAITS_HH__
|
|
|
|
|
#define __ARCH_MIPS_ISA_TRAITS_HH__
|
2006-01-25 01:57:17 +01:00
|
|
|
|
|
2006-03-08 08:05:38 +01:00
|
|
|
|
//#include "arch/mips/misc_regfile.hh"
|
2006-04-26 22:13:47 +02:00
|
|
|
|
#include "arch/mips/faults.hh"
|
2006-01-25 01:57:17 +01:00
|
|
|
|
#include "base/misc.hh"
|
2006-02-22 04:02:05 +01:00
|
|
|
|
#include "config/full_system.hh"
|
2006-04-26 22:13:47 +02:00
|
|
|
|
#include "sim/byteswap.hh"
|
2006-01-25 01:57:17 +01:00
|
|
|
|
#include "sim/host.hh"
|
2006-02-22 04:02:05 +01:00
|
|
|
|
#include "sim/faults.hh"
|
2006-01-25 01:57:17 +01:00
|
|
|
|
|
2006-03-08 08:05:38 +01:00
|
|
|
|
#include <vector>
|
|
|
|
|
|
2006-01-25 01:57:17 +01:00
|
|
|
|
class FastCPU;
|
2006-01-26 22:19:44 +01:00
|
|
|
|
class FullCPU;
|
|
|
|
|
class Checkpoint;
|
2006-03-15 22:26:40 +01:00
|
|
|
|
class ExecContext;
|
2006-01-25 01:57:17 +01:00
|
|
|
|
|
2006-03-08 08:05:38 +01:00
|
|
|
|
namespace LittleEndianGuest {};
|
|
|
|
|
|
2006-01-26 22:19:44 +01:00
|
|
|
|
#define TARGET_MIPS
|
2006-01-25 01:57:17 +01:00
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
class StaticInst;
|
|
|
|
|
class StaticInstPtr;
|
2006-01-25 01:57:17 +01:00
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
namespace MIPS34K {
|
|
|
|
|
int DTB_ASN_ASN(uint64_t reg);
|
|
|
|
|
int ITB_ASN_ASN(uint64_t reg);
|
2006-03-08 08:05:38 +01:00
|
|
|
|
};
|
2006-01-25 01:57:17 +01:00
|
|
|
|
|
2006-03-12 11:57:34 +01:00
|
|
|
|
#if !FULL_SYSTEM
|
|
|
|
|
class SyscallReturn {
|
|
|
|
|
public:
|
|
|
|
|
template <class T>
|
|
|
|
|
SyscallReturn(T v, bool s)
|
|
|
|
|
{
|
2006-04-10 18:23:17 +02:00
|
|
|
|
retval = (uint32_t)v;
|
2006-03-12 11:57:34 +01:00
|
|
|
|
success = s;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
|
SyscallReturn(T v)
|
|
|
|
|
{
|
|
|
|
|
success = (v >= 0);
|
2006-04-10 18:23:17 +02:00
|
|
|
|
retval = (uint32_t)v;
|
2006-03-12 11:57:34 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
~SyscallReturn() {}
|
|
|
|
|
|
|
|
|
|
SyscallReturn& operator=(const SyscallReturn& s) {
|
|
|
|
|
retval = s.retval;
|
|
|
|
|
success = s.success;
|
|
|
|
|
return *this;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool successful() { return success; }
|
|
|
|
|
uint64_t value() { return retval; }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
uint64_t retval;
|
|
|
|
|
bool success;
|
|
|
|
|
};
|
|
|
|
|
#endif
|
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
namespace MipsISA
|
2006-01-25 01:57:17 +01:00
|
|
|
|
{
|
Enable register windows.
arch/alpha/isa_traits.hh:
arch/mips/isa_traits.cc:
Turned the integer register file into a class instead of a typedef to an array.
arch/alpha/regfile.hh:
Changed the integer register file into a class instead of a typedef to an array. Also put the parts of the register file, ie the int, float, and misc register files, pc, npc, and nnpc, behind accessor functions. Added a changeContext function, and ContextParam and ContextVal types, so that things like the register window can be changed through call backs.
arch/mips/isa_traits.hh:
Turned the integer register file into a class instead of a typedef to an array. Also moved a "using namespace" into the namespace definition.
arch/sparc/isa_traits.hh:
Turned the integer register file into a class instead of a typedef to an array. Also "fixed" the max number of src and dest regs. They may need to be even larger.
arch/sparc/regfile.hh:
Changed the integer register file into a class instead of a typedef to an array. Also put the parts of the register file, ie the int, float, and misc register files, pc, npc, and nnpc, behind accessor functions. Added a changeContext function, and ContextParam and ContextVal types, so that things like the register window can be changed through call backs. Created setCWP and setAltGlobals functions for the IntRegFile.
cpu/cpu_exec_context.hh:
Used the accessor functions for the register file, and added a changeRegFileContext function to call back into the RegFile. Used the RegFile clear function rather than memsetting it to 0.
cpu/exec_context.hh:
Added the changeRegFileContext function.
cpu/exetrace.cc:
Use the TheISA::NumIntRegs constant, and use readReg now that the integer register file is a class instead of an array.
cpu/exetrace.hh:
Get the address of the regs object, now that it isn't an array.
--HG--
extra : convert_revision : ea2dd81be1c2e66b3c684af319eb58f8a77fd49c
2006-04-06 20:47:03 +02:00
|
|
|
|
using namespace LittleEndianGuest;
|
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
typedef uint32_t MachInst;
|
2006-03-12 11:57:34 +01:00
|
|
|
|
typedef uint32_t MachInst;
|
|
|
|
|
typedef uint64_t ExtMachInst;
|
2006-02-22 04:02:05 +01:00
|
|
|
|
typedef uint8_t RegIndex;
|
2006-03-12 11:57:34 +01:00
|
|
|
|
// typedef uint64_t Addr;
|
2006-03-15 00:28:51 +01:00
|
|
|
|
|
|
|
|
|
// Constants Related to the number of registers
|
|
|
|
|
|
|
|
|
|
const int NumIntArchRegs = 32;
|
|
|
|
|
const int NumPALShadowRegs = 8;
|
|
|
|
|
const int NumFloatArchRegs = 32;
|
|
|
|
|
// @todo: Figure out what this number really should be.
|
2006-04-26 22:13:47 +02:00
|
|
|
|
const int NumMiscArchRegs = 265;
|
2006-03-15 00:28:51 +01:00
|
|
|
|
|
|
|
|
|
const int NumIntRegs = NumIntArchRegs + NumPALShadowRegs;
|
|
|
|
|
const int NumFloatRegs = NumFloatArchRegs;
|
|
|
|
|
const int NumMiscRegs = NumMiscArchRegs;
|
|
|
|
|
|
|
|
|
|
const int TotalNumRegs = NumIntRegs + NumFloatRegs +
|
|
|
|
|
NumMiscRegs + 0/*NumInternalProcRegs*/;
|
|
|
|
|
|
|
|
|
|
const int TotalDataRegs = NumIntRegs + NumFloatRegs;
|
|
|
|
|
|
|
|
|
|
// Static instruction parameters
|
|
|
|
|
const int MaxInstSrcRegs = 3;
|
|
|
|
|
const int MaxInstDestRegs = 2;
|
|
|
|
|
|
|
|
|
|
// semantically meaningful register indices
|
2006-03-15 22:26:40 +01:00
|
|
|
|
const int ZeroReg = 0;
|
|
|
|
|
const int AssemblerReg = 1;
|
|
|
|
|
const int ReturnValueReg1 = 2;
|
|
|
|
|
const int ReturnValueReg2 = 3;
|
|
|
|
|
const int ArgumentReg0 = 4;
|
|
|
|
|
const int ArgumentReg1 = 5;
|
|
|
|
|
const int ArgumentReg2 = 6;
|
|
|
|
|
const int ArgumentReg3 = 7;
|
|
|
|
|
const int KernelReg0 = 26;
|
|
|
|
|
const int KernelReg1 = 27;
|
|
|
|
|
const int GlobalPointerReg = 28;
|
|
|
|
|
const int StackPointerReg = 29;
|
|
|
|
|
const int FramePointerReg = 30;
|
|
|
|
|
const int ReturnAddressReg = 31;
|
|
|
|
|
|
|
|
|
|
const int SyscallNumReg = ReturnValueReg1;
|
2006-03-19 19:40:03 +01:00
|
|
|
|
const int SyscallPseudoReturnReg = ReturnValueReg1;
|
2006-04-10 18:23:17 +02:00
|
|
|
|
const int SyscallSuccessReg = ArgumentReg3;
|
2006-03-15 00:28:51 +01:00
|
|
|
|
|
|
|
|
|
const int LogVMPageSize = 13; // 8K bytes
|
|
|
|
|
const int VMPageSize = (1 << LogVMPageSize);
|
|
|
|
|
|
|
|
|
|
const int BranchPredAddrShiftAmt = 2; // instructions are 4-byte aligned
|
|
|
|
|
|
2006-03-15 23:04:50 +01:00
|
|
|
|
const int MachineBytes = 4;
|
2006-03-15 00:28:51 +01:00
|
|
|
|
const int WordBytes = 4;
|
|
|
|
|
const int HalfwordBytes = 2;
|
|
|
|
|
const int ByteBytes = 1;
|
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
|
|
|
|
|
// These enumerate all the registers for dependence tracking.
|
|
|
|
|
enum DependenceTags {
|
|
|
|
|
// 0..31 are the integer regs 0..31
|
|
|
|
|
// 32..63 are the FP regs 0..31, i.e. use (reg + FP_Base_DepTag)
|
|
|
|
|
FP_Base_DepTag = 32,
|
|
|
|
|
Ctrl_Base_DepTag = 64,
|
|
|
|
|
Fpcr_DepTag = 64, // floating point control register
|
|
|
|
|
Uniq_DepTag = 65,
|
2006-03-08 08:05:38 +01:00
|
|
|
|
IPR_Base_DepTag = 66,
|
|
|
|
|
MiscReg_DepTag = 67
|
2006-02-22 04:02:05 +01:00
|
|
|
|
};
|
|
|
|
|
|
2006-04-12 09:44:45 +02:00
|
|
|
|
typedef uint64_t IntReg;
|
2006-04-10 18:57:59 +02:00
|
|
|
|
class IntRegFile
|
|
|
|
|
{
|
|
|
|
|
protected:
|
|
|
|
|
IntReg regs[NumIntRegs];
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
IntReg readReg(int intReg)
|
|
|
|
|
{
|
|
|
|
|
return regs[intReg];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setReg(int intReg, const IntReg &val)
|
|
|
|
|
{
|
|
|
|
|
regs[intReg] = val;
|
|
|
|
|
return NoFault;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void serialize(std::ostream &os);
|
|
|
|
|
|
|
|
|
|
void unserialize(Checkpoint *cp, const std::string §ion);
|
|
|
|
|
|
|
|
|
|
};
|
2006-02-22 04:02:05 +01:00
|
|
|
|
|
2006-03-15 22:26:40 +01:00
|
|
|
|
typedef double FloatReg;
|
|
|
|
|
typedef uint64_t FloatRegBits;
|
2006-04-26 22:13:47 +02:00
|
|
|
|
|
|
|
|
|
const int SingleWidth = 32;
|
|
|
|
|
const int SingleBytes = SingleWidth / 4;
|
|
|
|
|
|
|
|
|
|
const int DoubleWidth = 64;
|
|
|
|
|
const int DoubleBytes = DoubleWidth / 4;
|
|
|
|
|
|
|
|
|
|
const int QuadWidth = 128;
|
|
|
|
|
const int QuadBytes = QuadWidth / 4;
|
|
|
|
|
|
|
|
|
|
const int FloatRegSize = SingleWidth / SingleBytes;
|
|
|
|
|
const int DoubleRegSize = FloatRegSize * 2;
|
|
|
|
|
|
2006-04-12 09:44:45 +02:00
|
|
|
|
class FloatRegFile
|
2006-03-15 22:26:40 +01:00
|
|
|
|
{
|
|
|
|
|
protected:
|
|
|
|
|
|
2006-04-26 22:13:47 +02:00
|
|
|
|
//Since the floating point registers overlap each other,
|
|
|
|
|
//A generic storage space is used. The float to be returned is
|
|
|
|
|
//pulled from the appropriate section of this region.
|
|
|
|
|
char regSpace[FloatRegSize * NumFloatRegs];
|
2006-03-15 22:26:40 +01:00
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
2006-04-26 22:13:47 +02:00
|
|
|
|
void clear()
|
2006-03-15 22:26:40 +01:00
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
bzero(regSpace, sizeof(regSpace));
|
2006-03-15 22:26:40 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FloatReg readReg(int floatReg, int width)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
//In each of these cases, we have to copy the value into a temporary
|
|
|
|
|
//variable. This is because we may otherwise try to access an
|
|
|
|
|
//unaligned portion of memory.
|
|
|
|
|
switch(width)
|
|
|
|
|
{
|
|
|
|
|
case SingleWidth:
|
|
|
|
|
float result32;
|
|
|
|
|
memcpy(&result32, regSpace + 4 * floatReg, FloatRegSize);
|
|
|
|
|
return htog(result32);
|
|
|
|
|
|
|
|
|
|
case DoubleWidth:
|
|
|
|
|
double result64;
|
|
|
|
|
memcpy(&result64, regSpace + 4 * floatReg, DoubleRegSize);
|
|
|
|
|
return htog(result64);
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
panic("Attempted to read a %d bit floating point register!", width);
|
|
|
|
|
}
|
2006-03-15 22:26:40 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FloatRegBits readRegBits(int floatReg, int width)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
//In each of these cases, we have to copy the value into a temporary
|
|
|
|
|
//variable. This is because we may otherwise try to access an
|
|
|
|
|
//unaligned portion of memory.
|
|
|
|
|
switch(width)
|
|
|
|
|
{
|
|
|
|
|
case SingleWidth:
|
|
|
|
|
uint32_t result32;
|
|
|
|
|
memcpy(&result32, regSpace + 4 * floatReg, FloatRegSize);
|
|
|
|
|
return htog(result32);
|
2006-04-27 22:44:12 +02:00
|
|
|
|
|
2006-04-26 22:13:47 +02:00
|
|
|
|
case DoubleWidth:
|
|
|
|
|
uint64_t result64;
|
|
|
|
|
memcpy(&result64, regSpace + 4 * floatReg, DoubleRegSize);
|
|
|
|
|
return htog(result64);
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
panic("Attempted to read a %d bit floating point register!", width);
|
|
|
|
|
}
|
2006-03-15 22:26:40 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setReg(int floatReg, const FloatReg &val, int width)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
//In each of these cases, we have to copy the value into a temporary
|
|
|
|
|
//variable. This is because we may otherwise try to access an
|
|
|
|
|
//unaligned portion of memory.
|
|
|
|
|
switch(width)
|
|
|
|
|
{
|
|
|
|
|
case SingleWidth:
|
|
|
|
|
uint32_t result32;
|
|
|
|
|
result32 = gtoh((uint32_t)val);
|
|
|
|
|
memcpy(regSpace + 4 * floatReg, &result32, FloatRegSize);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DoubleWidth:
|
|
|
|
|
uint64_t result64;
|
|
|
|
|
result64 = gtoh((uint64_t)val);
|
|
|
|
|
memcpy(regSpace + 4 * floatReg, &result64, DoubleRegSize);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
panic("Attempted to read a %d bit floating point register!", width);
|
|
|
|
|
}
|
2006-03-15 22:26:40 +01:00
|
|
|
|
return NoFault;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setRegBits(int floatReg, const FloatRegBits &val, int width)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
//In each of these cases, we have to copy the value into a temporary
|
|
|
|
|
//variable. This is because we may otherwise try to access an
|
|
|
|
|
//unaligned portion of memory.
|
|
|
|
|
switch(width)
|
|
|
|
|
{
|
|
|
|
|
case SingleWidth:
|
|
|
|
|
uint32_t result32;
|
|
|
|
|
result32 = gtoh((uint32_t)val);
|
|
|
|
|
memcpy(regSpace + 4 * floatReg, &result32, FloatRegSize);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DoubleWidth:
|
|
|
|
|
uint64_t result64;
|
|
|
|
|
result64 = gtoh((uint64_t)val);
|
|
|
|
|
memcpy(regSpace + 4 * floatReg, &result64, DoubleRegSize);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
panic("Attempted to read a %d bit floating point register!", width);
|
|
|
|
|
}
|
|
|
|
|
return NoFault;
|
2006-03-15 22:26:40 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void serialize(std::ostream &os);
|
|
|
|
|
|
|
|
|
|
void unserialize(Checkpoint *cp, const std::string §ion);
|
|
|
|
|
};
|
|
|
|
|
|
2006-04-28 06:24:25 +02:00
|
|
|
|
enum ConvertType{
|
|
|
|
|
SINGLE_TO_DOUBLE,
|
|
|
|
|
SINGLE_TO_WORD,
|
|
|
|
|
SINGLE_TO_LONG,
|
|
|
|
|
|
|
|
|
|
DOUBLE_TO_SINGLE,
|
|
|
|
|
DOUBLE_TO_WORD,
|
|
|
|
|
DOUBLE_TO_LONG,
|
|
|
|
|
|
|
|
|
|
LONG_TO_SINGLE,
|
|
|
|
|
LONG_TO_DOUBLE,
|
|
|
|
|
LONG_TO_WORD,
|
|
|
|
|
|
|
|
|
|
WORD_TO_SINGLE,
|
|
|
|
|
WORD_TO_DOUBLE,
|
|
|
|
|
WORD_TO_LONG,
|
|
|
|
|
|
|
|
|
|
PLOWER_TO_SINGLE,
|
|
|
|
|
PUPPER_TO_SINGLE
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
enum RoundMode{
|
|
|
|
|
RND_ZERO,
|
|
|
|
|
RND_DOWN,
|
|
|
|
|
RND_UP,
|
|
|
|
|
RND_NEAREST
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
uint64_t convert_and_round(uint64_t fp_val,ConvertType cvt_type, int rnd_mode = 0);
|
|
|
|
|
|
2006-04-26 22:13:47 +02:00
|
|
|
|
|
2006-03-15 22:26:40 +01:00
|
|
|
|
void copyRegs(ExecContext *src, ExecContext *dest);
|
2006-02-22 04:02:05 +01:00
|
|
|
|
|
2006-03-08 08:05:38 +01:00
|
|
|
|
// cop-0/cop-1 system control register file
|
2006-02-22 04:02:05 +01:00
|
|
|
|
typedef uint64_t MiscReg;
|
2006-04-10 18:57:59 +02:00
|
|
|
|
//typedef MiscReg MiscRegFile[NumMiscRegs];
|
2006-03-09 09:27:51 +01:00
|
|
|
|
class MiscRegFile {
|
2006-03-12 11:57:34 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
protected:
|
|
|
|
|
uint64_t fpcr; // floating point condition codes
|
|
|
|
|
uint64_t uniq; // process-unique register
|
|
|
|
|
bool lock_flag; // lock flag for LL/SC
|
|
|
|
|
Addr lock_addr; // lock address for LL/SC
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
MiscReg miscRegFile[NumMiscRegs];
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
//These functions should be removed once the simplescalar cpu model
|
|
|
|
|
//has been replaced.
|
|
|
|
|
int getInstAsid();
|
|
|
|
|
int getDataAsid();
|
|
|
|
|
|
2006-03-12 11:57:34 +01:00
|
|
|
|
void copyMiscRegs(ExecContext *xc);
|
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
MiscReg readReg(int misc_reg)
|
|
|
|
|
{ return miscRegFile[misc_reg]; }
|
|
|
|
|
|
|
|
|
|
MiscReg readRegWithEffect(int misc_reg, Fault &fault, ExecContext *xc)
|
|
|
|
|
{ return miscRegFile[misc_reg];}
|
|
|
|
|
|
|
|
|
|
Fault setReg(int misc_reg, const MiscReg &val)
|
|
|
|
|
{ miscRegFile[misc_reg] = val; return NoFault; }
|
|
|
|
|
|
|
|
|
|
Fault setRegWithEffect(int misc_reg, const MiscReg &val,
|
|
|
|
|
ExecContext *xc)
|
|
|
|
|
{ miscRegFile[misc_reg] = val; return NoFault; }
|
|
|
|
|
|
|
|
|
|
#if FULL_SYSTEM
|
2006-03-12 11:57:34 +01:00
|
|
|
|
void clearIprs() { }
|
2006-03-09 09:27:51 +01:00
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
InternalProcReg ipr[NumInternalProcRegs]; // Internal processor regs
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MiscReg readIpr(int idx, Fault &fault, ExecContext *xc) { }
|
|
|
|
|
|
|
|
|
|
Fault setIpr(int idx, uint64_t val, ExecContext *xc) { }
|
|
|
|
|
#endif
|
|
|
|
|
friend class RegFile;
|
|
|
|
|
};
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
|
|
|
|
enum MiscRegTags {
|
|
|
|
|
//Coprocessor 0 Registers
|
|
|
|
|
//Reference MIPS32 Arch. for Programmers, Vol. III, Ch.8
|
|
|
|
|
//(Register Number-Register Select) Summary of Register
|
|
|
|
|
//------------------------------------------------------
|
2006-03-08 10:36:55 +01:00
|
|
|
|
Index = 0, //0-0 Index into the TLB array
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
2006-03-08 10:36:55 +01:00
|
|
|
|
MVPControl = 1, //0-1 Per-processor register containing global
|
2006-03-08 08:05:38 +01:00
|
|
|
|
//MIPS<50> MT configuration data
|
|
|
|
|
|
2006-03-08 10:36:55 +01:00
|
|
|
|
MVPConf0 = 2, //0-2 Per-processor register containing global
|
2006-03-08 08:05:38 +01:00
|
|
|
|
//MIPS<50> MT configuration data
|
|
|
|
|
|
2006-03-08 10:36:55 +01:00
|
|
|
|
MVPConf1 = 3, //0-3 Per-processor register containing global
|
2006-03-08 08:05:38 +01:00
|
|
|
|
//MIPS<50> MT configuration data
|
|
|
|
|
|
2006-03-08 10:36:55 +01:00
|
|
|
|
Random = 8, //1-0 Randomly generated index into the TLB array
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
2006-03-08 10:36:55 +01:00
|
|
|
|
VPEControl = 9, //1-1 Per-VPE register containing relatively volatile
|
2006-03-08 08:05:38 +01:00
|
|
|
|
//thread configuration data
|
|
|
|
|
|
2006-03-08 10:36:55 +01:00
|
|
|
|
VPEConf0 = 10, //1-2 Per-VPE multi-thread configuration
|
2006-03-08 08:05:38 +01:00
|
|
|
|
//information
|
|
|
|
|
|
|
|
|
|
|
2006-03-08 10:36:55 +01:00
|
|
|
|
VPEConf1 = 11, //1-2 Per-VPE multi-thread configuration
|
2006-03-08 08:05:38 +01:00
|
|
|
|
//information
|
|
|
|
|
|
2006-03-08 10:36:55 +01:00
|
|
|
|
YQMask = 12, //Per-VPE register defining which YIELD
|
2006-03-08 08:05:38 +01:00
|
|
|
|
//qualifier bits may be used without generating
|
|
|
|
|
//an exception
|
|
|
|
|
|
2006-03-08 10:36:55 +01:00
|
|
|
|
VPESchedule = 13,
|
|
|
|
|
VPEScheFBack = 14,
|
|
|
|
|
VPEOpt = 15,
|
|
|
|
|
EntryLo0 = 16, // Bank 3: 16 - 23
|
|
|
|
|
TCStatus = 17,
|
|
|
|
|
TCBind = 18,
|
|
|
|
|
TCRestart = 19,
|
|
|
|
|
TCHalt = 20,
|
|
|
|
|
TCContext = 21,
|
|
|
|
|
TCSchedule = 22,
|
|
|
|
|
TCScheFBack = 23,
|
|
|
|
|
|
|
|
|
|
EntryLo1 = 24,// Bank 4: 24 - 31
|
|
|
|
|
|
|
|
|
|
Context = 32, // Bank 5: 32 - 39
|
|
|
|
|
ContextConfig = 33,
|
|
|
|
|
|
|
|
|
|
//PageMask = 40, //Bank 6: 40 - 47
|
|
|
|
|
PageGrain = 41,
|
|
|
|
|
|
|
|
|
|
Wired = 48, //Bank 7:48 - 55
|
|
|
|
|
SRSConf0 = 49,
|
|
|
|
|
SRSConf1 = 50,
|
|
|
|
|
SRSConf2 = 51,
|
|
|
|
|
SRSConf3 = 52,
|
|
|
|
|
SRSConf4 = 53,
|
|
|
|
|
BadVAddr = 54,
|
|
|
|
|
|
|
|
|
|
HWRena = 56,//Bank 8:56 - 63
|
|
|
|
|
|
|
|
|
|
Count = 64, //Bank 9:64 - 71
|
|
|
|
|
|
|
|
|
|
EntryHi = 72,//Bank 10:72 - 79
|
|
|
|
|
|
|
|
|
|
Compare = 80,//Bank 11:80 - 87
|
|
|
|
|
|
|
|
|
|
Status = 88,//Bank 12:88 - 96 //12-0 Processor status and control
|
|
|
|
|
IntCtl = 89, //12-1 Interrupt system status and control
|
|
|
|
|
SRSCtl = 90, //12-2 Shadow register set status and control
|
|
|
|
|
SRSMap = 91, //12-3 Shadow set IPL mapping
|
|
|
|
|
|
|
|
|
|
Cause = 97,//97-104 //13-0 Cause of last general exception
|
|
|
|
|
|
|
|
|
|
EPC = 105,//105-112 //14-0 Program counter at last exception
|
|
|
|
|
|
2006-03-12 11:57:34 +01:00
|
|
|
|
PRId = 113,//113-120, //15-0 Processor identification and revision
|
2006-03-08 10:36:55 +01:00
|
|
|
|
EBase = 114, //15-1 Exception vector base register
|
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
Config = 121,//Bank 16: 121-128
|
2006-03-08 10:36:55 +01:00
|
|
|
|
Config1 = 122,
|
|
|
|
|
Config2 = 123,
|
|
|
|
|
Config3 = 124,
|
|
|
|
|
Config6 = 127,
|
|
|
|
|
Config7 = 128,
|
|
|
|
|
|
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
LLAddr = 129,//Bank 17: 129-136
|
2006-03-08 10:36:55 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
WatchLo0 = 137,//Bank 18: 137-144
|
2006-03-08 10:36:55 +01:00
|
|
|
|
WatchLo1 = 138,
|
|
|
|
|
WatchLo2 = 139,
|
|
|
|
|
WatchLo3 = 140,
|
|
|
|
|
WatchLo4 = 141,
|
|
|
|
|
WatchLo5 = 142,
|
|
|
|
|
WatchLo6 = 143,
|
|
|
|
|
WatchLo7 = 144,
|
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
WatchHi0 = 145,//Bank 19: 145-152
|
2006-03-08 10:36:55 +01:00
|
|
|
|
WatchHi1 = 146,
|
|
|
|
|
WatchHi2 = 147,
|
|
|
|
|
WatchHi3 = 148,
|
|
|
|
|
WatchHi4 = 149,
|
|
|
|
|
WatchHi5 = 150,
|
|
|
|
|
WatchHi6 = 151,
|
|
|
|
|
WatchHi7 = 152,
|
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
XCContext64 = 153,//Bank 20: 153-160
|
2006-03-08 10:36:55 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
//Bank 21: 161-168
|
2006-03-08 10:36:55 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
//Bank 22: 169-176
|
2006-03-08 10:36:55 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
Debug = 177, //Bank 23: 177-184
|
2006-03-08 10:36:55 +01:00
|
|
|
|
TraceControl1 = 178,
|
|
|
|
|
TraceControl2 = 179,
|
|
|
|
|
UserTraceData = 180,
|
|
|
|
|
TraceBPC = 181,
|
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
DEPC = 185,//Bank 24: 185-192
|
2006-03-08 10:36:55 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
PerfCnt0 = 193,//Bank 25: 193 - 200
|
2006-03-08 10:36:55 +01:00
|
|
|
|
PerfCnt1 = 194,
|
|
|
|
|
PerfCnt2 = 195,
|
|
|
|
|
PerfCnt3 = 196,
|
|
|
|
|
PerfCnt4 = 197,
|
|
|
|
|
PerfCnt5 = 198,
|
|
|
|
|
PerfCnt6 = 199,
|
|
|
|
|
PerfCnt7 = 200,
|
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
ErrCtl = 201, //Bank 26: 201 - 208
|
2006-03-08 10:36:55 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
CacheErr0 = 209, //Bank 27: 209 - 216
|
2006-03-08 10:36:55 +01:00
|
|
|
|
CacheErr1 = 210,
|
|
|
|
|
CacheErr2 = 211,
|
|
|
|
|
CacheErr3 = 212,
|
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
TagLo0 = 217,//Bank 28: 217 - 224
|
|
|
|
|
DataLo1 = 218,
|
2006-03-08 10:36:55 +01:00
|
|
|
|
TagLo2 = 219,
|
2006-03-09 09:27:51 +01:00
|
|
|
|
DataLo3 = 220,
|
2006-03-08 10:36:55 +01:00
|
|
|
|
TagLo4 = 221,
|
2006-03-09 09:27:51 +01:00
|
|
|
|
DataLo5 = 222,
|
2006-03-08 10:36:55 +01:00
|
|
|
|
TagLo6 = 223,
|
2006-03-09 09:27:51 +01:00
|
|
|
|
DataLo7 = 234,
|
2006-03-08 10:36:55 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
TagHi0 = 233,//Bank 29: 233 - 240
|
|
|
|
|
DataHi1 = 234,
|
2006-03-08 10:36:55 +01:00
|
|
|
|
TagHi2 = 235,
|
2006-03-09 09:27:51 +01:00
|
|
|
|
DataHi3 = 236,
|
2006-03-08 10:36:55 +01:00
|
|
|
|
TagHi4 = 237,
|
2006-03-09 09:27:51 +01:00
|
|
|
|
DataHi5 = 238,
|
2006-03-08 10:36:55 +01:00
|
|
|
|
TagHi6 = 239,
|
2006-03-09 09:27:51 +01:00
|
|
|
|
DataHi7 = 240,
|
2006-03-08 10:36:55 +01:00
|
|
|
|
|
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
ErrorEPC = 249,//Bank 30: 241 - 248
|
2006-03-08 10:36:55 +01:00
|
|
|
|
|
2006-03-09 09:27:51 +01:00
|
|
|
|
DESAVE = 257,//Bank 31: 249-256
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
|
|
|
|
//More Misc. Regs
|
|
|
|
|
Hi,
|
|
|
|
|
Lo,
|
2006-04-11 00:41:25 +02:00
|
|
|
|
FIR,
|
2006-03-08 08:05:38 +01:00
|
|
|
|
FCSR,
|
|
|
|
|
FPCR,
|
|
|
|
|
|
|
|
|
|
//Alpha Regs, but here now, for
|
|
|
|
|
//compiling sake
|
2006-03-09 09:27:51 +01:00
|
|
|
|
UNIQ,
|
|
|
|
|
LockAddr,
|
|
|
|
|
LockFlag
|
2006-03-08 08:05:38 +01:00
|
|
|
|
};
|
2006-02-22 04:02:05 +01:00
|
|
|
|
|
|
|
|
|
extern const Addr PageShift;
|
|
|
|
|
extern const Addr PageBytes;
|
|
|
|
|
extern const Addr PageMask;
|
|
|
|
|
extern const Addr PageOffset;
|
|
|
|
|
|
|
|
|
|
#if FULL_SYSTEM
|
|
|
|
|
|
|
|
|
|
typedef uint64_t InternalProcReg;
|
|
|
|
|
|
|
|
|
|
#include "arch/mips/isa_fullsys_traits.hh"
|
|
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
enum {
|
|
|
|
|
NumInternalProcRegs = 0
|
|
|
|
|
};
|
|
|
|
|
#endif
|
2006-01-25 01:57:17 +01:00
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
typedef union {
|
|
|
|
|
IntReg intreg;
|
|
|
|
|
FloatReg fpreg;
|
|
|
|
|
MiscReg ctrlreg;
|
|
|
|
|
} AnyReg;
|
|
|
|
|
|
2006-04-10 18:57:59 +02:00
|
|
|
|
class RegFile {
|
|
|
|
|
protected:
|
2006-02-22 04:02:05 +01:00
|
|
|
|
IntRegFile intRegFile; // (signed) integer register file
|
|
|
|
|
FloatRegFile floatRegFile; // floating point register file
|
2006-04-10 18:57:59 +02:00
|
|
|
|
MiscRegFile miscRegFile; // control register file
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
void clear()
|
|
|
|
|
{
|
|
|
|
|
bzero(&intRegFile, sizeof(intRegFile));
|
|
|
|
|
bzero(&floatRegFile, sizeof(floatRegFile));
|
|
|
|
|
bzero(&miscRegFile, sizeof(miscRegFile));
|
|
|
|
|
}
|
Enable register windows.
arch/alpha/isa_traits.hh:
arch/mips/isa_traits.cc:
Turned the integer register file into a class instead of a typedef to an array.
arch/alpha/regfile.hh:
Changed the integer register file into a class instead of a typedef to an array. Also put the parts of the register file, ie the int, float, and misc register files, pc, npc, and nnpc, behind accessor functions. Added a changeContext function, and ContextParam and ContextVal types, so that things like the register window can be changed through call backs.
arch/mips/isa_traits.hh:
Turned the integer register file into a class instead of a typedef to an array. Also moved a "using namespace" into the namespace definition.
arch/sparc/isa_traits.hh:
Turned the integer register file into a class instead of a typedef to an array. Also "fixed" the max number of src and dest regs. They may need to be even larger.
arch/sparc/regfile.hh:
Changed the integer register file into a class instead of a typedef to an array. Also put the parts of the register file, ie the int, float, and misc register files, pc, npc, and nnpc, behind accessor functions. Added a changeContext function, and ContextParam and ContextVal types, so that things like the register window can be changed through call backs. Created setCWP and setAltGlobals functions for the IntRegFile.
cpu/cpu_exec_context.hh:
Used the accessor functions for the register file, and added a changeRegFileContext function to call back into the RegFile. Used the RegFile clear function rather than memsetting it to 0.
cpu/exec_context.hh:
Added the changeRegFileContext function.
cpu/exetrace.cc:
Use the TheISA::NumIntRegs constant, and use readReg now that the integer register file is a class instead of an array.
cpu/exetrace.hh:
Get the address of the regs object, now that it isn't an array.
--HG--
extra : convert_revision : ea2dd81be1c2e66b3c684af319eb58f8a77fd49c
2006-04-06 20:47:03 +02:00
|
|
|
|
|
2006-04-10 18:57:59 +02:00
|
|
|
|
MiscReg readMiscReg(int miscReg)
|
|
|
|
|
{
|
|
|
|
|
return miscRegFile.readReg(miscReg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MiscReg readMiscRegWithEffect(int miscReg,
|
|
|
|
|
Fault &fault, ExecContext *xc)
|
|
|
|
|
{
|
|
|
|
|
fault = NoFault;
|
|
|
|
|
return miscRegFile.readRegWithEffect(miscReg, fault, xc);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setMiscReg(int miscReg, const MiscReg &val)
|
|
|
|
|
{
|
|
|
|
|
return miscRegFile.setReg(miscReg, val);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setMiscRegWithEffect(int miscReg, const MiscReg &val,
|
|
|
|
|
ExecContext * xc)
|
|
|
|
|
{
|
|
|
|
|
return miscRegFile.setRegWithEffect(miscReg, val, xc);
|
|
|
|
|
}
|
|
|
|
|
|
2006-04-26 22:13:47 +02:00
|
|
|
|
|
2006-04-10 18:57:59 +02:00
|
|
|
|
FloatReg readFloatReg(int floatReg)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
return floatRegFile.readReg(floatReg,SingleWidth);
|
2006-04-10 18:57:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FloatReg readFloatReg(int floatReg, int width)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
return floatRegFile.readReg(floatReg,width);
|
2006-04-10 18:57:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FloatRegBits readFloatRegBits(int floatReg)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
return floatRegFile.readRegBits(floatReg,SingleWidth);
|
2006-04-10 18:57:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FloatRegBits readFloatRegBits(int floatReg, int width)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
return floatRegFile.readRegBits(floatReg,width);
|
2006-04-10 18:57:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setFloatReg(int floatReg, const FloatReg &val)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
return floatRegFile.setReg(floatReg, val, SingleWidth);
|
2006-04-10 18:57:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setFloatReg(int floatReg, const FloatReg &val, int width)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
return floatRegFile.setReg(floatReg, val, width);
|
2006-04-10 18:57:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setFloatRegBits(int floatReg, const FloatRegBits &val)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
return floatRegFile.setRegBits(floatReg, val, SingleWidth);
|
2006-04-10 18:57:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setFloatRegBits(int floatReg, const FloatRegBits &val, int width)
|
|
|
|
|
{
|
2006-04-26 22:13:47 +02:00
|
|
|
|
return floatRegFile.setRegBits(floatReg, val, width);
|
2006-04-10 18:57:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
IntReg readIntReg(int intReg)
|
|
|
|
|
{
|
|
|
|
|
return intRegFile.readReg(intReg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setIntReg(int intReg, const IntReg &val)
|
|
|
|
|
{
|
|
|
|
|
return intRegFile.setReg(intReg, val);
|
|
|
|
|
}
|
|
|
|
|
protected:
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
Addr pc; // program counter
|
|
|
|
|
Addr npc; // next-cycle program counter
|
2006-03-08 08:05:38 +01:00
|
|
|
|
Addr nnpc; // next-next-cycle program counter
|
|
|
|
|
// used to implement branch delay slot
|
|
|
|
|
// not real register
|
2006-04-10 18:57:59 +02:00
|
|
|
|
public:
|
|
|
|
|
Addr readPC()
|
|
|
|
|
{
|
|
|
|
|
return pc;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void setPC(Addr val)
|
|
|
|
|
{
|
|
|
|
|
pc = val;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Addr readNextPC()
|
|
|
|
|
{
|
|
|
|
|
return npc;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void setNextPC(Addr val)
|
|
|
|
|
{
|
|
|
|
|
npc = val;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Addr readNextNPC()
|
|
|
|
|
{
|
|
|
|
|
return nnpc;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void setNextNPC(Addr val)
|
|
|
|
|
{
|
|
|
|
|
nnpc = val;
|
|
|
|
|
}
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
|
|
|
|
MiscReg hi; // MIPS HI Register
|
|
|
|
|
MiscReg lo; // MIPS LO Register
|
|
|
|
|
|
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
#if FULL_SYSTEM
|
|
|
|
|
IntReg palregs[NumIntRegs]; // PAL shadow registers
|
|
|
|
|
InternalProcReg ipr[NumInternalProcRegs]; // internal processor regs
|
|
|
|
|
int intrflag; // interrupt flag
|
|
|
|
|
bool pal_shadow; // using pal_shadow registers
|
2006-03-08 08:05:38 +01:00
|
|
|
|
inline int instAsid() { return MIPS34K::ITB_ASN_ASN(ipr[IPR_ITB_ASN]); }
|
|
|
|
|
inline int dataAsid() { return MIPS34K::DTB_ASN_ASN(ipr[IPR_DTB_ASN]); }
|
2006-02-22 04:02:05 +01:00
|
|
|
|
#endif // FULL_SYSTEM
|
|
|
|
|
|
2006-03-08 08:05:38 +01:00
|
|
|
|
//void initCP0Regs();
|
2006-02-22 04:02:05 +01:00
|
|
|
|
void serialize(std::ostream &os);
|
|
|
|
|
void unserialize(Checkpoint *cp, const std::string §ion);
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
|
|
|
|
void createCP0Regs();
|
|
|
|
|
void coldReset();
|
Enable register windows.
arch/alpha/isa_traits.hh:
arch/mips/isa_traits.cc:
Turned the integer register file into a class instead of a typedef to an array.
arch/alpha/regfile.hh:
Changed the integer register file into a class instead of a typedef to an array. Also put the parts of the register file, ie the int, float, and misc register files, pc, npc, and nnpc, behind accessor functions. Added a changeContext function, and ContextParam and ContextVal types, so that things like the register window can be changed through call backs.
arch/mips/isa_traits.hh:
Turned the integer register file into a class instead of a typedef to an array. Also moved a "using namespace" into the namespace definition.
arch/sparc/isa_traits.hh:
Turned the integer register file into a class instead of a typedef to an array. Also "fixed" the max number of src and dest regs. They may need to be even larger.
arch/sparc/regfile.hh:
Changed the integer register file into a class instead of a typedef to an array. Also put the parts of the register file, ie the int, float, and misc register files, pc, npc, and nnpc, behind accessor functions. Added a changeContext function, and ContextParam and ContextVal types, so that things like the register window can be changed through call backs. Created setCWP and setAltGlobals functions for the IntRegFile.
cpu/cpu_exec_context.hh:
Used the accessor functions for the register file, and added a changeRegFileContext function to call back into the RegFile. Used the RegFile clear function rather than memsetting it to 0.
cpu/exec_context.hh:
Added the changeRegFileContext function.
cpu/exetrace.cc:
Use the TheISA::NumIntRegs constant, and use readReg now that the integer register file is a class instead of an array.
cpu/exetrace.hh:
Get the address of the regs object, now that it isn't an array.
--HG--
extra : convert_revision : ea2dd81be1c2e66b3c684af319eb58f8a77fd49c
2006-04-06 20:47:03 +02:00
|
|
|
|
|
|
|
|
|
typedef int ContextParam;
|
|
|
|
|
typedef int ContextVal;
|
|
|
|
|
|
|
|
|
|
void changeContext(ContextParam param, ContextVal val)
|
|
|
|
|
{
|
|
|
|
|
}
|
2006-02-22 04:02:05 +01:00
|
|
|
|
};
|
|
|
|
|
|
2006-03-12 11:57:34 +01:00
|
|
|
|
StaticInstPtr decodeInst(ExtMachInst);
|
2006-02-22 04:02:05 +01:00
|
|
|
|
|
|
|
|
|
// return a no-op instruction... used for instruction fetch faults
|
|
|
|
|
extern const MachInst NoopMachInst;
|
|
|
|
|
|
|
|
|
|
enum annotes {
|
|
|
|
|
ANNOTE_NONE = 0,
|
|
|
|
|
// An impossible number for instruction annotations
|
|
|
|
|
ITOUCH_ANNOTE = 0xffffffff,
|
|
|
|
|
};
|
|
|
|
|
|
2006-03-12 11:57:34 +01:00
|
|
|
|
//void getMiscRegIdx(int reg_name,int &idx, int &sel);
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
2006-03-12 11:57:34 +01:00
|
|
|
|
static inline ExtMachInst
|
|
|
|
|
makeExtMI(MachInst inst, const uint64_t &pc) {
|
|
|
|
|
#if FULL_SYSTEM
|
|
|
|
|
ExtMachInst ext_inst = inst;
|
|
|
|
|
if (pc && 0x1)
|
|
|
|
|
return ext_inst|=(static_cast<ExtMachInst>(pc & 0x1) << 32);
|
|
|
|
|
else
|
|
|
|
|
return ext_inst;
|
|
|
|
|
#else
|
|
|
|
|
return ExtMachInst(inst);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
2006-03-08 08:05:38 +01:00
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
static inline bool isCallerSaveIntegerRegister(unsigned int reg) {
|
|
|
|
|
panic("register classification not implemented");
|
|
|
|
|
return (reg >= 1 && reg <= 8 || reg >= 22 && reg <= 25 || reg == 27);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline bool isCalleeSaveIntegerRegister(unsigned int reg) {
|
|
|
|
|
panic("register classification not implemented");
|
|
|
|
|
return (reg >= 9 && reg <= 15);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline bool isCallerSaveFloatRegister(unsigned int reg) {
|
|
|
|
|
panic("register classification not implemented");
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline bool isCalleeSaveFloatRegister(unsigned int reg) {
|
|
|
|
|
panic("register classification not implemented");
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline Addr alignAddress(const Addr &addr,
|
|
|
|
|
unsigned int nbytes) {
|
|
|
|
|
return (addr & ~(nbytes - 1));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Instruction address compression hooks
|
|
|
|
|
static inline Addr realPCToFetchPC(const Addr &addr) {
|
|
|
|
|
return addr;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline Addr fetchPCToRealPC(const Addr &addr) {
|
|
|
|
|
return addr;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// the size of "fetched" instructions (not necessarily the size
|
|
|
|
|
// of real instructions for PISA)
|
|
|
|
|
static inline size_t fetchInstSize() {
|
|
|
|
|
return sizeof(MachInst);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static inline MachInst makeRegisterCopy(int dest, int src) {
|
|
|
|
|
panic("makeRegisterCopy not implemented");
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2006-03-12 11:57:34 +01:00
|
|
|
|
static inline void setSyscallReturn(SyscallReturn return_value, RegFile *regs)
|
|
|
|
|
{
|
2006-03-18 17:31:31 +01:00
|
|
|
|
if (return_value.successful()) {
|
|
|
|
|
// no error
|
2006-04-10 18:57:59 +02:00
|
|
|
|
regs->setIntReg(SyscallSuccessReg, 0);
|
|
|
|
|
regs->setIntReg(ReturnValueReg1, return_value.value());
|
2006-03-18 17:31:31 +01:00
|
|
|
|
} else {
|
|
|
|
|
// got an error, return details
|
2006-04-10 18:57:59 +02:00
|
|
|
|
regs->setIntReg(SyscallSuccessReg, (IntReg) -1);
|
|
|
|
|
regs->setIntReg(ReturnValueReg1, -return_value.value());
|
2006-03-18 17:31:31 +01:00
|
|
|
|
}
|
2006-03-12 11:57:34 +01:00
|
|
|
|
}
|
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
// Machine operations
|
|
|
|
|
|
|
|
|
|
void saveMachineReg(AnyReg &savereg, const RegFile ®_file,
|
|
|
|
|
int regnum);
|
|
|
|
|
|
|
|
|
|
void restoreMachineReg(RegFile ®s, const AnyReg ®,
|
|
|
|
|
int regnum);
|
|
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
|
static void serializeSpecialRegs(const Serializable::Proxy &proxy,
|
|
|
|
|
const RegFile ®s);
|
|
|
|
|
|
|
|
|
|
static void unserializeSpecialRegs(const IniFile *db,
|
|
|
|
|
const std::string &category,
|
|
|
|
|
ConfigNode *node,
|
|
|
|
|
RegFile ®s);
|
|
|
|
|
#endif
|
2006-01-25 01:57:17 +01:00
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
/**
|
|
|
|
|
* Function to insure ISA semantics about 0 registers.
|
|
|
|
|
* @param xc The execution context.
|
|
|
|
|
*/
|
|
|
|
|
template <class XC>
|
|
|
|
|
void zeroRegisters(XC *xc);
|
|
|
|
|
|
2006-03-08 08:05:38 +01:00
|
|
|
|
const Addr MaxAddr = (Addr)-1;
|
2006-01-25 01:57:17 +01:00
|
|
|
|
};
|
|
|
|
|
|
2006-02-22 04:02:05 +01:00
|
|
|
|
#if FULL_SYSTEM
|
|
|
|
|
//typedef TheISA::InternalProcReg InternalProcReg;
|
|
|
|
|
//const int NumInternalProcRegs = TheISA::NumInternalProcRegs;
|
|
|
|
|
//const int NumInterruptLevels = TheISA::NumInterruptLevels;
|
2006-01-25 01:57:17 +01:00
|
|
|
|
|
2006-02-20 20:48:10 +01:00
|
|
|
|
#include "arch/mips/mips34k.hh"
|
2006-01-25 01:57:17 +01:00
|
|
|
|
#endif
|
|
|
|
|
|
2006-03-12 11:57:34 +01:00
|
|
|
|
using namespace MipsISA;
|
|
|
|
|
|
2006-01-26 22:19:44 +01:00
|
|
|
|
#endif // __ARCH_MIPS_ISA_TRAITS_HH__
|