mirror of
https://github.com/reactos/wine.git
synced 2024-11-29 14:40:56 +00:00
7afce0e6d6
No longer load wprocs.dll unconditionally. Restored default interrupt handler behavior (reported by Andreas Mohr).
194 lines
4.9 KiB
C
194 lines
4.9 KiB
C
/*
|
|
* Interrupt vectors emulation
|
|
*
|
|
* Copyright 1995 Alexandre Julliard
|
|
*/
|
|
|
|
#include <sys/types.h>
|
|
#include "windef.h"
|
|
#include "wine/winbase16.h"
|
|
#include "miscemu.h"
|
|
#include "msdos.h"
|
|
#include "module.h"
|
|
#include "debugtools.h"
|
|
|
|
DEFAULT_DEBUG_CHANNEL(int);
|
|
|
|
static FARPROC16 INT_Vectors[256];
|
|
|
|
/* Ordinal number for interrupt 0 handler in WPROCS.DLL */
|
|
#define FIRST_INTERRUPT 100
|
|
|
|
|
|
/**********************************************************************
|
|
* INT_GetPMHandler
|
|
*
|
|
* Return the protected mode interrupt vector for a given interrupt.
|
|
*/
|
|
FARPROC16 INT_GetPMHandler( BYTE intnum )
|
|
{
|
|
if (!INT_Vectors[intnum])
|
|
{
|
|
static HMODULE16 wprocs;
|
|
if (!wprocs)
|
|
{
|
|
if (((wprocs = GetModuleHandle16( "wprocs" )) < 32) &&
|
|
((wprocs = LoadLibrary16( "wprocs" )) < 32))
|
|
{
|
|
ERR("could not load wprocs.dll\n");
|
|
return 0;
|
|
}
|
|
}
|
|
if (!(INT_Vectors[intnum] = GetProcAddress16( wprocs, (LPCSTR)(FIRST_INTERRUPT + intnum))))
|
|
{
|
|
WARN("int%x not implemented, returning dummy handler\n", intnum );
|
|
INT_Vectors[intnum] = GetProcAddress16( wprocs, (LPCSTR)(FIRST_INTERRUPT + 256) );
|
|
}
|
|
}
|
|
return INT_Vectors[intnum];
|
|
}
|
|
|
|
|
|
/**********************************************************************
|
|
* INT_SetPMHandler
|
|
*
|
|
* Set the protected mode interrupt handler for a given interrupt.
|
|
*/
|
|
void INT_SetPMHandler( BYTE intnum, FARPROC16 handler )
|
|
{
|
|
TRACE("Set protected mode interrupt vector %02x <- %04x:%04x\n",
|
|
intnum, HIWORD(handler), LOWORD(handler) );
|
|
INT_Vectors[intnum] = handler;
|
|
}
|
|
|
|
|
|
/**********************************************************************
|
|
* INT_GetRMHandler
|
|
*
|
|
* Return the real mode interrupt vector for a given interrupt.
|
|
*/
|
|
FARPROC16 INT_GetRMHandler( BYTE intnum )
|
|
{
|
|
return ((FARPROC16*)DOSMEM_SystemBase())[intnum];
|
|
}
|
|
|
|
|
|
/**********************************************************************
|
|
* INT_SetRMHandler
|
|
*
|
|
* Set the real mode interrupt handler for a given interrupt.
|
|
*/
|
|
void INT_SetRMHandler( BYTE intnum, FARPROC16 handler )
|
|
{
|
|
TRACE("Set real mode interrupt vector %02x <- %04x:%04x\n",
|
|
intnum, HIWORD(handler), LOWORD(handler) );
|
|
((FARPROC16*)DOSMEM_SystemBase())[intnum] = handler;
|
|
}
|
|
|
|
|
|
/**********************************************************************
|
|
* INT_CtxGetHandler
|
|
*
|
|
* Return the interrupt vector for a given interrupt.
|
|
*/
|
|
FARPROC16 INT_CtxGetHandler( CONTEXT86 *context, BYTE intnum )
|
|
{
|
|
if (ISV86(context))
|
|
return INT_GetRMHandler(intnum);
|
|
else
|
|
return INT_GetPMHandler(intnum);
|
|
}
|
|
|
|
|
|
/**********************************************************************
|
|
* INT_CtxSetHandler
|
|
*
|
|
* Set the interrupt handler for a given interrupt.
|
|
*/
|
|
void INT_CtxSetHandler( CONTEXT86 *context, BYTE intnum, FARPROC16 handler )
|
|
{
|
|
if (ISV86(context))
|
|
INT_SetRMHandler(intnum, handler);
|
|
else
|
|
INT_SetPMHandler(intnum, handler);
|
|
}
|
|
|
|
|
|
/**********************************************************************
|
|
* INT_RealModeInterrupt
|
|
*
|
|
* Handle real mode interrupts
|
|
*/
|
|
int INT_RealModeInterrupt( BYTE intnum, CONTEXT86 *context )
|
|
{
|
|
/* we should really map to if1632/wprocs.spec, but not all
|
|
* interrupt handlers are adapted to support real mode yet */
|
|
switch (intnum) {
|
|
case 0x09:
|
|
INT_Int09Handler(context);
|
|
break;
|
|
case 0x10:
|
|
INT_Int10Handler(context);
|
|
break;
|
|
case 0x11:
|
|
INT_Int11Handler(context);
|
|
break;
|
|
case 0x12:
|
|
INT_Int12Handler(context);
|
|
break;
|
|
case 0x13:
|
|
INT_Int13Handler(context);
|
|
break;
|
|
case 0x15:
|
|
INT_Int15Handler(context);
|
|
break;
|
|
case 0x16:
|
|
INT_Int16Handler(context);
|
|
break;
|
|
case 0x17:
|
|
INT_Int17Handler(context);
|
|
break;
|
|
case 0x1a:
|
|
INT_Int1aHandler(context);
|
|
break;
|
|
case 0x20:
|
|
INT_Int20Handler(context);
|
|
break;
|
|
case 0x21:
|
|
DOS3Call(context);
|
|
break;
|
|
case 0x25:
|
|
INT_Int25Handler(context);
|
|
break;
|
|
case 0x29:
|
|
INT_Int29Handler(context);
|
|
break;
|
|
case 0x2a:
|
|
INT_Int2aHandler(context);
|
|
break;
|
|
case 0x2f:
|
|
INT_Int2fHandler(context);
|
|
break;
|
|
case 0x31:
|
|
INT_Int31Handler(context);
|
|
break;
|
|
case 0x33:
|
|
INT_Int33Handler(context);
|
|
break;
|
|
default:
|
|
FIXME("Unknown Interrupt in DOS mode: 0x%x\n", intnum);
|
|
return 1;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
|
|
/**********************************************************************
|
|
* INT_DefaultHandler
|
|
*
|
|
* Default interrupt handler.
|
|
*/
|
|
void WINAPI INT_DefaultHandler( CONTEXT86 *context )
|
|
{
|
|
}
|