summaryrefslogtreecommitdiff
path: root/arch/alpha/faults.hh
diff options
context:
space:
mode:
authorKevin Lim <ktlim@umich.edu>2006-03-07 20:01:34 -0500
committerKevin Lim <ktlim@umich.edu>2006-03-07 20:01:34 -0500
commit97c4a84985b0f9168f60f28d5cc96be448eef4fa (patch)
tree5d385f2410979c4b4b2164686c87b8a083ad108d /arch/alpha/faults.hh
parent11aead894d4186916b587b1449075f276319a235 (diff)
parentab67095b2a43b5f2d44d1e1a517d1079ddf9f104 (diff)
downloadgem5-97c4a84985b0f9168f60f28d5cc96be448eef4fa.tar.xz
Merge ktlim@zizzer:/bk/m5
into zamp.eecs.umich.edu:/z/ktlim2/m5-proxyxc arch/alpha/faults.cc: Hand merge. --HG-- rename : arch/alpha/linux_process.cc => arch/alpha/linux/process.cc rename : arch/alpha/tru64_process.cc => arch/alpha/tru64/process.cc extra : convert_revision : 6ea1fae5be0ebd02eff330423d16da63b790516d
Diffstat (limited to 'arch/alpha/faults.hh')
-rw-r--r--arch/alpha/faults.hh67
1 files changed, 34 insertions, 33 deletions
diff --git a/arch/alpha/faults.hh b/arch/alpha/faults.hh
index c4a72e07c..1a196cc94 100644
--- a/arch/alpha/faults.hh
+++ b/arch/alpha/faults.hh
@@ -38,7 +38,7 @@ namespace AlphaISA
typedef const Addr FaultVect;
-class AlphaFault : public virtual FaultBase
+class AlphaFault : public FaultBase
{
protected:
virtual bool skipFaultingInstruction() {return false;}
@@ -48,6 +48,7 @@ class AlphaFault : public virtual FaultBase
void invoke(ExecContext * xc);
#endif
virtual FaultVect vect() = 0;
+ virtual FaultStat & countStat() = 0;
};
class MachineCheckFault : public AlphaFault
@@ -55,11 +56,11 @@ class MachineCheckFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
bool isMachineCheckFault() {return true;}
};
@@ -68,11 +69,11 @@ class AlignmentFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
bool isAlignmentFault() {return true;}
};
@@ -91,11 +92,11 @@ class ResetFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class ArithmeticFault : public AlphaFault
@@ -105,11 +106,11 @@ class ArithmeticFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
#if FULL_SYSTEM
void invoke(ExecContext * xc);
#endif
@@ -122,11 +123,11 @@ class InterruptFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class NDtbMissFault : public AlphaFault
@@ -134,11 +135,11 @@ class NDtbMissFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class PDtbMissFault : public AlphaFault
@@ -146,11 +147,11 @@ class PDtbMissFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class DtbPageFault : public AlphaFault
@@ -158,11 +159,11 @@ class DtbPageFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class DtbAcvFault : public AlphaFault
@@ -170,11 +171,11 @@ class DtbAcvFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class ItbMissFault : public AlphaFault
@@ -182,11 +183,11 @@ class ItbMissFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class ItbPageFault : public AlphaFault
@@ -194,11 +195,11 @@ class ItbPageFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class ItbAcvFault : public AlphaFault
@@ -206,11 +207,11 @@ class ItbAcvFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class UnimplementedOpcodeFault : public AlphaFault
@@ -218,11 +219,11 @@ class UnimplementedOpcodeFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class FloatEnableFault : public AlphaFault
@@ -230,11 +231,11 @@ class FloatEnableFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class PalFault : public AlphaFault
@@ -244,11 +245,11 @@ class PalFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
class IntegerOverflowFault : public AlphaFault
@@ -256,11 +257,11 @@ class IntegerOverflowFault : public AlphaFault
private:
static FaultName _name;
static FaultVect _vect;
- static FaultStat _stat;
+ static FaultStat _count;
public:
FaultName name() {return _name;}
FaultVect vect() {return _vect;}
- FaultStat & stat() {return _stat;}
+ FaultStat & countStat() {return _count;}
};
} // AlphaISA namespace