- preparing "plugin-disable" feature for optional plugins not controlled by a

bochsrc option (e.g. biosdev, speaker, gameport)
  * the "unmapped device" is now an optional plugin, the builtin default handlers
    no longer cause panics
  * speaker stub calls the related gui methods for beep on/off
  * load all optional plugins before starting init of core plugins
This commit is contained in:
Volker Ruppert 2009-01-15 17:34:20 +00:00
parent 8af7eff93f
commit ae54b59cd0
3 changed files with 32 additions and 39 deletions

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: devices.cc,v 1.132 2009-01-13 19:01:19 vruppert Exp $ // $Id: devices.cc,v 1.133 2009-01-15 17:34:20 vruppert Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2002 MandrakeSoft S.A. // Copyright (C) 2002 MandrakeSoft S.A.
@ -88,7 +88,6 @@ void bx_devices_c::init_stubs()
pluginFloppyDevice = &stubFloppy; pluginFloppyDevice = &stubFloppy;
pluginCmosDevice = &stubCmos; pluginCmosDevice = &stubCmos;
pluginSerialDevice = &stubSerial; pluginSerialDevice = &stubSerial;
pluginUnmapped = NULL;
pluginVgaDevice = &stubVga; pluginVgaDevice = &stubVga;
pluginPicDevice = &stubPic; pluginPicDevice = &stubPic;
pluginHardDrive = &stubHardDrive; pluginHardDrive = &stubHardDrive;
@ -110,10 +109,10 @@ void bx_devices_c::init(BX_MEM_C *newmem)
unsigned i; unsigned i;
const char def_name[] = "Default"; const char def_name[] = "Default";
BX_DEBUG(("Init $Id: devices.cc,v 1.132 2009-01-13 19:01:19 vruppert Exp $")); BX_DEBUG(("Init $Id: devices.cc,v 1.133 2009-01-15 17:34:20 vruppert Exp $"));
mem = newmem; mem = newmem;
/* set no-default handlers, will be overwritten by the real default handler */ /* set builtin default handlers, will be overwritten by the real default handler */
register_default_io_read_handler(NULL, &default_read_handler, def_name, 7); register_default_io_read_handler(NULL, &default_read_handler, def_name, 7);
io_read_handlers.next = &io_read_handlers; io_read_handlers.next = &io_read_handlers;
io_read_handlers.prev = &io_read_handlers; io_read_handlers.prev = &io_read_handlers;
@ -156,14 +155,13 @@ void bx_devices_c::init(BX_MEM_C *newmem)
// "by hand" in this file. Basically, we're using core plugins when we // "by hand" in this file. Basically, we're using core plugins when we
// want to control the init order. // want to control the init order.
// //
// CB: UNMAPPED should maybe be optional
PLUG_load_plugin(unmapped, PLUGTYPE_CORE);
PLUG_load_plugin(cmos, PLUGTYPE_CORE); PLUG_load_plugin(cmos, PLUGTYPE_CORE);
PLUG_load_plugin(dma, PLUGTYPE_CORE); PLUG_load_plugin(dma, PLUGTYPE_CORE);
PLUG_load_plugin(pic, PLUGTYPE_CORE); PLUG_load_plugin(pic, PLUGTYPE_CORE);
PLUG_load_plugin(pit, PLUGTYPE_CORE); PLUG_load_plugin(pit, PLUGTYPE_CORE);
PLUG_load_plugin(vga, PLUGTYPE_CORE); PLUG_load_plugin(vga, PLUGTYPE_CORE);
PLUG_load_plugin(floppy, PLUGTYPE_CORE); PLUG_load_plugin(floppy, PLUGTYPE_CORE);
PLUG_load_plugin(unmapped, PLUGTYPE_OPTIONAL);
PLUG_load_plugin(biosdev, PLUGTYPE_OPTIONAL); PLUG_load_plugin(biosdev, PLUGTYPE_OPTIONAL);
PLUG_load_plugin(harddrv, PLUGTYPE_OPTIONAL); PLUG_load_plugin(harddrv, PLUGTYPE_OPTIONAL);
PLUG_load_plugin(keyboard, PLUGTYPE_OPTIONAL); PLUG_load_plugin(keyboard, PLUGTYPE_OPTIONAL);
@ -182,9 +180,6 @@ void bx_devices_c::init(BX_MEM_C *newmem)
#endif #endif
PLUG_load_plugin(speaker, PLUGTYPE_OPTIONAL); PLUG_load_plugin(speaker, PLUGTYPE_OPTIONAL);
// Start with registering the default (unmapped) handler
pluginUnmapped->init();
// PCI logic (i440FX) // PCI logic (i440FX)
if (SIM->get_param_bool(BXPN_I440FX_SUPPORT)->get()) { if (SIM->get_param_bool(BXPN_I440FX_SUPPORT)->get()) {
#if BX_SUPPORT_PCI #if BX_SUPPORT_PCI
@ -229,21 +224,6 @@ void bx_devices_c::init(BX_MEM_C *newmem)
#endif #endif
} }
#if BX_SUPPORT_APIC
// I/O APIC 82093AA
ioapic = & bx_ioapic;
ioapic->init ();
#endif
// CMOS RAM & RTC
pluginCmosDevice->init ();
/*--- 8237 DMA ---*/
pluginDmaDevice->init();
//--- FLOPPY ---
pluginFloppyDevice->init();
//--- SOUND --- //--- SOUND ---
if (SIM->get_param_bool(BXPN_SB16_ENABLED)->get()) { if (SIM->get_param_bool(BXPN_SB16_ENABLED)->get()) {
#if BX_SUPPORT_SB16 #if BX_SUPPORT_SB16
@ -256,13 +236,28 @@ void bx_devices_c::init(BX_MEM_C *newmem)
PLUG_load_plugin(iodebug, PLUGTYPE_OPTIONAL); PLUG_load_plugin(iodebug, PLUGTYPE_OPTIONAL);
#endif #endif
#if BX_SUPPORT_APIC
// I/O APIC 82093AA
ioapic = &bx_ioapic;
ioapic->init();
#endif
// CMOS RAM & RTC
pluginCmosDevice->init();
/*--- 8237 DMA ---*/
pluginDmaDevice->init();
//--- FLOPPY ---
pluginFloppyDevice->init();
#if BX_SUPPORT_PCI #if BX_SUPPORT_PCI
pluginPciBridge->init (); pluginPciBridge->init();
pluginPci2IsaBridge->init (); pluginPci2IsaBridge->init();
#endif #endif
/*--- VGA adapter ---*/ /*--- VGA adapter ---*/
pluginVgaDevice->init (); pluginVgaDevice->init();
/*--- 8259A PIC ---*/ /*--- 8259A PIC ---*/
pluginPicDevice->init(); pluginPicDevice->init();
@ -319,7 +314,6 @@ void bx_devices_c::init(BX_MEM_C *newmem)
void bx_devices_c::reset(unsigned type) void bx_devices_c::reset(unsigned type)
{ {
mem->disable_smram(); mem->disable_smram();
pluginUnmapped->reset(type);
#if BX_SUPPORT_PCI #if BX_SUPPORT_PCI
if (SIM->get_param_bool(BXPN_I440FX_SUPPORT)->get()) { if (SIM->get_param_bool(BXPN_I440FX_SUPPORT)->get()) {
pluginPciBridge->reset(type); pluginPciBridge->reset(type);
@ -402,7 +396,6 @@ void bx_devices_c::exit()
bx_slowdown_timer.exit(); bx_slowdown_timer.exit();
PLUG_unload_plugin(pit); PLUG_unload_plugin(pit);
PLUG_unload_plugin(unmapped);
PLUG_unload_plugin(cmos); PLUG_unload_plugin(cmos);
PLUG_unload_plugin(dma); PLUG_unload_plugin(dma);
PLUG_unload_plugin(pic); PLUG_unload_plugin(pic);
@ -457,21 +450,19 @@ void bx_devices_c::port92_write(Bit32u address, Bit32u value, unsigned io_len)
} }
} }
// This defines a no-default read handler, // This defines the builtin default read handler,
// so Bochs does not segfault if unmapped is not loaded // so Bochs does not segfault if unmapped is not loaded
Bit32u bx_devices_c::default_read_handler(void *this_ptr, Bit32u address, unsigned io_len) Bit32u bx_devices_c::default_read_handler(void *this_ptr, Bit32u address, unsigned io_len)
{ {
UNUSED(this_ptr); UNUSED(this_ptr);
BX_PANIC(("No default io-read handler found for 0x%04x/%d. Unmapped io-device not loaded ?", address, io_len));
return 0xffffffff; return 0xffffffff;
} }
// This defines a no-default write handler, // This defines the builtin default write handler,
// so Bochs does not segfault if unmapped is not loaded // so Bochs does not segfault if unmapped is not loaded
void bx_devices_c::default_write_handler(void *this_ptr, Bit32u address, Bit32u value, unsigned io_len) void bx_devices_c::default_write_handler(void *this_ptr, Bit32u address, Bit32u value, unsigned io_len)
{ {
UNUSED(this_ptr); UNUSED(this_ptr);
BX_PANIC(("No default io-write handler found for 0x%04x/%d. Unmapped io-device not loaded ?", address, io_len));
} }
void bx_devices_c::timer_handler(void *this_ptr) void bx_devices_c::timer_handler(void *this_ptr)

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: iodev.h,v 1.104 2009-01-13 19:01:19 vruppert Exp $ // $Id: iodev.h,v 1.105 2009-01-15 17:34:20 vruppert Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2002 MandrakeSoft S.A. // Copyright (C) 2002 MandrakeSoft S.A.
@ -323,8 +323,12 @@ public:
class BOCHSAPI bx_speaker_stub_c : public bx_devmodel_c { class BOCHSAPI bx_speaker_stub_c : public bx_devmodel_c {
public: public:
virtual void beep_on(float frequency) {} virtual void beep_on(float frequency) {
virtual void beep_off() {} bx_gui->beep_on(frequency);
}
virtual void beep_off() {
bx_gui->beep_off();
}
}; };
class BOCHSAPI bx_serial_stub_c : public bx_devmodel_c { class BOCHSAPI bx_serial_stub_c : public bx_devmodel_c {
@ -445,7 +449,6 @@ public:
#if BX_SUPPORT_PCIUSB #if BX_SUPPORT_PCIUSB
bx_pci_usb_stub_c *pluginPciUSBAdapter; bx_pci_usb_stub_c *pluginPciUSBAdapter;
#endif #endif
bx_devmodel_c *pluginUnmapped;
bx_vga_stub_c *pluginVgaDevice; bx_vga_stub_c *pluginVgaDevice;
bx_pic_stub_c *pluginPicDevice; bx_pic_stub_c *pluginPicDevice;
bx_hard_drive_stub_c *pluginHardDrive; bx_hard_drive_stub_c *pluginHardDrive;

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: unmapped.cc,v 1.29 2009-01-10 11:30:20 vruppert Exp $ // $Id: unmapped.cc,v 1.30 2009-01-15 17:34:20 vruppert Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -40,7 +40,6 @@ bx_unmapped_c *theUnmappedDevice = NULL;
int libunmapped_LTX_plugin_init(plugin_t *plugin, plugintype_t type, int argc, char *argv[]) int libunmapped_LTX_plugin_init(plugin_t *plugin, plugintype_t type, int argc, char *argv[])
{ {
theUnmappedDevice = new bx_unmapped_c(); theUnmappedDevice = new bx_unmapped_c();
bx_devices.pluginUnmapped = theUnmappedDevice;
BX_REGISTER_DEVICE_DEVMODEL(plugin, type, theUnmappedDevice, BX_PLUGIN_UNMAPPED); BX_REGISTER_DEVICE_DEVMODEL(plugin, type, theUnmappedDevice, BX_PLUGIN_UNMAPPED);
return(0); // Success return(0); // Success
} }