"failstar" sounds like a name for a cruise liner from the 80s. As "*" isn't a desirable part of directory names, just name the whole thing "fail/", the core parts being stored in "fail/core/". Additionally fixing two build system dependency issues: - missing jobserver -> protomessages dependency - broken bochs -> fail dependency (add_custom_target DEPENDS only allows plain file dependencies ... cmake for the win) git-svn-id: https://www4.informatik.uni-erlangen.de/i4svn/danceos/trunk/devel/fail@956 8c4709b5-6ec9-48aa-a5cd-a96041d1645a
38 lines
836 B
Plaintext
38 lines
836 B
Plaintext
#ifndef __GUESTSYS_COM_AH__
|
|
#define __GUESTSYS_COM_AH__
|
|
|
|
#include "../../AspectConfig.hpp"
|
|
|
|
#if CONFIG_EVENT_GUESTSYS == 1
|
|
|
|
#include "../../../bochs/bochs.h"
|
|
#include "../../../bochs/cpu/cpu.h"
|
|
#include "../SALInst.hpp"
|
|
|
|
#include "bochs_helpers.hpp"
|
|
|
|
// Fixed "port number" for "Guest system >> Bochs" communication
|
|
#define BOCHS_COM_PORT 0x378
|
|
|
|
aspect GuestSysCom
|
|
{
|
|
|
|
pointcut outInstructions() = "% ...::bx_cpu_c::OUT_DX%(...)";
|
|
|
|
advice execution (outInstructions()) : after ()
|
|
{
|
|
//
|
|
// Event source: "guest system"
|
|
//
|
|
unsigned rDX = getCPU(tjp->that())->gen_reg[2].word.rx; // port number
|
|
unsigned rAL = getCPU(tjp->that())->gen_reg[0].word.byte.rl; // data
|
|
if (rDX == BOCHS_COM_PORT) {
|
|
sal::simulator.onGuestSystemEvent((char)rAL, rDX);
|
|
}
|
|
}
|
|
};
|
|
|
|
#endif // CONFIG_EVENT_GUESTSYS
|
|
|
|
#endif /* __GUESTSYS_COM_AH__ */
|