225 lines
5.1 KiB
C
225 lines
5.1 KiB
C
/*++
|
||
|
||
Copyright (c) 1992 Microsoft Corporation
|
||
|
||
Module Name:
|
||
|
||
initx86.c
|
||
|
||
Abstract:
|
||
|
||
Does any x86-specific initialization, then starts the common ARC setupldr
|
||
|
||
Author:
|
||
|
||
John Vert (jvert) 14-Oct-1993
|
||
|
||
Revision History:
|
||
|
||
--*/
|
||
#include "setupldr.h"
|
||
#include "bldrx86.h"
|
||
#include "msgs.h"
|
||
#include <string.h>
|
||
#include <stdlib.h>
|
||
#include <stdio.h>
|
||
#include <netboot.h>
|
||
|
||
ARC_STATUS
|
||
SlInit(
|
||
IN ULONG Argc,
|
||
IN PCHAR Argv[],
|
||
IN PCHAR Envp[]
|
||
);
|
||
|
||
BOOLEAN
|
||
BlDetectHardware(
|
||
IN ULONG DriveId,
|
||
IN PCHAR LoadOptions
|
||
);
|
||
|
||
|
||
VOID
|
||
BlStartup(
|
||
IN PCHAR PartitionName
|
||
)
|
||
|
||
/*++
|
||
|
||
Routine Description:
|
||
|
||
Does x86-specific initialization, particularly running NTDETECT, then
|
||
calls to the common setupldr.
|
||
|
||
Arguments:
|
||
|
||
PartitionName - Supplies the ARC name of the partition (or floppy) that
|
||
setupldr was loaded from.
|
||
|
||
Return Value:
|
||
|
||
Does not return
|
||
|
||
--*/
|
||
|
||
{
|
||
ULONG Argc;
|
||
PCHAR Argv[10];
|
||
CHAR SetupLoadFileName[129];
|
||
ARC_STATUS Status;
|
||
ULONG DriveId;
|
||
ULONGLONG NetRebootParameter;
|
||
BOOLEAN UseCommandConsole = FALSE;
|
||
BOOLEAN RollbackEnabled = FALSE;
|
||
extern BOOLEAN FwDescriptorsValid;
|
||
extern BOOLEAN TryASRViaNetwork;
|
||
|
||
|
||
if (BlBootingFromNet) {
|
||
|
||
//
|
||
// Go retrieve all the information passed to us from StartROM.
|
||
// Once we have that, we'll call BlGetHeadlessRestartBlock and
|
||
// get all the port settings that StartROM sent us. These,
|
||
// in turn, will then be used in BlInitializeTerminal(), which
|
||
// we'are about to call.
|
||
//
|
||
NetGetRebootParameters(
|
||
&NetRebootParameter,
|
||
NULL,
|
||
NULL,
|
||
NULL,
|
||
NULL,
|
||
NULL,
|
||
NULL,
|
||
FALSE
|
||
);
|
||
|
||
if (NetRebootParameter == NET_REBOOT_COMMAND_CONSOLE_ONLY) {
|
||
UseCommandConsole = TRUE;
|
||
}
|
||
|
||
if (NetRebootParameter == NET_REBOOT_ASR) {
|
||
TryASRViaNetwork = TRUE;
|
||
}
|
||
}
|
||
|
||
//
|
||
// Initialize any dumb terminal that may be connected.
|
||
//
|
||
BlInitializeHeadlessPort();
|
||
|
||
//
|
||
// Open the boot partition so we can load NTDETECT off it.
|
||
//
|
||
Status = ArcOpen(PartitionName, ArcOpenReadOnly, &DriveId);
|
||
if (Status != ESUCCESS) {
|
||
BlPrint(BlFindMessage(SL_DRIVE_ERROR),PartitionName);
|
||
return;
|
||
}
|
||
|
||
if (_stricmp( (PCHAR)(0x7c03), "cmdcons" ) == 0) {
|
||
UseCommandConsole = TRUE;
|
||
} else if (strcmp ((PCHAR)(0x7c03), "undo") == 0) {
|
||
//
|
||
// NTLDR wrote the exact text "undo" (including the nul
|
||
// terminator). We know the address this text was written
|
||
// to -- 0x7C03. If we find the token, then enable rollback
|
||
// mode. This triggers an argument to be passed to textmode
|
||
// setup, plus a different boot message.
|
||
//
|
||
|
||
RollbackEnabled = TRUE;
|
||
}
|
||
|
||
//
|
||
// Initialize dbcs font and display.
|
||
//
|
||
TextGrInitialize(DriveId, &BootFontImageLength);
|
||
|
||
if (UseCommandConsole) {
|
||
BlPrint(BlFindMessage(SL_NTDETECT_CMDCONS));
|
||
} else if (RollbackEnabled) {
|
||
BlPrint(BlFindMessage(SL_NTDETECT_ROLLBACK));
|
||
} else {
|
||
BlPrint(BlFindMessage(SL_NTDETECT_MSG));
|
||
}
|
||
|
||
//
|
||
// detect HAL here.
|
||
//
|
||
if (!BlDetectHardware(DriveId, "FASTDETECT")) {
|
||
BlPrint(BlFindMessage(SL_NTDETECT_FAILURE));
|
||
return;
|
||
}
|
||
|
||
FwDescriptorsValid = FALSE;
|
||
BlKernelChecked=TRUE;
|
||
//
|
||
// NOTE:
|
||
// If you are testing the changes on read only Jaz drive uncomment this line
|
||
// and put the correct value for rdisk(?). You also need to make sure
|
||
// that SCSI BIOS emulation for the jaz drive is turned on for this trick
|
||
// to work.
|
||
//
|
||
|
||
//strcpy(PartitionName, "multi(0)disk(0)rdisk(1)partition(1)");
|
||
|
||
//
|
||
// Close the drive, the loader will re-open it.
|
||
//
|
||
|
||
ArcClose(DriveId);
|
||
|
||
//
|
||
// Create arguments, call off to setupldr
|
||
//
|
||
if (BlBootingFromNet) {
|
||
strcpy(SetupLoadFileName, PartitionName);
|
||
strcat(SetupLoadFileName, "\\i386\\SETUPLDR");
|
||
} else {
|
||
strcpy(SetupLoadFileName, PartitionName);
|
||
strcat(SetupLoadFileName, "\\SETUPLDR");
|
||
}
|
||
Argv[0] = SetupLoadFileName;
|
||
Argc = 1;
|
||
|
||
if (UseCommandConsole) {
|
||
Argv[Argc++] = "ImageType=cmdcons";
|
||
}
|
||
|
||
if (RollbackEnabled) {
|
||
//
|
||
// Rollback is a special case where we know there can be no
|
||
// OsLoadOptions.
|
||
//
|
||
|
||
Argv[Argc++] = "ImageType=rollback";
|
||
}
|
||
|
||
|
||
Status = SlInit( Argc, Argv, NULL );
|
||
|
||
//
|
||
// We should never return here, something
|
||
// horrible has happened.
|
||
//
|
||
|
||
if (!BlIsTerminalConnected()) {
|
||
//
|
||
// typical case. wait for user to press a key and then
|
||
// restart
|
||
//
|
||
while(!BlGetKey());
|
||
}
|
||
else {
|
||
//
|
||
// headless case. present user with mini sac
|
||
//
|
||
while(!BlTerminalHandleLoaderFailure());
|
||
}
|
||
ArcRestart();
|
||
|
||
return;
|
||
}
|