only set stuff up for binning interrupts if interrupt binning is on
kern/linux/linux_system.cc: Don't scheduling interrupt events if we are not binning interrupts kern/tru64/tru64_system.cc: set the bin_int boolean in the system structure --HG-- extra : convert_revision : 68eea9c448f1c481fc79be1777acb536d6385495
This commit is contained in:
parent
ac422ac949
commit
a7c089ab06
|
@ -145,29 +145,32 @@ LinuxSystem::LinuxSystem(Params *p)
|
||||||
printThreadEvent->schedule(addr + sizeof(MachInst) * 6);
|
printThreadEvent->schedule(addr + sizeof(MachInst) * 6);
|
||||||
|
|
||||||
intStartEvent = new InterruptStartEvent(&pcEventQueue, "intStartEvent");
|
intStartEvent = new InterruptStartEvent(&pcEventQueue, "intStartEvent");
|
||||||
if (palSymtab->findAddress("sys_int_21", addr))
|
|
||||||
intStartEvent->schedule(addr + sizeof(MachInst) * 2);
|
|
||||||
else
|
|
||||||
panic("could not find symbol: sys_int_21\n");
|
|
||||||
|
|
||||||
intEndEvent = new InterruptEndEvent(&pcEventQueue, "intEndEvent");
|
if (params->bin_int) {
|
||||||
if (palSymtab->findAddress("rti_to_kern", addr))
|
if (palSymtab->findAddress("sys_int_21", addr))
|
||||||
intEndEvent->schedule(addr) ;
|
intStartEvent->schedule(addr + sizeof(MachInst) * 2);
|
||||||
else
|
else
|
||||||
panic("could not find symbol: rti_to_kern\n");
|
panic("could not find symbol: sys_int_21\n");
|
||||||
|
|
||||||
intEndEvent2 = new InterruptEndEvent(&pcEventQueue, "intEndEvent2");
|
intEndEvent = new InterruptEndEvent(&pcEventQueue, "intEndEvent");
|
||||||
if (palSymtab->findAddress("rti_to_user", addr))
|
if (palSymtab->findAddress("rti_to_kern", addr))
|
||||||
intEndEvent2->schedule(addr);
|
intEndEvent->schedule(addr) ;
|
||||||
else
|
else
|
||||||
panic("could not find symbol: rti_to_user\n");
|
panic("could not find symbol: rti_to_kern\n");
|
||||||
|
|
||||||
|
intEndEvent2 = new InterruptEndEvent(&pcEventQueue, "intEndEvent2");
|
||||||
|
if (palSymtab->findAddress("rti_to_user", addr))
|
||||||
|
intEndEvent2->schedule(addr);
|
||||||
|
else
|
||||||
|
panic("could not find symbol: rti_to_user\n");
|
||||||
|
|
||||||
|
|
||||||
intEndEvent3 = new InterruptEndEvent(&pcEventQueue, "intEndEvent3");
|
intEndEvent3 = new InterruptEndEvent(&pcEventQueue, "intEndEvent3");
|
||||||
if (kernelSymtab->findAddress("do_softirq", addr))
|
if (kernelSymtab->findAddress("do_softirq", addr))
|
||||||
intEndEvent3->schedule(addr + sizeof(MachInst) * 2);
|
intEndEvent3->schedule(addr + sizeof(MachInst) * 2);
|
||||||
else
|
else
|
||||||
panic("could not find symbol: do_softirq\n");
|
panic("could not find symbol: do_softirq\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
LinuxSystem::~LinuxSystem()
|
LinuxSystem::~LinuxSystem()
|
||||||
|
|
|
@ -168,6 +168,7 @@ CREATE_SIM_OBJECT(Tru64System)
|
||||||
p->system_rev = system_rev;
|
p->system_rev = system_rev;
|
||||||
p->bin = bin;
|
p->bin = bin;
|
||||||
p->binned_fns = binned_fns;
|
p->binned_fns = binned_fns;
|
||||||
|
p->bin_int = false;
|
||||||
|
|
||||||
return new Tru64System(p);
|
return new Tru64System(p);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue