ev5.cc:
SCCS merged arch/alpha/ev5.cc: SCCS merged --HG-- extra : convert_revision : 9d70c1d461dab0ec016fd0616d74a49942aac659
This commit is contained in:
parent
e1c3acd91c
commit
4f831bc561
1 changed files with 30 additions and 40 deletions
|
@ -79,7 +79,7 @@ AlphaISA::initCPU(RegFile *regs, int cpuId)
|
||||||
regs->intRegFile[16] = cpuId;
|
regs->intRegFile[16] = cpuId;
|
||||||
regs->intRegFile[0] = cpuId;
|
regs->intRegFile[0] = cpuId;
|
||||||
|
|
||||||
regs->pc = regs->ipr[IPR_PAL_BASE] + fault_addr[Reset_Fault];
|
regs->pc = regs->ipr[IPR_PAL_BASE] + fault_addr(ResetFault);
|
||||||
regs->npc = regs->pc + sizeof(MachInst);
|
regs->npc = regs->pc + sizeof(MachInst);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,25 +87,15 @@ AlphaISA::initCPU(RegFile *regs, int cpuId)
|
||||||
//
|
//
|
||||||
// alpha exceptions - value equals trap address, update with MD_FAULT_TYPE
|
// alpha exceptions - value equals trap address, update with MD_FAULT_TYPE
|
||||||
//
|
//
|
||||||
Addr
|
const Addr
|
||||||
AlphaISA::fault_addr[Num_Faults] = {
|
AlphaISA::fault_addr(Fault fault)
|
||||||
0x0000, /* No_Fault */
|
{
|
||||||
0x0001, /* Reset_Fault */
|
//Check for the system wide faults
|
||||||
0x0401, /* Machine_Check_Fault */
|
if(fault == NoFault) return 0x0000;
|
||||||
0x0501, /* Arithmetic_Fault */
|
else if(fault == MachineCheckFault) return 0x0401;
|
||||||
0x0101, /* Interrupt_Fault */
|
else if(fault == AlignmentFault) return 0x0301;
|
||||||
0x0201, /* Ndtb_Miss_Fault */
|
//Deal with the alpha specific faults
|
||||||
0x0281, /* Pdtb_Miss_Fault */
|
return ((AlphaFault*)fault)->vect;
|
||||||
0x0301, /* Alignment_Fault */
|
|
||||||
0x0381, /* DTB_Fault_Fault */
|
|
||||||
0x0381, /* DTB_Acv_Fault */
|
|
||||||
0x0181, /* ITB_Miss_Fault */
|
|
||||||
0x0181, /* ITB_Fault_Fault */
|
|
||||||
0x0081, /* ITB_Acv_Fault */
|
|
||||||
0x0481, /* Unimplemented_Opcode_Fault */
|
|
||||||
0x0581, /* Fen_Fault */
|
|
||||||
0x2001, /* Pal_Fault */
|
|
||||||
0x0501, /* Integer_Overflow_Fault: maps to Arithmetic_Fault */
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const int AlphaISA::reg_redir[AlphaISA::NumIntRegs] = {
|
const int AlphaISA::reg_redir[AlphaISA::NumIntRegs] = {
|
||||||
|
@ -172,7 +162,7 @@ AlphaISA::processInterrupts(CPU *cpu)
|
||||||
if (ipl && ipl > ipr[IPR_IPLR]) {
|
if (ipl && ipl > ipr[IPR_IPLR]) {
|
||||||
ipr[IPR_ISR] = summary;
|
ipr[IPR_ISR] = summary;
|
||||||
ipr[IPR_INTID] = ipl;
|
ipr[IPR_INTID] = ipl;
|
||||||
cpu->trap(Interrupt_Fault);
|
cpu->trap(InterruptFault);
|
||||||
DPRINTF(Flow, "Interrupt! IPLR=%d ipl=%d summary=%x\n",
|
DPRINTF(Flow, "Interrupt! IPLR=%d ipl=%d summary=%x\n",
|
||||||
ipr[IPR_IPLR], ipl, summary);
|
ipr[IPR_IPLR], ipl, summary);
|
||||||
}
|
}
|
||||||
|
@ -193,23 +183,23 @@ AlphaISA::zeroRegisters(CPU *cpu)
|
||||||
void
|
void
|
||||||
ExecContext::ev5_trap(Fault fault)
|
ExecContext::ev5_trap(Fault fault)
|
||||||
{
|
{
|
||||||
DPRINTF(Fault, "Fault %s at PC: %#x\n", FaultName(fault), regs.pc);
|
DPRINTF(Fault, "Fault %s at PC: %#x\n", fault->name, regs.pc);
|
||||||
cpu->recordEvent(csprintf("Fault %s", FaultName(fault)));
|
cpu->recordEvent(csprintf("Fault %s", fault->name));
|
||||||
|
|
||||||
assert(!misspeculating());
|
assert(!misspeculating());
|
||||||
kernelStats->fault(fault);
|
kernelStats->fault(fault);
|
||||||
|
|
||||||
if (fault == Arithmetic_Fault)
|
if (fault == ArithmeticFault)
|
||||||
panic("Arithmetic traps are unimplemented!");
|
panic("Arithmetic traps are unimplemented!");
|
||||||
|
|
||||||
AlphaISA::InternalProcReg *ipr = regs.ipr;
|
AlphaISA::InternalProcReg *ipr = regs.ipr;
|
||||||
|
|
||||||
// exception restart address
|
// exception restart address
|
||||||
if (fault != Interrupt_Fault || !inPalMode())
|
if (fault != InterruptFault || !inPalMode())
|
||||||
ipr[AlphaISA::IPR_EXC_ADDR] = regs.pc;
|
ipr[AlphaISA::IPR_EXC_ADDR] = regs.pc;
|
||||||
|
|
||||||
if (fault == Pal_Fault || fault == Arithmetic_Fault /* ||
|
if (fault == PalFault || fault == ArithmeticFault /* ||
|
||||||
fault == Interrupt_Fault && !inPalMode() */) {
|
fault == InterruptFault && !inPalMode() */) {
|
||||||
// traps... skip faulting instruction
|
// traps... skip faulting instruction
|
||||||
ipr[AlphaISA::IPR_EXC_ADDR] += 4;
|
ipr[AlphaISA::IPR_EXC_ADDR] += 4;
|
||||||
}
|
}
|
||||||
|
@ -217,7 +207,7 @@ ExecContext::ev5_trap(Fault fault)
|
||||||
if (!inPalMode())
|
if (!inPalMode())
|
||||||
AlphaISA::swap_palshadow(®s, true);
|
AlphaISA::swap_palshadow(®s, true);
|
||||||
|
|
||||||
regs.pc = ipr[AlphaISA::IPR_PAL_BASE] + AlphaISA::fault_addr[fault];
|
regs.pc = ipr[AlphaISA::IPR_PAL_BASE] + AlphaISA::fault_addr(fault);
|
||||||
regs.npc = regs.pc + sizeof(MachInst);
|
regs.npc = regs.pc + sizeof(MachInst);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -226,13 +216,13 @@ void
|
||||||
AlphaISA::intr_post(RegFile *regs, Fault fault, Addr pc)
|
AlphaISA::intr_post(RegFile *regs, Fault fault, Addr pc)
|
||||||
{
|
{
|
||||||
InternalProcReg *ipr = regs->ipr;
|
InternalProcReg *ipr = regs->ipr;
|
||||||
bool use_pc = (fault == No_Fault);
|
bool use_pc = (fault == NoFault);
|
||||||
|
|
||||||
if (fault == Arithmetic_Fault)
|
if (fault == ArithmeticFault)
|
||||||
panic("arithmetic faults NYI...");
|
panic("arithmetic faults NYI...");
|
||||||
|
|
||||||
// compute exception restart address
|
// compute exception restart address
|
||||||
if (use_pc || fault == Pal_Fault || fault == Arithmetic_Fault) {
|
if (use_pc || fault == PalFault || fault == ArithmeticFault) {
|
||||||
// traps... skip faulting instruction
|
// traps... skip faulting instruction
|
||||||
ipr[IPR_EXC_ADDR] = regs->pc + 4;
|
ipr[IPR_EXC_ADDR] = regs->pc + 4;
|
||||||
} else {
|
} else {
|
||||||
|
@ -242,7 +232,7 @@ AlphaISA::intr_post(RegFile *regs, Fault fault, Addr pc)
|
||||||
|
|
||||||
// jump to expection address (PAL PC bit set here as well...)
|
// jump to expection address (PAL PC bit set here as well...)
|
||||||
if (!use_pc)
|
if (!use_pc)
|
||||||
regs->npc = ipr[IPR_PAL_BASE] + fault_addr[fault];
|
regs->npc = ipr[IPR_PAL_BASE] + fault_addr(fault);
|
||||||
else
|
else
|
||||||
regs->npc = ipr[IPR_PAL_BASE] + pc;
|
regs->npc = ipr[IPR_PAL_BASE] + pc;
|
||||||
|
|
||||||
|
@ -255,7 +245,7 @@ ExecContext::hwrei()
|
||||||
uint64_t *ipr = regs.ipr;
|
uint64_t *ipr = regs.ipr;
|
||||||
|
|
||||||
if (!inPalMode())
|
if (!inPalMode())
|
||||||
return Unimplemented_Opcode_Fault;
|
return UnimplementedOpcodeFault;
|
||||||
|
|
||||||
setNextPC(ipr[AlphaISA::IPR_EXC_ADDR]);
|
setNextPC(ipr[AlphaISA::IPR_EXC_ADDR]);
|
||||||
|
|
||||||
|
@ -269,7 +259,7 @@ ExecContext::hwrei()
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME: XXX check for interrupts? XXX
|
// FIXME: XXX check for interrupts? XXX
|
||||||
return No_Fault;
|
return NoFault;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64_t
|
uint64_t
|
||||||
|
@ -367,12 +357,12 @@ ExecContext::readIpr(int idx, Fault &fault)
|
||||||
case AlphaISA::IPR_DTB_IAP:
|
case AlphaISA::IPR_DTB_IAP:
|
||||||
case AlphaISA::IPR_ITB_IA:
|
case AlphaISA::IPR_ITB_IA:
|
||||||
case AlphaISA::IPR_ITB_IAP:
|
case AlphaISA::IPR_ITB_IAP:
|
||||||
fault = Unimplemented_Opcode_Fault;
|
fault = UnimplementedOpcodeFault;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
// invalid IPR
|
// invalid IPR
|
||||||
fault = Unimplemented_Opcode_Fault;
|
fault = UnimplementedOpcodeFault;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -391,7 +381,7 @@ ExecContext::setIpr(int idx, uint64_t val)
|
||||||
uint64_t old;
|
uint64_t old;
|
||||||
|
|
||||||
if (misspeculating())
|
if (misspeculating())
|
||||||
return No_Fault;
|
return NoFault;
|
||||||
|
|
||||||
switch (idx) {
|
switch (idx) {
|
||||||
case AlphaISA::IPR_PALtemp0:
|
case AlphaISA::IPR_PALtemp0:
|
||||||
|
@ -537,7 +527,7 @@ ExecContext::setIpr(int idx, uint64_t val)
|
||||||
case AlphaISA::IPR_ITB_PTE_TEMP:
|
case AlphaISA::IPR_ITB_PTE_TEMP:
|
||||||
case AlphaISA::IPR_DTB_PTE_TEMP:
|
case AlphaISA::IPR_DTB_PTE_TEMP:
|
||||||
// read-only registers
|
// read-only registers
|
||||||
return Unimplemented_Opcode_Fault;
|
return UnimplementedOpcodeFault;
|
||||||
|
|
||||||
case AlphaISA::IPR_HWINT_CLR:
|
case AlphaISA::IPR_HWINT_CLR:
|
||||||
case AlphaISA::IPR_SL_XMIT:
|
case AlphaISA::IPR_SL_XMIT:
|
||||||
|
@ -639,11 +629,11 @@ ExecContext::setIpr(int idx, uint64_t val)
|
||||||
|
|
||||||
default:
|
default:
|
||||||
// invalid IPR
|
// invalid IPR
|
||||||
return Unimplemented_Opcode_Fault;
|
return UnimplementedOpcodeFault;
|
||||||
}
|
}
|
||||||
|
|
||||||
// no error...
|
// no error...
|
||||||
return No_Fault;
|
return NoFault;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in a new issue