SCCS merged

arch/alpha/ev5.cc:
    SCCS merged

--HG--
extra : convert_revision : 9d70c1d461dab0ec016fd0616d74a49942aac659
This commit is contained in:
Ali Saidi 2006-02-23 15:08:08 -05:00
parent e1c3acd91c
commit 4f831bc561

View file

@ -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(&regs, true); AlphaISA::swap_palshadow(&regs, 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;
} }
/** /**