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-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-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 {};
|
|
|
|
|
using 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)
|
|
|
|
|
{
|
|
|
|
|
retval = (uint64_t)v;
|
|
|
|
|
success = s;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
|
SyscallReturn(T v)
|
|
|
|
|
{
|
|
|
|
|
success = (v >= 0);
|
|
|
|
|
retval = (uint64_t)v;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
~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
|
|
|
|
{
|
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.
|
|
|
|
|
const int NumMiscArchRegs = 32;
|
|
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
const int SyscallSuccessReg = ReturnValueReg1;
|
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
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
typedef uint64_t IntReg;
|
|
|
|
|
typedef IntReg IntRegFile[NumIntRegs];
|
|
|
|
|
|
2006-03-15 22:26:40 +01:00
|
|
|
|
/* floating point register file entry type
|
2006-02-22 04:02:05 +01:00
|
|
|
|
typedef union {
|
|
|
|
|
uint64_t q;
|
|
|
|
|
double d;
|
2006-03-15 22:26:40 +01:00
|
|
|
|
} FloatReg;*/
|
2006-02-22 04:02:05 +01:00
|
|
|
|
|
2006-03-15 22:26:40 +01:00
|
|
|
|
typedef double FloatReg;
|
|
|
|
|
typedef uint64_t FloatRegBits;
|
|
|
|
|
|
|
|
|
|
/*typedef union {
|
2006-02-22 04:02:05 +01:00
|
|
|
|
uint64_t q[NumFloatRegs]; // integer qword view
|
|
|
|
|
double d[NumFloatRegs]; // double-precision floating point view
|
2006-03-15 22:26:40 +01:00
|
|
|
|
} FloatRegFile;*/
|
|
|
|
|
|
|
|
|
|
class FloatRegFile
|
|
|
|
|
{
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
FloatRegBits q[NumFloatRegs]; // integer qword view
|
|
|
|
|
double d[NumFloatRegs]; // double-precision floating point view
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
FloatReg readReg(int floatReg)
|
|
|
|
|
{
|
|
|
|
|
return d[floatReg];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FloatReg readReg(int floatReg, int width)
|
|
|
|
|
{
|
|
|
|
|
return readReg(floatReg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FloatRegBits readRegBits(int floatReg)
|
|
|
|
|
{
|
|
|
|
|
return q[floatReg];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
FloatRegBits readRegBits(int floatReg, int width)
|
|
|
|
|
{
|
|
|
|
|
return readRegBits(floatReg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setReg(int floatReg, const FloatReg &val)
|
|
|
|
|
{
|
|
|
|
|
d[floatReg] = val;
|
|
|
|
|
return NoFault;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setReg(int floatReg, const FloatReg &val, int width)
|
|
|
|
|
{
|
|
|
|
|
return setReg(floatReg, val);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setRegBits(int floatReg, const FloatRegBits &val)
|
|
|
|
|
{
|
|
|
|
|
q[floatReg] = val;
|
|
|
|
|
return NoFault;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Fault setRegBits(int floatReg, const FloatRegBits &val, int width)
|
|
|
|
|
{
|
|
|
|
|
return setRegBits(floatReg, val);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void serialize(std::ostream &os);
|
|
|
|
|
|
|
|
|
|
void unserialize(Checkpoint *cp, const std::string §ion);
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
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-03-09 09:27:51 +01:00
|
|
|
|
//typedef MiscReg MiscRegFile[NumMiscRegs];
|
|
|
|
|
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,
|
|
|
|
|
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;
|
|
|
|
|
|
|
|
|
|
struct RegFile {
|
|
|
|
|
IntRegFile intRegFile; // (signed) integer register file
|
|
|
|
|
FloatRegFile floatRegFile; // floating point register file
|
|
|
|
|
MiscRegFile miscRegs; // control register file
|
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
|
|
|
|
|
|
|
|
|
|
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();
|
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
|
|
|
|
// check for error condition. Alpha syscall convention is to
|
|
|
|
|
// indicate success/failure in reg a3 (r19) and put the
|
|
|
|
|
// return value itself in the standard return value reg (v0).
|
|
|
|
|
if (return_value.successful()) {
|
|
|
|
|
// no error
|
|
|
|
|
regs->intRegFile[ReturnValueReg1] = 0;
|
|
|
|
|
regs->intRegFile[ReturnValueReg2] = return_value.value();
|
|
|
|
|
} else {
|
|
|
|
|
// got an error, return details
|
|
|
|
|
regs->intRegFile[ReturnValueReg1] = (IntReg) -1;
|
|
|
|
|
regs->intRegFile[ReturnValueReg2] = -return_value.value();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//regs->intRegFile[ReturnValueReg1] = (IntReg)return_value;
|
2006-03-18 16:51:28 +01:00
|
|
|
|
//panic("Returning from syscall\n");
|
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__
|