* Authors: Gabe Black
*/
+#include "arch/x86/decoder.hh"
#include "arch/x86/faults.hh"
#include "base/trace.hh"
#include "config/full_system.hh"
void X86Interrupt::invoke(ThreadContext * tc)
{
- panic("X86 faults are not implemented!");
+ using namespace X86ISAInst::RomLabels;
+ HandyM5Reg m5reg = tc->readMiscRegNoEffect(MISCREG_M5_REG);
+ MicroPC entry;
+ if (m5reg.mode == LongMode) {
+ entry = extern_label_longModeInterrupt;
+ } else {
+ entry = extern_label_legacyModeInterrupt;
+ }
+ tc->setIntReg(INTREG_MICRO(1), vector);
+ tc->setIntReg(INTREG_MICRO(7), tc->readPC());
+ tc->setMicroPC(romMicroPC(entry));
+ tc->setNextMicroPC(romMicroPC(entry) + 1);
}
void FakeITLBFault::invoke(ThreadContext * tc)
class X86Interrupt : public X86FaultBase
{
protected:
- X86Interrupt(const char * name, const char * mnem,
+ uint8_t vector;
+ X86Interrupt(const char * name, const char * mnem, uint8_t _vector,
uint64_t _errorCode = 0) :
- X86FaultBase(name, mnem, _errorCode)
+ X86FaultBase(name, mnem, _errorCode), vector(_vector)
{}
#if FULL_SYSTEM
class NonMaskableInterrupt : public X86Interrupt
{
- uint8_t vector;
public:
NonMaskableInterrupt(uint8_t _vector) :
- X86Interrupt("Non Maskable Interrupt", "#NMI"), vector(_vector)
+ X86Interrupt("Non Maskable Interrupt", "#NMI", _vector)
{}
};
class ExternalInterrupt : public X86Interrupt
{
- uint8_t vector;
public:
ExternalInterrupt(uint8_t _vector) :
- X86Interrupt("External Interrupt", "#INTR"), vector(_vector)
+ X86Interrupt("External Interrupt", "#INTR", _vector)
{}
};
{
public:
SystemManagementInterrupt() :
- X86Interrupt("System Management Interrupt", "#SMI")
+ X86Interrupt("System Management Interrupt", "#SMI", 0)
{}
};
uint8_t vector;
public:
InitInterrupt(uint8_t _vector) :
- X86Interrupt("INIT Interrupt", "#INIT"), vector(_vector)
+ X86Interrupt("INIT Interrupt", "#INIT", _vector)
{}
};
class SoftwareInterrupt : public X86Interrupt
{
public:
- SoftwareInterrupt() :
- X86Interrupt("Software Interrupt", "INTn")
+ SoftwareInterrupt(uint8_t _vector) :
+ X86Interrupt("Software Interrupt", "INTn", _vector)
{}
};