- applied rombios boot message improvements by Sebastian
* shorten the boot failure message (removed redundant part) and added some indentation * print BEV product string * changed put_str to accept segment and offset as parameters. It allows printing strings from memory != get_CS(), e.g. option roms. * introduced a custom format specifier %S to bios_printf
This commit is contained in:
parent
a459a64f3e
commit
08d7c76e09
Binary file not shown.
Binary file not shown.
@ -1,5 +1,5 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// $Id: rombios.c,v 1.200 2008-02-07 20:46:08 sshwarts Exp $
|
// $Id: rombios.c,v 1.201 2008-02-17 16:37:42 vruppert Exp $
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Copyright (C) 2002 MandrakeSoft S.A.
|
// Copyright (C) 2002 MandrakeSoft S.A.
|
||||||
@ -935,7 +935,7 @@ Bit16u cdrom_boot();
|
|||||||
|
|
||||||
#endif // BX_ELTORITO_BOOT
|
#endif // BX_ELTORITO_BOOT
|
||||||
|
|
||||||
static char bios_cvs_version_string[] = "$Revision: 1.200 $ $Date: 2008-02-07 20:46:08 $";
|
static char bios_cvs_version_string[] = "$Revision: 1.201 $ $Date: 2008-02-17 16:37:42 $";
|
||||||
|
|
||||||
#define BIOS_COPYRIGHT_STRING "(c) 2002 MandrakeSoft S.A. Written by Kevin Lawton & the Bochs team."
|
#define BIOS_COPYRIGHT_STRING "(c) 2002 MandrakeSoft S.A. Written by Kevin Lawton & the Bochs team."
|
||||||
|
|
||||||
@ -1515,17 +1515,16 @@ put_luint(action, val, width, neg)
|
|||||||
send(action, val - (nval * 10) + '0');
|
send(action, val - (nval * 10) + '0');
|
||||||
}
|
}
|
||||||
|
|
||||||
void put_str(action, s)
|
void put_str(action, segment, offset)
|
||||||
Bit16u action;
|
Bit16u action;
|
||||||
Bit8u *s;
|
Bit16u segment;
|
||||||
|
Bit16u offset;
|
||||||
{
|
{
|
||||||
Bit8u c;
|
Bit8u c;
|
||||||
if (!s)
|
|
||||||
s = "<NULL>";
|
|
||||||
|
|
||||||
while (c = read_byte(get_CS(), s)) {
|
while (c = read_byte(segment, offset)) {
|
||||||
send(action, c);
|
send(action, c);
|
||||||
s++;
|
offset++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1534,7 +1533,7 @@ void put_str(action, s)
|
|||||||
// A compact variable argument printf function.
|
// A compact variable argument printf function.
|
||||||
//
|
//
|
||||||
// Supports %[format_width][length]format
|
// Supports %[format_width][length]format
|
||||||
// where format can be x,X,u,d,s,c
|
// where format can be x,X,u,d,s,S,c
|
||||||
// and the optional length modifier is l (ell)
|
// and the optional length modifier is l (ell)
|
||||||
//--------------------------------------------------------------------------
|
//--------------------------------------------------------------------------
|
||||||
void
|
void
|
||||||
@ -1623,7 +1622,13 @@ bios_printf(action, s)
|
|||||||
put_int(action, arg, format_width, 0);
|
put_int(action, arg, format_width, 0);
|
||||||
}
|
}
|
||||||
else if (c == 's') {
|
else if (c == 's') {
|
||||||
put_str(action, arg);
|
put_str(action, get_CS(), arg);
|
||||||
|
}
|
||||||
|
else if (c == 'S') {
|
||||||
|
hibyte = arg;
|
||||||
|
arg_ptr++;
|
||||||
|
arg = read_word(arg_seg, arg_ptr);
|
||||||
|
put_str(action, hibyte, arg);
|
||||||
}
|
}
|
||||||
else if (c == 'c') {
|
else if (c == 'c') {
|
||||||
send(action, arg);
|
send(action, arg);
|
||||||
@ -1926,13 +1931,26 @@ Bit16u i; ipl_entry_t *e;
|
|||||||
static char drivetypes[][10]={"", "Floppy","Hard Disk","CD-Rom", "Network"};
|
static char drivetypes[][10]={"", "Floppy","Hard Disk","CD-Rom", "Network"};
|
||||||
|
|
||||||
void
|
void
|
||||||
print_boot_device(type)
|
print_boot_device(e)
|
||||||
Bit16u type;
|
ipl_entry_t *e;
|
||||||
{
|
{
|
||||||
|
Bit16u type;
|
||||||
|
char description[33];
|
||||||
|
Bit16u ss = get_SS();
|
||||||
|
type = e->type;
|
||||||
/* NIC appears as type 0x80 */
|
/* NIC appears as type 0x80 */
|
||||||
if (type == IPL_TYPE_BEV) type = 0x4;
|
if (type == IPL_TYPE_BEV) type = 0x4;
|
||||||
if (type == 0 || type > 0x4) BX_PANIC("Bad drive type\n");
|
if (type == 0 || type > 0x4) BX_PANIC("Bad drive type\n");
|
||||||
printf("Booting from %s...\n", drivetypes[type]);
|
printf("Booting from %s", drivetypes[type]);
|
||||||
|
/* print product string if BEV */
|
||||||
|
if (type == 4 && e->description != 0) {
|
||||||
|
/* first 32 bytes are significant */
|
||||||
|
memcpyb(ss, &description, (Bit16u)(e->description >> 16), (Bit16u)(e->description & 0xffff), 32);
|
||||||
|
/* terminate string */
|
||||||
|
description[32] = 0;
|
||||||
|
printf(" [%S]", ss, description);
|
||||||
|
}
|
||||||
|
printf("...\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------
|
//--------------------------------------------------------------------------
|
||||||
@ -1945,15 +1963,15 @@ print_boot_failure(type, reason)
|
|||||||
{
|
{
|
||||||
if (type == 0 || type > 0x3) BX_PANIC("Bad drive type\n");
|
if (type == 0 || type > 0x3) BX_PANIC("Bad drive type\n");
|
||||||
|
|
||||||
printf("Boot from %s failed", drivetypes[type]);
|
printf("Boot failed");
|
||||||
if (type < 4) {
|
if (type < 4) {
|
||||||
/* Report the reason too */
|
/* Report the reason too */
|
||||||
if (reason==0)
|
if (reason==0)
|
||||||
printf(": not a bootable disk");
|
printf(": not a bootable disk");
|
||||||
else
|
else
|
||||||
printf(": could not read the boot disk");
|
printf(": could not read the boot disk");
|
||||||
}
|
}
|
||||||
printf("\n");
|
printf("\n\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------
|
//--------------------------------------------------------------------------
|
||||||
@ -7796,7 +7814,7 @@ Bit16u seq_nr;
|
|||||||
|
|
||||||
/* Do the loading, and set up vector as a far pointer to the boot
|
/* Do the loading, and set up vector as a far pointer to the boot
|
||||||
* address, and bootdrv as the boot drive */
|
* address, and bootdrv as the boot drive */
|
||||||
print_boot_device(e.type);
|
print_boot_device(&e);
|
||||||
|
|
||||||
switch(e.type) {
|
switch(e.type) {
|
||||||
case IPL_TYPE_FLOPPY: /* FDD */
|
case IPL_TYPE_FLOPPY: /* FDD */
|
||||||
|
Loading…
Reference in New Issue
Block a user