03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync * XFree86 int10 module
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync * execute BIOS int 10h calls in x86 real mode environment
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync * Copyright 1999 Egbert Eich
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync/* int10 info structure */
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsynctypedef struct {
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsynctypedef struct {
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync/* OS dependent functions */
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT xf86Int10InfoPtr xf86InitInt10(int entityIndex);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT xf86Int10InfoPtr xf86ExtendedInitInt10(int entityIndex,
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT void xf86FreeInt10(xf86Int10InfoPtr pInt);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT void *xf86Int10AllocPages(xf86Int10InfoPtr pInt, int num,
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT void xf86Int10FreePages(xf86Int10InfoPtr pInt, void *pbase,
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT pointer xf86int10Addr(xf86Int10InfoPtr pInt, CARD32 addr);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync/* x86 executor related functions */
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT void xf86ExecX86int10(xf86Int10InfoPtr pInt);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#else /* a bug in DGUX requires this - let's try it */
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define BIOS_SCRATCH_LEN (BIOS_SCRATCH_END - BIOS_SCRATCH_OFF + 1)
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define SEG_ADR(type, seg, reg) type((seg << 4) + (X86_##reg))
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define SEG_EADR(type, seg, reg) type((seg << 4) + (X86_E##reg))
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define X86_VIF_MASK 0x00080000 /* virtual interrupt flag */
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define X86_VIP_MASK 0x00100000 /* virtual interrupt pending */
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define MEM_RB(name, addr) (*name->mem->rb)(name, addr)
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define MEM_RW(name, addr) (*name->mem->rw)(name, addr)
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define MEM_RL(name, addr) (*name->mem->rl)(name, addr)
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define MEM_WB(name, addr, val) (*name->mem->wb)(name, addr, val)
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define MEM_WW(name, addr, val) (*name->mem->ww)(name, addr, val)
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#define MEM_WL(name, addr, val) (*name->mem->wl)(name, addr, val)
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync/* OS dependent functions */
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT Bool MapCurrentInt10(xf86Int10InfoPtr pInt);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync/* x86 executor related functions */
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT Bool xf86Int10ExecSetup(xf86Int10InfoPtr pInt);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncvoid LockLegacyVGA(xf86Int10InfoPtr pInt, legacyVGAPtr vga);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncvoid UnlockLegacyVGA(xf86Int10InfoPtr pInt, legacyVGAPtr vga);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#if defined (_PC)
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT void xf86Int10SaveRestoreBIOSVars(xf86Int10InfoPtr pInt,
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT void *xf86HandleInt10Options(ScrnInfoPtr pScrn,
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync const unsigned char *vbiosMem);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT BusType xf86int10GetBiosLocationType(const xf86Int10InfoPtr
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncextern _X_EXPORT Bool xf86int10GetBiosSegment(xf86Int10InfoPtr pInt,
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsyncvoid dprint(unsigned long start, unsigned long size);
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#endif /* _INT10_PRIVATE */
03532efdc331b598d3dedc8cc7477641c3b0dd12vboxsync#endif /* _XF86INT10_H */