2013-06-17 00:00:36 +00:00
|
|
|
/*
|
|
|
|
* COPYRIGHT: GPL - See COPYING in the top level directory
|
|
|
|
* PROJECT: ReactOS Virtual DOS Machine
|
|
|
|
* FILE: bios.c
|
2014-02-17 22:20:03 +00:00
|
|
|
* PURPOSE: VDM BIOS Support Library
|
|
|
|
* PROGRAMMERS: Hermes Belusca-Maito (hermes.belusca@sfr.fr)
|
2013-06-17 00:00:36 +00:00
|
|
|
*/
|
|
|
|
|
2013-06-26 22:58:41 +00:00
|
|
|
/* INCLUDES *******************************************************************/
|
2013-06-17 00:00:36 +00:00
|
|
|
|
2013-07-22 13:51:26 +00:00
|
|
|
#define NDEBUG
|
|
|
|
|
2014-02-17 22:50:41 +00:00
|
|
|
#include "emulator.h"
|
2014-09-30 23:47:23 +00:00
|
|
|
#include "cpu/callback.h"
|
|
|
|
#include "cpu/bop.h"
|
2014-02-26 01:16:56 +00:00
|
|
|
|
2013-11-09 22:15:40 +00:00
|
|
|
#include "bios.h"
|
2014-03-02 22:50:31 +00:00
|
|
|
#include "bios32/bios32.h"
|
2013-11-09 23:01:11 +00:00
|
|
|
|
2014-02-26 01:16:56 +00:00
|
|
|
#include "rom.h"
|
|
|
|
|
2014-03-02 22:50:31 +00:00
|
|
|
#include "io.h"
|
|
|
|
#include "hardware/cmos.h"
|
2013-07-15 01:37:38 +00:00
|
|
|
|
2014-03-02 22:50:31 +00:00
|
|
|
/* DEFINES ********************************************************************/
|
2014-02-26 01:16:56 +00:00
|
|
|
|
|
|
|
/* BOP Identifiers */
|
2014-10-04 13:36:17 +00:00
|
|
|
#define BOP_RESET 0x00 // Windows NTVDM (SoftPC) BIOS calls BOP 0x00
|
2014-02-26 01:16:56 +00:00
|
|
|
// to let the virtual machine initialize itself
|
|
|
|
// the IVT and its hardware.
|
2014-03-02 22:50:31 +00:00
|
|
|
#define BOP_EQUIPLIST 0x11
|
|
|
|
#define BOP_GETMEMSIZE 0x12
|
|
|
|
|
|
|
|
/* PRIVATE VARIABLES **********************************************************/
|
|
|
|
|
|
|
|
static BOOLEAN Bios32Loaded = FALSE;
|
|
|
|
|
|
|
|
PBIOS_DATA_AREA Bda;
|
2014-05-19 02:21:49 +00:00
|
|
|
PBIOS_CONFIG_TABLE Bct;
|
2014-02-26 01:16:56 +00:00
|
|
|
|
2013-08-05 23:20:25 +00:00
|
|
|
/* PRIVATE FUNCTIONS **********************************************************/
|
2013-06-26 22:58:41 +00:00
|
|
|
|
2014-01-25 00:21:51 +00:00
|
|
|
/* PUBLIC FUNCTIONS ***********************************************************/
|
2013-07-05 01:31:50 +00:00
|
|
|
|
2014-03-02 22:50:31 +00:00
|
|
|
VOID WINAPI BiosEquipmentService(LPWORD Stack)
|
|
|
|
{
|
|
|
|
/* Return the equipment list */
|
|
|
|
setAX(Bda->EquipmentList);
|
|
|
|
}
|
|
|
|
|
|
|
|
VOID WINAPI BiosGetMemorySize(LPWORD Stack)
|
|
|
|
{
|
|
|
|
/* Return the conventional memory size in kB, typically 640 kB */
|
|
|
|
setAX(Bda->MemorySize);
|
|
|
|
}
|
|
|
|
|
2014-02-27 03:05:42 +00:00
|
|
|
BOOLEAN
|
2014-03-02 01:45:57 +00:00
|
|
|
BiosInitialize(IN LPCSTR BiosFileName)
|
2013-06-21 00:47:07 +00:00
|
|
|
{
|
2014-03-02 22:50:31 +00:00
|
|
|
BOOLEAN Success = FALSE;
|
|
|
|
|
|
|
|
/* Disable interrupts */
|
|
|
|
setIF(0);
|
|
|
|
|
2014-05-19 02:21:49 +00:00
|
|
|
/* Initialize the BDA and the BCT pointers */
|
|
|
|
Bda = (PBIOS_DATA_AREA)SEG_OFF_TO_PTR(BDA_SEGMENT, 0x0000);
|
|
|
|
// The BCT is found at F000:E6F5 for 100% compatible BIOSes.
|
|
|
|
Bct = (PBIOS_CONFIG_TABLE)SEG_OFF_TO_PTR(BIOS_SEGMENT, 0xE6F5);
|
2014-03-02 22:50:31 +00:00
|
|
|
|
2014-10-04 13:36:17 +00:00
|
|
|
/**** HACK! HACK! for Windows NTVDM BIOS ****/
|
|
|
|
// WinNtVdmBiosSupportInitialize();
|
|
|
|
|
|
|
|
// /* Register the BIOS support BOPs */
|
|
|
|
// RegisterBop(BOP_EQUIPLIST , BiosEquipmentService);
|
|
|
|
// RegisterBop(BOP_GETMEMSIZE, BiosGetMemorySize);
|
2014-02-26 01:16:56 +00:00
|
|
|
|
2014-10-04 13:36:17 +00:00
|
|
|
if (BiosFileName && BiosFileName[0] != '\0')
|
2014-02-17 22:50:41 +00:00
|
|
|
{
|
2014-03-02 22:50:31 +00:00
|
|
|
PVOID BiosLocation = NULL;
|
|
|
|
DWORD BiosSize = 0;
|
2014-02-23 20:40:09 +00:00
|
|
|
|
2014-03-02 22:50:31 +00:00
|
|
|
Success = LoadBios(BiosFileName, &BiosLocation, &BiosSize);
|
2014-02-17 22:50:41 +00:00
|
|
|
DPRINT1("BIOS loading %s ; GetLastError() = %u\n", Success ? "succeeded" : "failed", GetLastError());
|
|
|
|
|
2014-03-02 22:50:31 +00:00
|
|
|
if (!Success) return FALSE;
|
2014-02-17 22:50:41 +00:00
|
|
|
|
|
|
|
DisplayMessage(L"First bytes at 0x%p: 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x\n"
|
|
|
|
L"3 last bytes at 0x%p: 0x%02x 0x%02x 0x%02x",
|
2014-02-23 20:40:09 +00:00
|
|
|
BiosLocation,
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 0),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 1),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 2),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 3),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 4),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 5),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 6),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 7),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 8),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + 9),
|
|
|
|
|
2014-02-26 01:16:56 +00:00
|
|
|
(PVOID)((ULONG_PTR)BiosLocation + BiosSize - 2),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + BiosSize - 2),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + BiosSize - 1),
|
|
|
|
*(PCHAR)((ULONG_PTR)REAL_TO_PHYS(BiosLocation) + BiosSize - 0));
|
2014-02-17 22:50:41 +00:00
|
|
|
|
|
|
|
DisplayMessage(L"POST at 0x%p: 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x",
|
|
|
|
TO_LINEAR(getCS(), getIP()),
|
|
|
|
*(PCHAR)((ULONG_PTR)SEG_OFF_TO_PTR(getCS(), getIP()) + 0),
|
|
|
|
*(PCHAR)((ULONG_PTR)SEG_OFF_TO_PTR(getCS(), getIP()) + 1),
|
|
|
|
*(PCHAR)((ULONG_PTR)SEG_OFF_TO_PTR(getCS(), getIP()) + 2),
|
|
|
|
*(PCHAR)((ULONG_PTR)SEG_OFF_TO_PTR(getCS(), getIP()) + 3),
|
|
|
|
*(PCHAR)((ULONG_PTR)SEG_OFF_TO_PTR(getCS(), getIP()) + 4));
|
|
|
|
|
|
|
|
/* Boot it up */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The CPU is already in reset-mode so that
|
|
|
|
* CS:IP points to F000:FFF0 as required.
|
|
|
|
*/
|
|
|
|
DisplayMessage(L"CS=0x%p ; IP=0x%p", getCS(), getIP());
|
|
|
|
// setCS(0xF000);
|
|
|
|
// setIP(0xFFF0);
|
|
|
|
|
2014-03-02 22:50:31 +00:00
|
|
|
Success = TRUE;
|
2014-02-17 22:50:41 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-03-02 22:50:31 +00:00
|
|
|
Success = Bios32Loaded = Bios32Initialize();
|
2014-02-17 22:50:41 +00:00
|
|
|
}
|
2014-03-02 22:50:31 +00:00
|
|
|
|
2014-10-04 13:36:17 +00:00
|
|
|
// /* Enable interrupts */
|
|
|
|
// setIF(1);
|
2014-03-02 22:50:31 +00:00
|
|
|
|
|
|
|
return Success;
|
2014-01-25 00:21:51 +00:00
|
|
|
}
|
|
|
|
|
2014-02-27 03:05:42 +00:00
|
|
|
VOID
|
|
|
|
BiosCleanup(VOID)
|
2014-01-25 00:21:51 +00:00
|
|
|
{
|
2014-02-17 22:20:03 +00:00
|
|
|
if (Bios32Loaded) Bios32Cleanup();
|
2013-06-21 00:47:07 +00:00
|
|
|
}
|
|
|
|
|
2013-06-17 00:00:36 +00:00
|
|
|
/* EOF */
|