git-svn-id: https://www4.informatik.uni-erlangen.de/i4svn/danceos/trunk/devel/fail@1058 8c4709b5-6ec9-48aa-a5cd-a96041d1645a
29 lines
591 B
Plaintext
29 lines
591 B
Plaintext
#ifndef __INTERRUPT_SUPPRESSION_AH__
|
|
#define __INTERRUPT_SUPPRESSION_AH__
|
|
|
|
#include "config/AspectConfig.hpp"
|
|
|
|
#ifdef CONFIG_SUPPRESS_INTERRUPTS
|
|
|
|
#include "../../../bochs/bochs.h"
|
|
#include "../../../bochs/cpu/cpu.h"
|
|
#include "../SALInst.hpp"
|
|
|
|
aspect Interrupt_FI
|
|
{
|
|
pointcut interrupt_method() = "void bx_cpu_c::interrupt(...)";
|
|
|
|
advice execution (interrupt_method()) : around ()
|
|
{
|
|
unsigned vector = *(tjp->arg<0>());
|
|
|
|
if(!sal::simulator.isSuppressedInterrupt(vector)){
|
|
tjp->proceed();
|
|
}
|
|
}
|
|
};
|
|
|
|
#endif // CONFIG_SUPPRESS_INTERRUPTS
|
|
|
|
#endif /* __INTERRUPT_SUPPRESSION_AH__ */
|