2017-05-30 03:38:38 +02:00
|
|
|
/*
|
2022-10-27 17:08:58 -04:00
|
|
|
* 86Box A hypervisor and IBM PC system emulator that specializes in
|
|
|
|
|
* running old operating systems and software designed for IBM
|
|
|
|
|
* PC systems and compatibles from 1981 through fairly recent
|
|
|
|
|
* system designs based on the PCI bus.
|
2017-05-30 03:38:38 +02:00
|
|
|
*
|
2022-10-27 17:08:58 -04:00
|
|
|
* This file is part of the 86Box distribution.
|
2017-05-30 03:38:38 +02:00
|
|
|
*
|
2022-10-27 17:08:58 -04:00
|
|
|
* Implementation of the generic device interface to handle
|
|
|
|
|
* all devices attached to the emulator.
|
2017-05-30 03:38:38 +02:00
|
|
|
*
|
2020-03-25 00:46:02 +02:00
|
|
|
*
|
2017-05-30 03:38:38 +02:00
|
|
|
*
|
2022-10-27 17:08:58 -04:00
|
|
|
* Authors: Fred N. van Kempen, <decwiz@yahoo.com>
|
|
|
|
|
* Miran Grca, <mgrca8@gmail.com>
|
2023-01-06 15:36:29 -05:00
|
|
|
* Sarah Walker, <https://pcem-emulator.co.uk/>
|
2017-10-17 01:59:09 -04:00
|
|
|
*
|
2022-10-27 17:08:58 -04:00
|
|
|
* Copyright 2017-2019 Fred N. van Kempen.
|
|
|
|
|
* Copyright 2016-2019 Miran Grca.
|
|
|
|
|
* Copyright 2008-2019 Sarah Walker.
|
2023-02-14 20:37:58 -05:00
|
|
|
* Copyright 2021 Andreas J. Reichel.
|
2025-01-06 23:28:08 -05:00
|
|
|
* Copyright 2021-2025 Jasmine Iwanek.
|
2018-03-19 01:02:04 +01:00
|
|
|
*
|
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
* General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program; if not, write to the:
|
|
|
|
|
*
|
|
|
|
|
* Free Software Foundation, Inc.
|
|
|
|
|
* 59 Temple Place - Suite 330
|
|
|
|
|
* Boston, MA 02111-1307
|
|
|
|
|
* USA.
|
2017-05-30 03:38:38 +02:00
|
|
|
*/
|
2023-10-14 06:45:45 +02:00
|
|
|
#include <inttypes.h>
|
2018-05-21 19:04:05 +02:00
|
|
|
#include <stdarg.h>
|
2017-09-25 04:31:20 -04:00
|
|
|
#include <stdio.h>
|
2018-09-03 13:55:09 +02:00
|
|
|
#include <stdlib.h>
|
2017-09-25 04:31:20 -04:00
|
|
|
#include <stdint.h>
|
|
|
|
|
#include <string.h>
|
2025-01-27 01:20:37 +01:00
|
|
|
#include <wchar.h>
|
2018-05-21 19:04:05 +02:00
|
|
|
#define HAVE_STDARG_H
|
2020-03-29 14:24:42 +02:00
|
|
|
#include <86box/86box.h>
|
2022-09-10 13:32:46 +02:00
|
|
|
#include <86box/ini.h>
|
2020-03-29 14:24:42 +02:00
|
|
|
#include <86box/config.h>
|
|
|
|
|
#include <86box/device.h>
|
|
|
|
|
#include <86box/machine.h>
|
2022-07-22 23:35:18 -04:00
|
|
|
#include <86box/mem.h>
|
2025-01-27 01:20:37 +01:00
|
|
|
#include <86box/plat.h>
|
2022-07-22 23:35:18 -04:00
|
|
|
#include <86box/rom.h>
|
2020-03-29 14:24:42 +02:00
|
|
|
#include <86box/sound.h>
|
2025-01-27 01:20:37 +01:00
|
|
|
#include <86box/ui.h>
|
2017-05-06 17:48:33 +02:00
|
|
|
|
2022-09-18 17:11:43 -04:00
|
|
|
#define DEVICE_MAX 256 /* max # of devices */
|
2016-06-26 00:34:39 +02:00
|
|
|
|
2022-09-18 17:11:43 -04:00
|
|
|
static device_t *devices[DEVICE_MAX];
|
|
|
|
|
static void *device_priv[DEVICE_MAX];
|
2023-05-11 03:02:36 -04:00
|
|
|
static device_context_t device_current;
|
|
|
|
|
static device_context_t device_prev;
|
2024-02-22 00:52:20 +01:00
|
|
|
static void *device_common_priv;
|
2017-06-04 02:11:19 -04:00
|
|
|
|
2018-05-21 19:04:05 +02:00
|
|
|
#ifdef ENABLE_DEVICE_LOG
|
|
|
|
|
int device_do_log = ENABLE_DEVICE_LOG;
|
|
|
|
|
|
|
|
|
|
static void
|
2018-10-19 00:39:32 +02:00
|
|
|
device_log(const char *fmt, ...)
|
2018-05-21 19:04:05 +02:00
|
|
|
{
|
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
|
|
if (device_do_log) {
|
2022-09-18 17:11:43 -04:00
|
|
|
va_start(ap, fmt);
|
|
|
|
|
pclog_ex(fmt, ap);
|
|
|
|
|
va_end(ap);
|
2018-05-21 19:04:05 +02:00
|
|
|
}
|
|
|
|
|
}
|
2018-10-19 00:39:32 +02:00
|
|
|
#else
|
2022-09-18 17:11:43 -04:00
|
|
|
# define device_log(fmt, ...)
|
2018-10-19 00:39:32 +02:00
|
|
|
#endif
|
2018-05-21 19:04:05 +02:00
|
|
|
|
2018-09-03 13:55:09 +02:00
|
|
|
/* Initialize the module for use. */
|
2017-10-07 00:46:54 -04:00
|
|
|
void
|
|
|
|
|
device_init(void)
|
2016-06-26 00:34:39 +02:00
|
|
|
{
|
2017-10-07 00:46:54 -04:00
|
|
|
memset(devices, 0x00, sizeof(devices));
|
2016-06-26 00:34:39 +02:00
|
|
|
}
|
|
|
|
|
|
2018-10-23 21:14:41 +02:00
|
|
|
void
|
2025-01-06 23:28:08 -05:00
|
|
|
device_set_context(device_context_t *ctx, const device_t *dev, int inst)
|
2018-09-03 13:55:09 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
memset(ctx, 0, sizeof(device_context_t));
|
|
|
|
|
ctx->dev = dev;
|
|
|
|
|
ctx->instance = inst;
|
2021-07-23 01:20:14 +02:00
|
|
|
if (inst) {
|
2025-01-06 23:28:08 -05:00
|
|
|
sprintf(ctx->name, "%s #%i", dev->name, inst);
|
2022-09-18 17:11:43 -04:00
|
|
|
|
2024-07-21 15:13:16 +02:00
|
|
|
/* If a numbered section is not present, but a non-numbered of the same name
|
|
|
|
|
is, rename the non-numbered section to numbered. */
|
2025-01-06 23:28:08 -05:00
|
|
|
const void *sec = config_find_section(ctx->name);
|
2024-07-21 15:13:16 +02:00
|
|
|
void * single_sec = config_find_section((char *) dev->name);
|
|
|
|
|
if ((sec == NULL) && (single_sec != NULL))
|
2025-01-06 23:28:08 -05:00
|
|
|
config_rename_section(single_sec, ctx->name);
|
2024-11-10 02:23:21 +01:00
|
|
|
} else if (!strcmp(dev->name, "PS/2 Mouse")) {
|
2025-01-06 23:28:08 -05:00
|
|
|
sprintf(ctx->name, "%s", dev->name);
|
2024-11-10 02:23:21 +01:00
|
|
|
|
|
|
|
|
/* Migrate the old "Standard PS/2 Mouse" section */
|
2025-01-06 23:28:08 -05:00
|
|
|
const void *sec = config_find_section(ctx->name);
|
2024-11-10 02:23:21 +01:00
|
|
|
void * old_sec = config_find_section("Standard PS/2 Mouse");
|
|
|
|
|
if ((sec == NULL) && (old_sec != NULL))
|
2025-01-06 23:28:08 -05:00
|
|
|
config_rename_section(old_sec, ctx->name);
|
2024-11-21 14:59:19 +01:00
|
|
|
} else if (!strcmp(dev->name, "Microsoft RAMCard")) {
|
2025-01-06 23:28:08 -05:00
|
|
|
sprintf(ctx->name, "%s", dev->name);
|
2024-11-21 14:59:19 +01:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
/* Migrate the old "Microsoft RAMCard for IBM PC" section */
|
|
|
|
|
const void *sec = config_find_section(ctx->name);
|
2024-11-21 14:59:19 +01:00
|
|
|
void * old_sec = config_find_section("Microsoft RAMCard for IBM PC");
|
|
|
|
|
if ((sec == NULL) && (old_sec != NULL))
|
2025-01-06 23:28:08 -05:00
|
|
|
config_rename_section(old_sec, ctx->name);
|
2021-07-23 01:20:14 +02:00
|
|
|
} else
|
2025-01-06 23:28:08 -05:00
|
|
|
sprintf(ctx->name, "%s", dev->name);
|
2018-09-03 13:55:09 +02:00
|
|
|
}
|
|
|
|
|
|
Added the IBM 5161 ISA expansion for PC and XT;
Cleaned up the parallel port emulation, added IRQ support, and made enabling/disabling per port;
Added the Award 430NX and the Intel Classic/PCI (Alfredo, 420TX);
Finished the 586MC1;
Added 8087 emulation;
Moved Cyrix 6x86'es to the Dev branch;
Sanitized/cleaned up memregs.c/h and intel.c/h;
Split the chipsets from machines and sanitized Port 92 emulation;
Added support for the 15bpp mode to the Compaq ATI 28800;
Moved the MR 386DX and 486 machines to the Dev branch;
Ported the new dynamic recompiler from PCem, but it remains in Dev branch until after v2.00;
Ported the new timer code from PCem;
Cleaned up the CPU table of unused stuff and better optimized its structure;
Ported the Open-XT and Open-AT from VARCem, the Open-AT is in the Dev branch;
Ported the XT MFM controller rewrite and adding of more controllers (incl. two RLL ones), from VARCem;
Added the AHA-1540A and the BusTek BT-542B;
Moved the Sumo SCSI-AT to the Dev branch;
Minor IDE, FDC, and floppy drive code clean-ups;
Made NCR 5380/53C400-based cards' BIOS address configurable;
Got rid of the legacy romset variable;
Unified (video) buffer and buffer32 into one and make the unified buffer 32-bit;
Added the Amstead PPC512 per PCem patch by John Elliott;
Switched memory mapping granularity from 16k to 4k (less than 1k not possible due to internal pages);
Rewrote the CL-GD 54xx blitter, fixes Win-OS/2 on the 54x6 among other thing;
Added the Image Manager 1024 and Professional Graphics Controller per PCem patch by John Elliott and work done on VARCem;
Added Headland HT-216, GC-205 and Video 7 VGA 1024i emulation based on PCem commit;
Implemented the fuction keys for the Toshiba T1000/T1200/T3100 enhancement;
Amstrad MegaPC does now works correctly with non-internal graphics card;
The SLiRP code no longer casts a packed struct type to a non-packed struct type;
The Xi8088 and PB410a no longer hang on 86Box when PS/2 mouse is not present;
The S3 Virge on BeOS is no longer broken (was broken by build #1591);
OS/2 2.0 build 6.167 now sees key presses again;
Xi8088 now work on CGA again;
86F images converted from either the old or new variants of the HxC MFM format now work correctly;
Hardware interrupts with a vector of 0xFF are now handled correctly;
OPTi 495SX boards no longer incorrectly have 64 MB maximum RAM when 32 MB is correct;
Fixed VNC keyboard input bugs;
Fixed AT RTC periodic interrupt - Chicago 58s / 73f / 73g / 81 MIDI play no longer hangs with the build's own VTD driver;
Fixed mouse polling with internal mice - Amstrad and Olivetti mice now work correctly;
Triones ATAPI DMA driver now correctly reads a file at the end of a CD image with a sectors number not divisible by 4;
Compaq Portable now works with all graphics cards;
Fixed various MDSI Genius bugs;
Added segment limit checks and improved page fault checks for several CPU instructions - Memphis 15xx WINSETUP and Chicago 58s WINDISK.CPL no longer issue a GPF, and some S3 drivers that used to have glitches, now work correctly;
Further improved the 808x emulation, also fixes the noticably choppy sound when using 808x CPU's, also fixes #355;
OS/2 installer no logner locks up on splash screen on PS/2 Model 70 and 80, fixes #400.
Fixed several Amstead bugs, GEM no longer crashes on the Amstrad 1640, fixes #391.
Ported John Elliott's Amstrad fixes and improvement from PCem, and fixed the default language so it's correctly Engliish, fixes #278, fixes #389.
Fixed a minor IDE timing bug, fixes #388.
Fixed Toshiba T1000 RAM issues, fixes #379.
Fixed EGA/(S)VGA overscan border handling, fixes #378;
Got rid of the now long useless IDE channel 2 auto-removal, fixes #370;
Fixed the BIOS files used by the AMSTRAD PC1512, fixes #366;
Ported the Unicode CD image file name fix from VARCem, fixes #365;
Fixed high density floppy disks on the Xi8088, fixes #359;
Fixed some bugs in the Hercules emulation, fixes #346, fixes #358;
Fixed the SCSI hard disk mode sense pages, fixes #356;
Removed the AMI Unknown 386SX because of impossibility to identify the chipset, closes #349;
Fixed bugs in the serial mouse emulation, fixes #344;
Compiled 86Box binaries now include all the required .DLL's, fixes #341;
Made some combo boxes in the Settings dialog slightly wider, fixes #276.
2019-09-20 14:02:30 +02:00
|
|
|
static void
|
2023-06-28 13:46:28 -04:00
|
|
|
device_context_common(const device_t *dev, int inst)
|
Added the IBM 5161 ISA expansion for PC and XT;
Cleaned up the parallel port emulation, added IRQ support, and made enabling/disabling per port;
Added the Award 430NX and the Intel Classic/PCI (Alfredo, 420TX);
Finished the 586MC1;
Added 8087 emulation;
Moved Cyrix 6x86'es to the Dev branch;
Sanitized/cleaned up memregs.c/h and intel.c/h;
Split the chipsets from machines and sanitized Port 92 emulation;
Added support for the 15bpp mode to the Compaq ATI 28800;
Moved the MR 386DX and 486 machines to the Dev branch;
Ported the new dynamic recompiler from PCem, but it remains in Dev branch until after v2.00;
Ported the new timer code from PCem;
Cleaned up the CPU table of unused stuff and better optimized its structure;
Ported the Open-XT and Open-AT from VARCem, the Open-AT is in the Dev branch;
Ported the XT MFM controller rewrite and adding of more controllers (incl. two RLL ones), from VARCem;
Added the AHA-1540A and the BusTek BT-542B;
Moved the Sumo SCSI-AT to the Dev branch;
Minor IDE, FDC, and floppy drive code clean-ups;
Made NCR 5380/53C400-based cards' BIOS address configurable;
Got rid of the legacy romset variable;
Unified (video) buffer and buffer32 into one and make the unified buffer 32-bit;
Added the Amstead PPC512 per PCem patch by John Elliott;
Switched memory mapping granularity from 16k to 4k (less than 1k not possible due to internal pages);
Rewrote the CL-GD 54xx blitter, fixes Win-OS/2 on the 54x6 among other thing;
Added the Image Manager 1024 and Professional Graphics Controller per PCem patch by John Elliott and work done on VARCem;
Added Headland HT-216, GC-205 and Video 7 VGA 1024i emulation based on PCem commit;
Implemented the fuction keys for the Toshiba T1000/T1200/T3100 enhancement;
Amstrad MegaPC does now works correctly with non-internal graphics card;
The SLiRP code no longer casts a packed struct type to a non-packed struct type;
The Xi8088 and PB410a no longer hang on 86Box when PS/2 mouse is not present;
The S3 Virge on BeOS is no longer broken (was broken by build #1591);
OS/2 2.0 build 6.167 now sees key presses again;
Xi8088 now work on CGA again;
86F images converted from either the old or new variants of the HxC MFM format now work correctly;
Hardware interrupts with a vector of 0xFF are now handled correctly;
OPTi 495SX boards no longer incorrectly have 64 MB maximum RAM when 32 MB is correct;
Fixed VNC keyboard input bugs;
Fixed AT RTC periodic interrupt - Chicago 58s / 73f / 73g / 81 MIDI play no longer hangs with the build's own VTD driver;
Fixed mouse polling with internal mice - Amstrad and Olivetti mice now work correctly;
Triones ATAPI DMA driver now correctly reads a file at the end of a CD image with a sectors number not divisible by 4;
Compaq Portable now works with all graphics cards;
Fixed various MDSI Genius bugs;
Added segment limit checks and improved page fault checks for several CPU instructions - Memphis 15xx WINSETUP and Chicago 58s WINDISK.CPL no longer issue a GPF, and some S3 drivers that used to have glitches, now work correctly;
Further improved the 808x emulation, also fixes the noticably choppy sound when using 808x CPU's, also fixes #355;
OS/2 installer no logner locks up on splash screen on PS/2 Model 70 and 80, fixes #400.
Fixed several Amstead bugs, GEM no longer crashes on the Amstrad 1640, fixes #391.
Ported John Elliott's Amstrad fixes and improvement from PCem, and fixed the default language so it's correctly Engliish, fixes #278, fixes #389.
Fixed a minor IDE timing bug, fixes #388.
Fixed Toshiba T1000 RAM issues, fixes #379.
Fixed EGA/(S)VGA overscan border handling, fixes #378;
Got rid of the now long useless IDE channel 2 auto-removal, fixes #370;
Fixed the BIOS files used by the AMSTRAD PC1512, fixes #366;
Ported the Unicode CD image file name fix from VARCem, fixes #365;
Fixed high density floppy disks on the Xi8088, fixes #359;
Fixed some bugs in the Hercules emulation, fixes #346, fixes #358;
Fixed the SCSI hard disk mode sense pages, fixes #356;
Removed the AMI Unknown 386SX because of impossibility to identify the chipset, closes #349;
Fixed bugs in the serial mouse emulation, fixes #344;
Compiled 86Box binaries now include all the required .DLL's, fixes #341;
Made some combo boxes in the Settings dialog slightly wider, fixes #276.
2019-09-20 14:02:30 +02:00
|
|
|
{
|
|
|
|
|
memcpy(&device_prev, &device_current, sizeof(device_context_t));
|
2023-06-28 13:46:28 -04:00
|
|
|
device_set_context(&device_current, dev, inst);
|
Added the IBM 5161 ISA expansion for PC and XT;
Cleaned up the parallel port emulation, added IRQ support, and made enabling/disabling per port;
Added the Award 430NX and the Intel Classic/PCI (Alfredo, 420TX);
Finished the 586MC1;
Added 8087 emulation;
Moved Cyrix 6x86'es to the Dev branch;
Sanitized/cleaned up memregs.c/h and intel.c/h;
Split the chipsets from machines and sanitized Port 92 emulation;
Added support for the 15bpp mode to the Compaq ATI 28800;
Moved the MR 386DX and 486 machines to the Dev branch;
Ported the new dynamic recompiler from PCem, but it remains in Dev branch until after v2.00;
Ported the new timer code from PCem;
Cleaned up the CPU table of unused stuff and better optimized its structure;
Ported the Open-XT and Open-AT from VARCem, the Open-AT is in the Dev branch;
Ported the XT MFM controller rewrite and adding of more controllers (incl. two RLL ones), from VARCem;
Added the AHA-1540A and the BusTek BT-542B;
Moved the Sumo SCSI-AT to the Dev branch;
Minor IDE, FDC, and floppy drive code clean-ups;
Made NCR 5380/53C400-based cards' BIOS address configurable;
Got rid of the legacy romset variable;
Unified (video) buffer and buffer32 into one and make the unified buffer 32-bit;
Added the Amstead PPC512 per PCem patch by John Elliott;
Switched memory mapping granularity from 16k to 4k (less than 1k not possible due to internal pages);
Rewrote the CL-GD 54xx blitter, fixes Win-OS/2 on the 54x6 among other thing;
Added the Image Manager 1024 and Professional Graphics Controller per PCem patch by John Elliott and work done on VARCem;
Added Headland HT-216, GC-205 and Video 7 VGA 1024i emulation based on PCem commit;
Implemented the fuction keys for the Toshiba T1000/T1200/T3100 enhancement;
Amstrad MegaPC does now works correctly with non-internal graphics card;
The SLiRP code no longer casts a packed struct type to a non-packed struct type;
The Xi8088 and PB410a no longer hang on 86Box when PS/2 mouse is not present;
The S3 Virge on BeOS is no longer broken (was broken by build #1591);
OS/2 2.0 build 6.167 now sees key presses again;
Xi8088 now work on CGA again;
86F images converted from either the old or new variants of the HxC MFM format now work correctly;
Hardware interrupts with a vector of 0xFF are now handled correctly;
OPTi 495SX boards no longer incorrectly have 64 MB maximum RAM when 32 MB is correct;
Fixed VNC keyboard input bugs;
Fixed AT RTC periodic interrupt - Chicago 58s / 73f / 73g / 81 MIDI play no longer hangs with the build's own VTD driver;
Fixed mouse polling with internal mice - Amstrad and Olivetti mice now work correctly;
Triones ATAPI DMA driver now correctly reads a file at the end of a CD image with a sectors number not divisible by 4;
Compaq Portable now works with all graphics cards;
Fixed various MDSI Genius bugs;
Added segment limit checks and improved page fault checks for several CPU instructions - Memphis 15xx WINSETUP and Chicago 58s WINDISK.CPL no longer issue a GPF, and some S3 drivers that used to have glitches, now work correctly;
Further improved the 808x emulation, also fixes the noticably choppy sound when using 808x CPU's, also fixes #355;
OS/2 installer no logner locks up on splash screen on PS/2 Model 70 and 80, fixes #400.
Fixed several Amstead bugs, GEM no longer crashes on the Amstrad 1640, fixes #391.
Ported John Elliott's Amstrad fixes and improvement from PCem, and fixed the default language so it's correctly Engliish, fixes #278, fixes #389.
Fixed a minor IDE timing bug, fixes #388.
Fixed Toshiba T1000 RAM issues, fixes #379.
Fixed EGA/(S)VGA overscan border handling, fixes #378;
Got rid of the now long useless IDE channel 2 auto-removal, fixes #370;
Fixed the BIOS files used by the AMSTRAD PC1512, fixes #366;
Ported the Unicode CD image file name fix from VARCem, fixes #365;
Fixed high density floppy disks on the Xi8088, fixes #359;
Fixed some bugs in the Hercules emulation, fixes #346, fixes #358;
Fixed the SCSI hard disk mode sense pages, fixes #356;
Removed the AMI Unknown 386SX because of impossibility to identify the chipset, closes #349;
Fixed bugs in the serial mouse emulation, fixes #344;
Compiled 86Box binaries now include all the required .DLL's, fixes #341;
Made some combo boxes in the Settings dialog slightly wider, fixes #276.
2019-09-20 14:02:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2023-06-28 13:46:28 -04:00
|
|
|
device_context(const device_t *dev)
|
Added the IBM 5161 ISA expansion for PC and XT;
Cleaned up the parallel port emulation, added IRQ support, and made enabling/disabling per port;
Added the Award 430NX and the Intel Classic/PCI (Alfredo, 420TX);
Finished the 586MC1;
Added 8087 emulation;
Moved Cyrix 6x86'es to the Dev branch;
Sanitized/cleaned up memregs.c/h and intel.c/h;
Split the chipsets from machines and sanitized Port 92 emulation;
Added support for the 15bpp mode to the Compaq ATI 28800;
Moved the MR 386DX and 486 machines to the Dev branch;
Ported the new dynamic recompiler from PCem, but it remains in Dev branch until after v2.00;
Ported the new timer code from PCem;
Cleaned up the CPU table of unused stuff and better optimized its structure;
Ported the Open-XT and Open-AT from VARCem, the Open-AT is in the Dev branch;
Ported the XT MFM controller rewrite and adding of more controllers (incl. two RLL ones), from VARCem;
Added the AHA-1540A and the BusTek BT-542B;
Moved the Sumo SCSI-AT to the Dev branch;
Minor IDE, FDC, and floppy drive code clean-ups;
Made NCR 5380/53C400-based cards' BIOS address configurable;
Got rid of the legacy romset variable;
Unified (video) buffer and buffer32 into one and make the unified buffer 32-bit;
Added the Amstead PPC512 per PCem patch by John Elliott;
Switched memory mapping granularity from 16k to 4k (less than 1k not possible due to internal pages);
Rewrote the CL-GD 54xx blitter, fixes Win-OS/2 on the 54x6 among other thing;
Added the Image Manager 1024 and Professional Graphics Controller per PCem patch by John Elliott and work done on VARCem;
Added Headland HT-216, GC-205 and Video 7 VGA 1024i emulation based on PCem commit;
Implemented the fuction keys for the Toshiba T1000/T1200/T3100 enhancement;
Amstrad MegaPC does now works correctly with non-internal graphics card;
The SLiRP code no longer casts a packed struct type to a non-packed struct type;
The Xi8088 and PB410a no longer hang on 86Box when PS/2 mouse is not present;
The S3 Virge on BeOS is no longer broken (was broken by build #1591);
OS/2 2.0 build 6.167 now sees key presses again;
Xi8088 now work on CGA again;
86F images converted from either the old or new variants of the HxC MFM format now work correctly;
Hardware interrupts with a vector of 0xFF are now handled correctly;
OPTi 495SX boards no longer incorrectly have 64 MB maximum RAM when 32 MB is correct;
Fixed VNC keyboard input bugs;
Fixed AT RTC periodic interrupt - Chicago 58s / 73f / 73g / 81 MIDI play no longer hangs with the build's own VTD driver;
Fixed mouse polling with internal mice - Amstrad and Olivetti mice now work correctly;
Triones ATAPI DMA driver now correctly reads a file at the end of a CD image with a sectors number not divisible by 4;
Compaq Portable now works with all graphics cards;
Fixed various MDSI Genius bugs;
Added segment limit checks and improved page fault checks for several CPU instructions - Memphis 15xx WINSETUP and Chicago 58s WINDISK.CPL no longer issue a GPF, and some S3 drivers that used to have glitches, now work correctly;
Further improved the 808x emulation, also fixes the noticably choppy sound when using 808x CPU's, also fixes #355;
OS/2 installer no logner locks up on splash screen on PS/2 Model 70 and 80, fixes #400.
Fixed several Amstead bugs, GEM no longer crashes on the Amstrad 1640, fixes #391.
Ported John Elliott's Amstrad fixes and improvement from PCem, and fixed the default language so it's correctly Engliish, fixes #278, fixes #389.
Fixed a minor IDE timing bug, fixes #388.
Fixed Toshiba T1000 RAM issues, fixes #379.
Fixed EGA/(S)VGA overscan border handling, fixes #378;
Got rid of the now long useless IDE channel 2 auto-removal, fixes #370;
Fixed the BIOS files used by the AMSTRAD PC1512, fixes #366;
Ported the Unicode CD image file name fix from VARCem, fixes #365;
Fixed high density floppy disks on the Xi8088, fixes #359;
Fixed some bugs in the Hercules emulation, fixes #346, fixes #358;
Fixed the SCSI hard disk mode sense pages, fixes #356;
Removed the AMI Unknown 386SX because of impossibility to identify the chipset, closes #349;
Fixed bugs in the serial mouse emulation, fixes #344;
Compiled 86Box binaries now include all the required .DLL's, fixes #341;
Made some combo boxes in the Settings dialog slightly wider, fixes #276.
2019-09-20 14:02:30 +02:00
|
|
|
{
|
2023-06-28 13:46:28 -04:00
|
|
|
device_context_common(dev, 0);
|
Added the IBM 5161 ISA expansion for PC and XT;
Cleaned up the parallel port emulation, added IRQ support, and made enabling/disabling per port;
Added the Award 430NX and the Intel Classic/PCI (Alfredo, 420TX);
Finished the 586MC1;
Added 8087 emulation;
Moved Cyrix 6x86'es to the Dev branch;
Sanitized/cleaned up memregs.c/h and intel.c/h;
Split the chipsets from machines and sanitized Port 92 emulation;
Added support for the 15bpp mode to the Compaq ATI 28800;
Moved the MR 386DX and 486 machines to the Dev branch;
Ported the new dynamic recompiler from PCem, but it remains in Dev branch until after v2.00;
Ported the new timer code from PCem;
Cleaned up the CPU table of unused stuff and better optimized its structure;
Ported the Open-XT and Open-AT from VARCem, the Open-AT is in the Dev branch;
Ported the XT MFM controller rewrite and adding of more controllers (incl. two RLL ones), from VARCem;
Added the AHA-1540A and the BusTek BT-542B;
Moved the Sumo SCSI-AT to the Dev branch;
Minor IDE, FDC, and floppy drive code clean-ups;
Made NCR 5380/53C400-based cards' BIOS address configurable;
Got rid of the legacy romset variable;
Unified (video) buffer and buffer32 into one and make the unified buffer 32-bit;
Added the Amstead PPC512 per PCem patch by John Elliott;
Switched memory mapping granularity from 16k to 4k (less than 1k not possible due to internal pages);
Rewrote the CL-GD 54xx blitter, fixes Win-OS/2 on the 54x6 among other thing;
Added the Image Manager 1024 and Professional Graphics Controller per PCem patch by John Elliott and work done on VARCem;
Added Headland HT-216, GC-205 and Video 7 VGA 1024i emulation based on PCem commit;
Implemented the fuction keys for the Toshiba T1000/T1200/T3100 enhancement;
Amstrad MegaPC does now works correctly with non-internal graphics card;
The SLiRP code no longer casts a packed struct type to a non-packed struct type;
The Xi8088 and PB410a no longer hang on 86Box when PS/2 mouse is not present;
The S3 Virge on BeOS is no longer broken (was broken by build #1591);
OS/2 2.0 build 6.167 now sees key presses again;
Xi8088 now work on CGA again;
86F images converted from either the old or new variants of the HxC MFM format now work correctly;
Hardware interrupts with a vector of 0xFF are now handled correctly;
OPTi 495SX boards no longer incorrectly have 64 MB maximum RAM when 32 MB is correct;
Fixed VNC keyboard input bugs;
Fixed AT RTC periodic interrupt - Chicago 58s / 73f / 73g / 81 MIDI play no longer hangs with the build's own VTD driver;
Fixed mouse polling with internal mice - Amstrad and Olivetti mice now work correctly;
Triones ATAPI DMA driver now correctly reads a file at the end of a CD image with a sectors number not divisible by 4;
Compaq Portable now works with all graphics cards;
Fixed various MDSI Genius bugs;
Added segment limit checks and improved page fault checks for several CPU instructions - Memphis 15xx WINSETUP and Chicago 58s WINDISK.CPL no longer issue a GPF, and some S3 drivers that used to have glitches, now work correctly;
Further improved the 808x emulation, also fixes the noticably choppy sound when using 808x CPU's, also fixes #355;
OS/2 installer no logner locks up on splash screen on PS/2 Model 70 and 80, fixes #400.
Fixed several Amstead bugs, GEM no longer crashes on the Amstrad 1640, fixes #391.
Ported John Elliott's Amstrad fixes and improvement from PCem, and fixed the default language so it's correctly Engliish, fixes #278, fixes #389.
Fixed a minor IDE timing bug, fixes #388.
Fixed Toshiba T1000 RAM issues, fixes #379.
Fixed EGA/(S)VGA overscan border handling, fixes #378;
Got rid of the now long useless IDE channel 2 auto-removal, fixes #370;
Fixed the BIOS files used by the AMSTRAD PC1512, fixes #366;
Ported the Unicode CD image file name fix from VARCem, fixes #365;
Fixed high density floppy disks on the Xi8088, fixes #359;
Fixed some bugs in the Hercules emulation, fixes #346, fixes #358;
Fixed the SCSI hard disk mode sense pages, fixes #356;
Removed the AMI Unknown 386SX because of impossibility to identify the chipset, closes #349;
Fixed bugs in the serial mouse emulation, fixes #344;
Compiled 86Box binaries now include all the required .DLL's, fixes #341;
Made some combo boxes in the Settings dialog slightly wider, fixes #276.
2019-09-20 14:02:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2023-06-28 13:46:28 -04:00
|
|
|
device_context_inst(const device_t *dev, int inst)
|
Added the IBM 5161 ISA expansion for PC and XT;
Cleaned up the parallel port emulation, added IRQ support, and made enabling/disabling per port;
Added the Award 430NX and the Intel Classic/PCI (Alfredo, 420TX);
Finished the 586MC1;
Added 8087 emulation;
Moved Cyrix 6x86'es to the Dev branch;
Sanitized/cleaned up memregs.c/h and intel.c/h;
Split the chipsets from machines and sanitized Port 92 emulation;
Added support for the 15bpp mode to the Compaq ATI 28800;
Moved the MR 386DX and 486 machines to the Dev branch;
Ported the new dynamic recompiler from PCem, but it remains in Dev branch until after v2.00;
Ported the new timer code from PCem;
Cleaned up the CPU table of unused stuff and better optimized its structure;
Ported the Open-XT and Open-AT from VARCem, the Open-AT is in the Dev branch;
Ported the XT MFM controller rewrite and adding of more controllers (incl. two RLL ones), from VARCem;
Added the AHA-1540A and the BusTek BT-542B;
Moved the Sumo SCSI-AT to the Dev branch;
Minor IDE, FDC, and floppy drive code clean-ups;
Made NCR 5380/53C400-based cards' BIOS address configurable;
Got rid of the legacy romset variable;
Unified (video) buffer and buffer32 into one and make the unified buffer 32-bit;
Added the Amstead PPC512 per PCem patch by John Elliott;
Switched memory mapping granularity from 16k to 4k (less than 1k not possible due to internal pages);
Rewrote the CL-GD 54xx blitter, fixes Win-OS/2 on the 54x6 among other thing;
Added the Image Manager 1024 and Professional Graphics Controller per PCem patch by John Elliott and work done on VARCem;
Added Headland HT-216, GC-205 and Video 7 VGA 1024i emulation based on PCem commit;
Implemented the fuction keys for the Toshiba T1000/T1200/T3100 enhancement;
Amstrad MegaPC does now works correctly with non-internal graphics card;
The SLiRP code no longer casts a packed struct type to a non-packed struct type;
The Xi8088 and PB410a no longer hang on 86Box when PS/2 mouse is not present;
The S3 Virge on BeOS is no longer broken (was broken by build #1591);
OS/2 2.0 build 6.167 now sees key presses again;
Xi8088 now work on CGA again;
86F images converted from either the old or new variants of the HxC MFM format now work correctly;
Hardware interrupts with a vector of 0xFF are now handled correctly;
OPTi 495SX boards no longer incorrectly have 64 MB maximum RAM when 32 MB is correct;
Fixed VNC keyboard input bugs;
Fixed AT RTC periodic interrupt - Chicago 58s / 73f / 73g / 81 MIDI play no longer hangs with the build's own VTD driver;
Fixed mouse polling with internal mice - Amstrad and Olivetti mice now work correctly;
Triones ATAPI DMA driver now correctly reads a file at the end of a CD image with a sectors number not divisible by 4;
Compaq Portable now works with all graphics cards;
Fixed various MDSI Genius bugs;
Added segment limit checks and improved page fault checks for several CPU instructions - Memphis 15xx WINSETUP and Chicago 58s WINDISK.CPL no longer issue a GPF, and some S3 drivers that used to have glitches, now work correctly;
Further improved the 808x emulation, also fixes the noticably choppy sound when using 808x CPU's, also fixes #355;
OS/2 installer no logner locks up on splash screen on PS/2 Model 70 and 80, fixes #400.
Fixed several Amstead bugs, GEM no longer crashes on the Amstrad 1640, fixes #391.
Ported John Elliott's Amstrad fixes and improvement from PCem, and fixed the default language so it's correctly Engliish, fixes #278, fixes #389.
Fixed a minor IDE timing bug, fixes #388.
Fixed Toshiba T1000 RAM issues, fixes #379.
Fixed EGA/(S)VGA overscan border handling, fixes #378;
Got rid of the now long useless IDE channel 2 auto-removal, fixes #370;
Fixed the BIOS files used by the AMSTRAD PC1512, fixes #366;
Ported the Unicode CD image file name fix from VARCem, fixes #365;
Fixed high density floppy disks on the Xi8088, fixes #359;
Fixed some bugs in the Hercules emulation, fixes #346, fixes #358;
Fixed the SCSI hard disk mode sense pages, fixes #356;
Removed the AMI Unknown 386SX because of impossibility to identify the chipset, closes #349;
Fixed bugs in the serial mouse emulation, fixes #344;
Compiled 86Box binaries now include all the required .DLL's, fixes #341;
Made some combo boxes in the Settings dialog slightly wider, fixes #276.
2019-09-20 14:02:30 +02:00
|
|
|
{
|
2023-06-28 13:46:28 -04:00
|
|
|
device_context_common(dev, inst);
|
Added the IBM 5161 ISA expansion for PC and XT;
Cleaned up the parallel port emulation, added IRQ support, and made enabling/disabling per port;
Added the Award 430NX and the Intel Classic/PCI (Alfredo, 420TX);
Finished the 586MC1;
Added 8087 emulation;
Moved Cyrix 6x86'es to the Dev branch;
Sanitized/cleaned up memregs.c/h and intel.c/h;
Split the chipsets from machines and sanitized Port 92 emulation;
Added support for the 15bpp mode to the Compaq ATI 28800;
Moved the MR 386DX and 486 machines to the Dev branch;
Ported the new dynamic recompiler from PCem, but it remains in Dev branch until after v2.00;
Ported the new timer code from PCem;
Cleaned up the CPU table of unused stuff and better optimized its structure;
Ported the Open-XT and Open-AT from VARCem, the Open-AT is in the Dev branch;
Ported the XT MFM controller rewrite and adding of more controllers (incl. two RLL ones), from VARCem;
Added the AHA-1540A and the BusTek BT-542B;
Moved the Sumo SCSI-AT to the Dev branch;
Minor IDE, FDC, and floppy drive code clean-ups;
Made NCR 5380/53C400-based cards' BIOS address configurable;
Got rid of the legacy romset variable;
Unified (video) buffer and buffer32 into one and make the unified buffer 32-bit;
Added the Amstead PPC512 per PCem patch by John Elliott;
Switched memory mapping granularity from 16k to 4k (less than 1k not possible due to internal pages);
Rewrote the CL-GD 54xx blitter, fixes Win-OS/2 on the 54x6 among other thing;
Added the Image Manager 1024 and Professional Graphics Controller per PCem patch by John Elliott and work done on VARCem;
Added Headland HT-216, GC-205 and Video 7 VGA 1024i emulation based on PCem commit;
Implemented the fuction keys for the Toshiba T1000/T1200/T3100 enhancement;
Amstrad MegaPC does now works correctly with non-internal graphics card;
The SLiRP code no longer casts a packed struct type to a non-packed struct type;
The Xi8088 and PB410a no longer hang on 86Box when PS/2 mouse is not present;
The S3 Virge on BeOS is no longer broken (was broken by build #1591);
OS/2 2.0 build 6.167 now sees key presses again;
Xi8088 now work on CGA again;
86F images converted from either the old or new variants of the HxC MFM format now work correctly;
Hardware interrupts with a vector of 0xFF are now handled correctly;
OPTi 495SX boards no longer incorrectly have 64 MB maximum RAM when 32 MB is correct;
Fixed VNC keyboard input bugs;
Fixed AT RTC periodic interrupt - Chicago 58s / 73f / 73g / 81 MIDI play no longer hangs with the build's own VTD driver;
Fixed mouse polling with internal mice - Amstrad and Olivetti mice now work correctly;
Triones ATAPI DMA driver now correctly reads a file at the end of a CD image with a sectors number not divisible by 4;
Compaq Portable now works with all graphics cards;
Fixed various MDSI Genius bugs;
Added segment limit checks and improved page fault checks for several CPU instructions - Memphis 15xx WINSETUP and Chicago 58s WINDISK.CPL no longer issue a GPF, and some S3 drivers that used to have glitches, now work correctly;
Further improved the 808x emulation, also fixes the noticably choppy sound when using 808x CPU's, also fixes #355;
OS/2 installer no logner locks up on splash screen on PS/2 Model 70 and 80, fixes #400.
Fixed several Amstead bugs, GEM no longer crashes on the Amstrad 1640, fixes #391.
Ported John Elliott's Amstrad fixes and improvement from PCem, and fixed the default language so it's correctly Engliish, fixes #278, fixes #389.
Fixed a minor IDE timing bug, fixes #388.
Fixed Toshiba T1000 RAM issues, fixes #379.
Fixed EGA/(S)VGA overscan border handling, fixes #378;
Got rid of the now long useless IDE channel 2 auto-removal, fixes #370;
Fixed the BIOS files used by the AMSTRAD PC1512, fixes #366;
Ported the Unicode CD image file name fix from VARCem, fixes #365;
Fixed high density floppy disks on the Xi8088, fixes #359;
Fixed some bugs in the Hercules emulation, fixes #346, fixes #358;
Fixed the SCSI hard disk mode sense pages, fixes #356;
Removed the AMI Unknown 386SX because of impossibility to identify the chipset, closes #349;
Fixed bugs in the serial mouse emulation, fixes #344;
Compiled 86Box binaries now include all the required .DLL's, fixes #341;
Made some combo boxes in the Settings dialog slightly wider, fixes #276.
2019-09-20 14:02:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
device_context_restore(void)
|
|
|
|
|
{
|
|
|
|
|
memcpy(&device_current, &device_prev, sizeof(device_context_t));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void *
|
2024-05-25 02:00:19 +02:00
|
|
|
device_add_common(const device_t *dev, void *p, void *params, int inst)
|
2016-06-26 00:34:39 +02:00
|
|
|
{
|
2024-05-25 02:02:55 +02:00
|
|
|
device_t *init_dev = NULL;
|
|
|
|
|
void *priv = NULL;
|
2025-01-06 23:28:08 -05:00
|
|
|
int16_t c;
|
2024-05-25 02:00:19 +02:00
|
|
|
|
2024-09-09 00:43:14 -04:00
|
|
|
/*
|
|
|
|
|
IMPORTANT: This is needed to gracefully handle machine
|
|
|
|
|
device addition if the relevant device is NULL.
|
|
|
|
|
*/
|
|
|
|
|
if (dev == NULL)
|
|
|
|
|
return NULL;
|
|
|
|
|
|
2025-01-27 01:20:37 +01:00
|
|
|
if (!device_available(dev)) {
|
|
|
|
|
wchar_t temp[512] = { 0 };
|
|
|
|
|
swprintf(temp, sizeof_w(temp),
|
|
|
|
|
plat_get_string(STRING_HW_NOT_AVAILABLE_DEVICE),
|
|
|
|
|
dev->name);
|
|
|
|
|
ui_msgbox_header(MBX_INFO,
|
|
|
|
|
plat_get_string(STRING_HW_NOT_AVAILABLE_TITLE),
|
|
|
|
|
temp);
|
|
|
|
|
return ((void *) dev->name);
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-25 02:00:19 +02:00
|
|
|
if (params != NULL) {
|
|
|
|
|
init_dev = calloc(1, sizeof(device_t));
|
|
|
|
|
memcpy(init_dev, dev, sizeof(device_t));
|
|
|
|
|
init_dev->local |= (uintptr_t) params;
|
|
|
|
|
} else
|
|
|
|
|
init_dev = (device_t *) dev;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
for (c = 0; c < DEVICE_MAX; c++) {
|
2023-06-09 23:46:54 -04:00
|
|
|
if (!inst && (devices[c] == dev)) {
|
2022-09-18 17:11:43 -04:00
|
|
|
device_log("DEVICE: device already exists!\n");
|
|
|
|
|
return (NULL);
|
|
|
|
|
}
|
|
|
|
|
if (devices[c] == NULL)
|
|
|
|
|
break;
|
2017-11-05 01:57:04 -05:00
|
|
|
}
|
2024-05-25 02:00:19 +02:00
|
|
|
if (c >= DEVICE_MAX) {
|
2025-01-27 01:20:37 +01:00
|
|
|
fatal("Attempting to initialize more than the maximum "
|
|
|
|
|
"limit of %i devices\n", DEVICE_MAX);
|
2023-06-19 01:10:15 +02:00
|
|
|
return NULL;
|
2023-06-18 23:58:05 +02:00
|
|
|
}
|
2017-11-05 01:57:04 -05:00
|
|
|
|
2018-10-25 07:43:32 +02:00
|
|
|
/* Do this so that a chained device_add will not identify the same ID
|
|
|
|
|
its master device is already trying to assign. */
|
2023-06-28 13:46:28 -04:00
|
|
|
devices[c] = (device_t *) dev;
|
2023-10-21 06:53:11 +02:00
|
|
|
if (!strcmp(dev->name, "None") || !strcmp(dev->name, "Internal"))
|
|
|
|
|
fatal("Attempting to add dummy device of type: %s\n", dev->name);
|
2018-10-25 07:43:32 +02:00
|
|
|
|
2018-10-23 21:14:41 +02:00
|
|
|
if (p == NULL) {
|
2022-09-18 17:11:43 -04:00
|
|
|
memcpy(&device_prev, &device_current, sizeof(device_context_t));
|
2024-05-25 02:00:19 +02:00
|
|
|
device_set_context(&device_current, dev, inst);
|
2022-09-18 17:11:43 -04:00
|
|
|
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev->init != NULL) {
|
2024-05-25 02:00:19 +02:00
|
|
|
/* Give it our temporary device in case we have dynamically changed info->local. */
|
|
|
|
|
priv = dev->init(init_dev);
|
|
|
|
|
|
2022-09-18 17:11:43 -04:00
|
|
|
if (priv == NULL) {
|
2024-05-25 02:00:19 +02:00
|
|
|
#ifdef ENABLE_DEVICE_LOG
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev->name)
|
|
|
|
|
device_log("DEVICE: device '%s' init failed\n", dev->name);
|
2022-09-18 17:11:43 -04:00
|
|
|
else
|
|
|
|
|
device_log("DEVICE: device init failed\n");
|
2024-05-25 02:00:19 +02:00
|
|
|
#endif
|
2022-09-18 17:11:43 -04:00
|
|
|
|
|
|
|
|
devices[c] = NULL;
|
|
|
|
|
device_priv[c] = NULL;
|
|
|
|
|
|
2024-07-19 22:08:37 +02:00
|
|
|
if ((init_dev != NULL) && (init_dev != (device_t *) dev))
|
2024-07-19 22:02:02 +02:00
|
|
|
free(init_dev);
|
2024-05-25 02:00:19 +02:00
|
|
|
|
2022-09-18 17:11:43 -04:00
|
|
|
return (NULL);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-25 02:00:19 +02:00
|
|
|
#ifdef ENABLE_DEVICE_LOG
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev->name)
|
|
|
|
|
device_log("DEVICE: device '%s' init successful\n", dev->name);
|
2022-09-18 17:11:43 -04:00
|
|
|
else
|
|
|
|
|
device_log("DEVICE: device init successful\n");
|
2024-05-25 02:00:19 +02:00
|
|
|
#endif
|
2022-09-18 17:11:43 -04:00
|
|
|
|
|
|
|
|
memcpy(&device_current, &device_prev, sizeof(device_context_t));
|
|
|
|
|
device_priv[c] = priv;
|
2018-10-23 21:14:41 +02:00
|
|
|
} else
|
2022-09-18 17:11:43 -04:00
|
|
|
device_priv[c] = p;
|
2018-10-23 21:14:41 +02:00
|
|
|
|
2024-05-25 02:02:55 +02:00
|
|
|
if (init_dev != dev)
|
|
|
|
|
free(init_dev);
|
2024-05-25 02:00:19 +02:00
|
|
|
|
2023-05-11 03:02:36 -04:00
|
|
|
return priv;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2023-08-21 20:25:33 -04:00
|
|
|
const char *
|
2023-06-28 13:46:28 -04:00
|
|
|
device_get_internal_name(const device_t *dev)
|
2022-02-03 03:10:06 +01:00
|
|
|
{
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev == NULL)
|
2022-09-18 17:11:43 -04:00
|
|
|
return "";
|
2022-02-03 03:10:06 +01:00
|
|
|
|
2023-08-21 20:25:33 -04:00
|
|
|
return dev->internal_name;
|
2022-02-03 03:10:06 +01:00
|
|
|
}
|
|
|
|
|
|
2018-10-23 21:14:41 +02:00
|
|
|
void *
|
2023-06-28 13:46:28 -04:00
|
|
|
device_add(const device_t *dev)
|
2018-10-23 21:14:41 +02:00
|
|
|
{
|
2024-05-25 02:00:19 +02:00
|
|
|
return device_add_common(dev, NULL, NULL, 0);
|
2023-02-19 22:49:30 +06:00
|
|
|
}
|
|
|
|
|
|
2024-02-22 00:52:20 +01:00
|
|
|
void *
|
|
|
|
|
device_add_linked(const device_t *dev, void *priv)
|
|
|
|
|
{
|
|
|
|
|
void *ret;
|
2025-01-06 23:28:08 -05:00
|
|
|
|
2024-02-22 00:52:20 +01:00
|
|
|
device_common_priv = priv;
|
2024-05-25 02:00:19 +02:00
|
|
|
ret = device_add_common(dev, NULL, NULL, 0);
|
2024-02-22 00:52:20 +01:00
|
|
|
device_common_priv = NULL;
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
2023-02-19 22:49:30 +06:00
|
|
|
void *
|
2024-05-25 02:00:19 +02:00
|
|
|
device_add_params(const device_t *dev, void *params)
|
2023-02-19 22:49:30 +06:00
|
|
|
{
|
2024-05-25 02:00:19 +02:00
|
|
|
return device_add_common(dev, NULL, params, 0);
|
2018-10-23 21:14:41 +02:00
|
|
|
}
|
|
|
|
|
|
2017-11-05 01:57:04 -05:00
|
|
|
/* For devices that do not have an init function (internal video etc.) */
|
|
|
|
|
void
|
2023-06-28 13:46:28 -04:00
|
|
|
device_add_ex(const device_t *dev, void *priv)
|
2017-11-05 01:57:04 -05:00
|
|
|
{
|
2024-05-25 02:00:19 +02:00
|
|
|
device_add_common(dev, priv, NULL, 0);
|
2023-02-19 22:49:30 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2024-05-25 02:00:19 +02:00
|
|
|
device_add_ex_params(const device_t *dev, void *priv, void *params)
|
2023-02-19 22:49:30 +06:00
|
|
|
{
|
2024-05-25 02:00:19 +02:00
|
|
|
device_add_common(dev, priv, params, 0);
|
2018-10-23 21:14:41 +02:00
|
|
|
}
|
2017-11-05 01:57:04 -05:00
|
|
|
|
2018-10-23 21:14:41 +02:00
|
|
|
void *
|
2023-06-28 13:46:28 -04:00
|
|
|
device_add_inst(const device_t *dev, int inst)
|
2018-10-23 21:14:41 +02:00
|
|
|
{
|
2024-05-25 02:00:19 +02:00
|
|
|
return device_add_common(dev, NULL, NULL, inst);
|
2023-02-19 22:49:30 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void *
|
2024-05-25 02:00:19 +02:00
|
|
|
device_add_inst_params(const device_t *dev, int inst, void *params)
|
2023-02-19 22:49:30 +06:00
|
|
|
{
|
2024-05-25 02:00:19 +02:00
|
|
|
return device_add_common(dev, NULL, params, inst);
|
2018-10-23 21:14:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* For devices that do not have an init function (internal video etc.) */
|
|
|
|
|
void
|
2023-06-28 13:46:28 -04:00
|
|
|
device_add_inst_ex(const device_t *dev, void *priv, int inst)
|
2018-10-23 21:14:41 +02:00
|
|
|
{
|
2024-05-25 02:00:19 +02:00
|
|
|
device_add_common(dev, priv, NULL, inst);
|
2023-02-19 22:49:30 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2024-05-25 02:00:19 +02:00
|
|
|
device_add_inst_ex_params(const device_t *dev, void *priv, int inst, void *params)
|
2023-02-19 22:49:30 +06:00
|
|
|
{
|
2024-05-25 02:00:19 +02:00
|
|
|
device_add_common(dev, priv, params, inst);
|
2017-11-05 01:57:04 -05:00
|
|
|
}
|
|
|
|
|
|
2024-02-22 00:52:20 +01:00
|
|
|
void *
|
|
|
|
|
device_get_common_priv(void)
|
|
|
|
|
{
|
|
|
|
|
return device_common_priv;
|
|
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
void
|
|
|
|
|
device_close_all(void)
|
|
|
|
|
{
|
2023-05-11 03:02:36 -04:00
|
|
|
for (int16_t c = (DEVICE_MAX - 1); c >= 0; c--) {
|
2022-09-18 17:11:43 -04:00
|
|
|
if (devices[c] != NULL) {
|
2024-05-25 02:00:19 +02:00
|
|
|
#ifdef ENABLE_DEVICE_LOG
|
2022-09-18 17:11:43 -04:00
|
|
|
if (devices[c]->name)
|
|
|
|
|
device_log("Closing device: \"%s\"...\n", devices[c]->name);
|
2024-05-25 02:00:19 +02:00
|
|
|
#endif
|
2022-09-18 17:11:43 -04:00
|
|
|
if (devices[c]->close != NULL)
|
|
|
|
|
devices[c]->close(device_priv[c]);
|
2025-01-06 23:28:08 -05:00
|
|
|
devices[c] = NULL;
|
|
|
|
|
device_priv[c] = NULL;
|
2022-09-18 17:11:43 -04:00
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
2016-06-26 00:34:39 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
void
|
2023-04-19 23:34:32 +02:00
|
|
|
device_reset_all(uint32_t match_flags)
|
2016-06-26 00:34:39 +02:00
|
|
|
{
|
2023-05-11 03:02:36 -04:00
|
|
|
for (uint16_t c = 0; c < DEVICE_MAX; c++) {
|
2022-09-18 17:11:43 -04:00
|
|
|
if (devices[c] != NULL) {
|
2023-04-19 23:34:32 +02:00
|
|
|
if ((devices[c]->reset != NULL) && (devices[c]->flags & match_flags))
|
2022-09-18 17:11:43 -04:00
|
|
|
devices[c]->reset(device_priv[c]);
|
|
|
|
|
}
|
2018-04-25 23:51:13 +02:00
|
|
|
}
|
2024-05-03 17:02:13 +02:00
|
|
|
|
2024-05-03 18:47:54 +02:00
|
|
|
#ifdef UNCOMMENT_LATER
|
2024-05-03 17:02:13 +02:00
|
|
|
/* TODO: Actually convert the LPT devices to device_t's. */
|
|
|
|
|
if ((match_flags == DEVICE_ALL) || (match_flags == DEVICE_PCI))
|
|
|
|
|
lpt_reset();
|
2024-05-03 18:47:54 +02:00
|
|
|
#endif
|
2018-04-25 23:51:13 +02:00
|
|
|
}
|
|
|
|
|
|
2023-10-20 02:57:50 +02:00
|
|
|
void *
|
|
|
|
|
device_find_first_priv(uint32_t match_flags)
|
|
|
|
|
{
|
|
|
|
|
void *ret = NULL;
|
|
|
|
|
|
|
|
|
|
for (uint16_t c = 0; c < DEVICE_MAX; c++) {
|
|
|
|
|
if (devices[c] != NULL) {
|
|
|
|
|
if ((device_priv[c] != NULL) && (devices[c]->flags & match_flags)) {
|
|
|
|
|
ret = device_priv[c];
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
void *
|
2023-06-28 13:46:28 -04:00
|
|
|
device_get_priv(const device_t *dev)
|
2017-06-14 03:03:29 +02:00
|
|
|
{
|
2023-05-11 03:02:36 -04:00
|
|
|
for (uint16_t c = 0; c < DEVICE_MAX; c++) {
|
2022-09-18 17:11:43 -04:00
|
|
|
if (devices[c] != NULL) {
|
2023-06-28 13:46:28 -04:00
|
|
|
if (devices[c] == dev)
|
2022-09-18 17:11:43 -04:00
|
|
|
return (device_priv[c]);
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2022-09-18 17:11:43 -04:00
|
|
|
return (NULL);
|
2017-06-14 03:03:29 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
int
|
2023-06-28 13:46:28 -04:00
|
|
|
device_available(const device_t *dev)
|
2016-06-26 00:34:39 +02:00
|
|
|
{
|
2024-05-25 02:00:19 +02:00
|
|
|
const device_config_t *config = NULL;
|
|
|
|
|
const device_config_bios_t *bios = NULL;
|
2022-07-22 23:35:18 -04:00
|
|
|
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev != NULL) {
|
2023-06-09 23:46:54 -04:00
|
|
|
config = dev->config;
|
2022-09-18 17:11:43 -04:00
|
|
|
if (config != NULL) {
|
2025-01-06 23:28:08 -05:00
|
|
|
while (config->type != CONFIG_END) {
|
2022-09-18 17:11:43 -04:00
|
|
|
if (config->type == CONFIG_BIOS) {
|
2024-05-25 02:00:19 +02:00
|
|
|
int roms_present = 0;
|
|
|
|
|
|
2023-07-20 18:58:26 -04:00
|
|
|
bios = (const device_config_bios_t *) config->bios;
|
2022-09-18 17:11:43 -04:00
|
|
|
|
|
|
|
|
/* Go through the ROM's in the device configuration. */
|
|
|
|
|
while (bios->files_no != 0) {
|
2024-05-25 02:00:19 +02:00
|
|
|
int i = 0;
|
2023-05-11 03:02:36 -04:00
|
|
|
for (int bf = 0; bf < bios->files_no; bf++)
|
2023-06-09 23:46:54 -04:00
|
|
|
i += !!rom_present(bios->files[bf]);
|
2022-09-18 17:11:43 -04:00
|
|
|
if (i == bios->files_no)
|
|
|
|
|
roms_present++;
|
|
|
|
|
bios++;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return (roms_present ? -1 : 0);
|
|
|
|
|
}
|
|
|
|
|
config++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* No CONFIG_BIOS field present, use the classic available(). */
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev->available != NULL)
|
|
|
|
|
return (dev->available());
|
2022-09-18 17:11:43 -04:00
|
|
|
else
|
2023-05-11 03:02:36 -04:00
|
|
|
return 1;
|
2022-07-22 23:35:18 -04:00
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2022-07-22 23:35:18 -04:00
|
|
|
/* A NULL device is never available. */
|
2023-05-11 03:02:36 -04:00
|
|
|
return 0;
|
2016-06-26 00:34:39 +02:00
|
|
|
}
|
|
|
|
|
|
2022-12-22 02:30:25 +01:00
|
|
|
const char *
|
2023-06-28 13:46:28 -04:00
|
|
|
device_get_bios_file(const device_t *dev, const char *internal_name, int file_no)
|
2022-12-22 02:30:25 +01:00
|
|
|
{
|
2023-07-20 18:58:26 -04:00
|
|
|
const device_config_t *config = NULL;
|
|
|
|
|
const device_config_bios_t *bios = NULL;
|
2022-12-22 02:30:25 +01:00
|
|
|
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev != NULL) {
|
2023-06-09 23:46:54 -04:00
|
|
|
config = dev->config;
|
2022-12-22 02:30:25 +01:00
|
|
|
if (config != NULL) {
|
2025-01-06 23:28:08 -05:00
|
|
|
while (config->type != CONFIG_END) {
|
2022-12-22 02:30:25 +01:00
|
|
|
if (config->type == CONFIG_BIOS) {
|
2023-06-09 23:46:54 -04:00
|
|
|
bios = config->bios;
|
2022-12-22 02:30:25 +01:00
|
|
|
|
|
|
|
|
/* Go through the ROM's in the device configuration. */
|
|
|
|
|
while (bios->files_no != 0) {
|
|
|
|
|
if (!strcmp(internal_name, bios->internal_name)) {
|
|
|
|
|
if (file_no < bios->files_no)
|
|
|
|
|
return bios->files[file_no];
|
|
|
|
|
else
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
bios++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
config++;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* A NULL device is never available. */
|
|
|
|
|
return (NULL);
|
|
|
|
|
}
|
|
|
|
|
|
2022-04-04 18:11:39 +02:00
|
|
|
int
|
2023-06-28 13:46:28 -04:00
|
|
|
device_has_config(const device_t *dev)
|
2022-04-04 18:11:39 +02:00
|
|
|
{
|
2023-07-20 18:58:26 -04:00
|
|
|
int c = 0;
|
|
|
|
|
const device_config_t *config;
|
2022-04-04 18:11:39 +02:00
|
|
|
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev == NULL)
|
2022-09-18 17:11:43 -04:00
|
|
|
return 0;
|
2022-04-04 18:11:39 +02:00
|
|
|
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev->config == NULL)
|
2022-09-18 17:11:43 -04:00
|
|
|
return 0;
|
2022-04-04 18:11:39 +02:00
|
|
|
|
2023-06-09 23:46:54 -04:00
|
|
|
config = dev->config;
|
2022-04-04 18:11:39 +02:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (config->type != CONFIG_END) {
|
2024-03-29 08:23:55 -04:00
|
|
|
c++;
|
2022-09-18 17:11:43 -04:00
|
|
|
config++;
|
2022-04-04 18:11:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return (c > 0) ? 1 : 0;
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-16 00:01:21 +01:00
|
|
|
void
|
2023-06-28 13:46:28 -04:00
|
|
|
device_get_name(const device_t *dev, int bus, char *name)
|
2020-11-16 00:01:21 +01:00
|
|
|
{
|
2023-07-20 18:58:26 -04:00
|
|
|
const char *sbus = NULL;
|
|
|
|
|
const char *fbus;
|
|
|
|
|
char *tname;
|
2025-02-21 22:25:00 +01:00
|
|
|
char pbus[16] = { 0 };
|
2020-11-16 00:01:21 +01:00
|
|
|
|
2023-06-28 13:46:28 -04:00
|
|
|
if (dev == NULL)
|
2022-09-18 17:11:43 -04:00
|
|
|
return;
|
2020-11-16 00:01:21 +01:00
|
|
|
|
|
|
|
|
name[0] = 0x00;
|
|
|
|
|
|
|
|
|
|
if (bus) {
|
2025-02-14 07:39:21 +01:00
|
|
|
if ((dev->flags & (DEVICE_SIDECAR | DEVICE_ISA)) ==
|
|
|
|
|
(DEVICE_SIDECAR | DEVICE_ISA))
|
|
|
|
|
sbus = "ISA/Sidecar";
|
2025-02-14 07:10:55 +01:00
|
|
|
else if (dev->flags & DEVICE_SIDECAR)
|
|
|
|
|
sbus = "Sidecar";
|
|
|
|
|
else if (dev->flags & DEVICE_XT_KBC)
|
|
|
|
|
sbus = "XT KBC";
|
|
|
|
|
else if (dev->flags & DEVICE_ISA16)
|
|
|
|
|
sbus = "ISA16";
|
|
|
|
|
else if (dev->flags & DEVICE_AT_KBC)
|
|
|
|
|
sbus = "AT KBC";
|
|
|
|
|
else if (dev->flags & DEVICE_PS2_KBC)
|
|
|
|
|
sbus = "PS/2 KBC";
|
|
|
|
|
else if (dev->flags & DEVICE_ISA)
|
|
|
|
|
sbus = "ISA";
|
2023-06-28 13:46:28 -04:00
|
|
|
else if (dev->flags & DEVICE_CBUS)
|
2022-09-18 17:11:43 -04:00
|
|
|
sbus = "C-BUS";
|
2025-01-02 01:39:23 -05:00
|
|
|
else if (dev->flags & DEVICE_PCMCIA)
|
|
|
|
|
sbus = "PCMCIA";
|
2023-06-28 13:46:28 -04:00
|
|
|
else if (dev->flags & DEVICE_MCA)
|
2022-09-18 17:11:43 -04:00
|
|
|
sbus = "MCA";
|
2025-02-14 07:39:21 +01:00
|
|
|
else if (dev->flags & DEVICE_MCA32)
|
|
|
|
|
sbus = "MCA32";
|
2025-01-02 01:39:23 -05:00
|
|
|
else if (dev->flags & DEVICE_HIL)
|
|
|
|
|
sbus = "HP HIL";
|
2023-06-28 13:46:28 -04:00
|
|
|
else if (dev->flags & DEVICE_EISA)
|
2022-09-18 17:11:43 -04:00
|
|
|
sbus = "EISA";
|
2025-01-02 01:39:23 -05:00
|
|
|
else if (dev->flags & DEVICE_AT32)
|
|
|
|
|
sbus = "AT/32";
|
|
|
|
|
else if (dev->flags & DEVICE_OLB)
|
|
|
|
|
sbus = "OLB";
|
2023-06-28 13:46:28 -04:00
|
|
|
else if (dev->flags & DEVICE_VLB)
|
2022-09-18 17:11:43 -04:00
|
|
|
sbus = "VLB";
|
2023-06-28 13:46:28 -04:00
|
|
|
else if (dev->flags & DEVICE_PCI)
|
2022-09-18 17:11:43 -04:00
|
|
|
sbus = "PCI";
|
2025-01-02 01:39:23 -05:00
|
|
|
else if (dev->flags & DEVICE_CARDBUS)
|
2025-02-14 07:10:55 +01:00
|
|
|
sbus = "CardBus";
|
2025-01-02 01:39:23 -05:00
|
|
|
else if (dev->flags & DEVICE_USB)
|
|
|
|
|
sbus = "USB";
|
2023-06-28 13:46:28 -04:00
|
|
|
else if (dev->flags & DEVICE_AGP)
|
2022-09-18 17:11:43 -04:00
|
|
|
sbus = "AGP";
|
2023-06-28 13:46:28 -04:00
|
|
|
else if (dev->flags & DEVICE_AC97)
|
2022-09-18 17:11:43 -04:00
|
|
|
sbus = "AMR";
|
2023-06-28 13:46:28 -04:00
|
|
|
else if (dev->flags & DEVICE_COM)
|
2022-09-18 17:11:43 -04:00
|
|
|
sbus = "COM";
|
2023-06-28 13:46:28 -04:00
|
|
|
else if (dev->flags & DEVICE_LPT)
|
2022-09-18 17:11:43 -04:00
|
|
|
sbus = "LPT";
|
|
|
|
|
|
|
|
|
|
if (sbus != NULL) {
|
|
|
|
|
/* First concatenate [<Bus>] before the device's name. */
|
|
|
|
|
strcat(name, "[");
|
|
|
|
|
strcat(name, sbus);
|
|
|
|
|
strcat(name, "] ");
|
|
|
|
|
|
|
|
|
|
/* Then change string from ISA16 to ISA if applicable. */
|
|
|
|
|
if (!strcmp(sbus, "ISA16"))
|
|
|
|
|
sbus = "ISA";
|
|
|
|
|
else if (!strcmp(sbus, "COM") || !strcmp(sbus, "LPT")) {
|
|
|
|
|
sbus = NULL;
|
2023-06-28 13:46:28 -04:00
|
|
|
strcat(name, dev->name);
|
2022-09-18 17:11:43 -04:00
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Generate the bus string with parentheses. */
|
|
|
|
|
strcat(pbus, "(");
|
|
|
|
|
strcat(pbus, sbus);
|
|
|
|
|
strcat(pbus, ")");
|
|
|
|
|
|
|
|
|
|
/* Allocate the temporary device name string and set it to all zeroes. */
|
2025-01-06 23:28:08 -05:00
|
|
|
tname = (char *) calloc(1, strlen(dev->name) + 1);
|
2022-09-18 17:11:43 -04:00
|
|
|
|
|
|
|
|
/* First strip the bus string with parentheses. */
|
2023-06-28 13:46:28 -04:00
|
|
|
fbus = strstr(dev->name, pbus);
|
|
|
|
|
if (fbus == dev->name)
|
|
|
|
|
strcat(tname, dev->name + strlen(pbus) + 1);
|
2022-09-18 17:11:43 -04:00
|
|
|
else if (fbus == NULL)
|
2023-06-28 13:46:28 -04:00
|
|
|
strcat(tname, dev->name);
|
2022-09-18 17:11:43 -04:00
|
|
|
else {
|
2023-06-28 13:46:28 -04:00
|
|
|
strncat(tname, dev->name, fbus - dev->name - 1);
|
2022-09-18 17:11:43 -04:00
|
|
|
strcat(tname, fbus + strlen(pbus));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Then also strip the bus string with parentheses. */
|
|
|
|
|
fbus = strstr(tname, sbus);
|
|
|
|
|
if (fbus == tname)
|
|
|
|
|
strcat(name, tname + strlen(sbus) + 1);
|
|
|
|
|
/* Special case to not strip the "oPCI" from "Ensoniq AudioPCI" or
|
|
|
|
|
the "-ISA" from "AMD PCnet-ISA". */
|
2024-06-10 22:44:00 +02:00
|
|
|
else if ((fbus == NULL) || (*(fbus - 1) == 'o') || (*(fbus - 1) == '-') || (*(fbus - 2) == 'r'))
|
2022-09-18 17:11:43 -04:00
|
|
|
strcat(name, tname);
|
|
|
|
|
else {
|
|
|
|
|
strncat(name, tname, fbus - tname - 1);
|
|
|
|
|
strcat(name, fbus + strlen(sbus));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Free the temporary device name string. */
|
|
|
|
|
free(tname);
|
|
|
|
|
tname = NULL;
|
|
|
|
|
} else
|
2023-06-28 13:46:28 -04:00
|
|
|
strcat(name, dev->name);
|
2020-11-16 00:01:21 +01:00
|
|
|
} else
|
2023-06-28 13:46:28 -04:00
|
|
|
strcat(name, dev->name);
|
2020-11-16 00:01:21 +01:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
void
|
|
|
|
|
device_speed_changed(void)
|
2016-06-26 00:34:39 +02:00
|
|
|
{
|
2023-05-11 03:02:36 -04:00
|
|
|
for (uint16_t c = 0; c < DEVICE_MAX; c++) {
|
2022-09-18 17:11:43 -04:00
|
|
|
if (devices[c] != NULL) {
|
2023-10-14 06:45:45 +02:00
|
|
|
device_log("DEVICE: device '%s' speed changed\n", devices[c]->name);
|
|
|
|
|
|
2022-09-18 17:11:43 -04:00
|
|
|
if (devices[c]->speed_changed != NULL)
|
|
|
|
|
devices[c]->speed_changed(device_priv[c]);
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sound_speed_changed();
|
2016-06-26 00:34:39 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
void
|
|
|
|
|
device_force_redraw(void)
|
2016-06-26 00:34:39 +02:00
|
|
|
{
|
2023-05-11 03:02:36 -04:00
|
|
|
for (uint16_t c = 0; c < DEVICE_MAX; c++) {
|
2022-09-18 17:11:43 -04:00
|
|
|
if (devices[c] != NULL) {
|
|
|
|
|
if (devices[c]->force_redraw != NULL)
|
|
|
|
|
devices[c]->force_redraw(device_priv[c]);
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
2016-06-26 00:34:39 +02:00
|
|
|
}
|
|
|
|
|
|
2024-05-25 02:00:19 +02:00
|
|
|
int
|
2023-02-14 20:37:58 -05:00
|
|
|
device_get_instance(void)
|
|
|
|
|
{
|
|
|
|
|
return device_current.instance;
|
|
|
|
|
}
|
|
|
|
|
|
2018-09-06 14:38:43 +02:00
|
|
|
const char *
|
2025-01-06 23:28:08 -05:00
|
|
|
device_get_config_string(const char *str)
|
2016-06-26 00:34:39 +02:00
|
|
|
{
|
2025-02-12 05:18:12 +01:00
|
|
|
const char *ret = "";
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-02-12 05:18:12 +01:00
|
|
|
if (device_current.dev != NULL) {
|
|
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-02-12 05:18:12 +01:00
|
|
|
while ((cfg != NULL) && (cfg->type != CONFIG_END)) {
|
|
|
|
|
if (!strcmp(str, cfg->name)) {
|
|
|
|
|
const char *s = (config_get_string((char *) device_current.name,
|
|
|
|
|
(char *) str, (char *) cfg->default_string));
|
|
|
|
|
ret = (s == NULL) ? "" : s;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
cfg++;
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2025-02-12 05:18:12 +01:00
|
|
|
return ret;
|
2016-06-26 00:34:39 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
int
|
2025-01-06 23:28:08 -05:00
|
|
|
device_get_config_int(const char *str)
|
2017-05-17 21:56:31 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name))
|
|
|
|
|
return (config_get_int((char *) device_current.name, (char *) str, cfg->default_int));
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2023-05-11 03:02:36 -04:00
|
|
|
return 0;
|
2017-05-17 21:56:31 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
int
|
2025-01-06 23:28:08 -05:00
|
|
|
device_get_config_int_ex(const char *str, int def)
|
2017-05-27 03:53:32 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-08-25 02:21:26 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name))
|
|
|
|
|
return (config_get_int((char *) device_current.name, (char *) str, def));
|
2017-05-27 03:53:32 +02:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2023-05-11 03:02:36 -04:00
|
|
|
return def;
|
2017-05-27 03:53:32 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
int
|
2025-01-06 23:28:08 -05:00
|
|
|
device_get_config_hex16(const char *str)
|
2017-05-27 03:53:32 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name))
|
|
|
|
|
return (config_get_hex16((char *) device_current.name, (char *) str, cfg->default_int));
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2023-05-11 03:02:36 -04:00
|
|
|
return 0;
|
2017-05-27 03:53:32 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
int
|
2025-01-06 23:28:08 -05:00
|
|
|
device_get_config_hex20(const char *str)
|
2017-05-27 03:53:32 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name))
|
|
|
|
|
return (config_get_hex20((char *) device_current.name, (char *) str, cfg->default_int));
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2023-05-11 03:02:36 -04:00
|
|
|
return 0;
|
2017-05-27 03:53:32 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
int
|
2025-01-06 23:28:08 -05:00
|
|
|
device_get_config_mac(const char *str, int def)
|
2017-05-17 21:56:31 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name))
|
|
|
|
|
return (config_get_mac((char *) device_current.name, (char *) str, def));
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2023-05-11 03:02:36 -04:00
|
|
|
return def;
|
2017-05-17 21:56:31 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
void
|
2025-01-06 23:28:08 -05:00
|
|
|
device_set_config_int(const char *str, int val)
|
2017-05-27 03:53:32 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name)) {
|
|
|
|
|
config_set_int((char *) device_current.name, (char *) str, val);
|
2022-09-18 17:11:43 -04:00
|
|
|
break;
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
2017-05-27 03:53:32 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
void
|
2025-01-06 23:28:08 -05:00
|
|
|
device_set_config_hex16(const char *str, int val)
|
2017-05-27 03:53:32 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name)) {
|
|
|
|
|
config_set_hex16((char *) device_current.name, (char *) str, val);
|
2022-09-18 17:11:43 -04:00
|
|
|
break;
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
2017-05-27 03:53:32 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
void
|
2025-01-06 23:28:08 -05:00
|
|
|
device_set_config_hex20(const char *str, int val)
|
2017-05-27 03:53:32 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name)) {
|
|
|
|
|
config_set_hex20((char *) device_current.name, (char *) str, val);
|
2022-09-18 17:11:43 -04:00
|
|
|
break;
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
2017-05-27 03:53:32 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
void
|
2025-01-06 23:28:08 -05:00
|
|
|
device_set_config_mac(const char *str, int val)
|
2016-06-26 00:34:39 +02:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_config_t *cfg = device_current.dev->config;
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name)) {
|
|
|
|
|
config_set_mac((char *) device_current.name, (char *) str, val);
|
2022-09-18 17:11:43 -04:00
|
|
|
break;
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
2016-06-26 00:34:39 +02:00
|
|
|
}
|
2016-12-23 03:16:24 +01:00
|
|
|
|
2017-10-10 00:14:15 +02:00
|
|
|
int
|
2025-01-06 23:28:08 -05:00
|
|
|
device_is_valid(const device_t *device, int mch)
|
2017-10-10 00:14:15 +02:00
|
|
|
{
|
2025-02-14 07:10:55 +01:00
|
|
|
int ret = 1;
|
2017-10-10 00:14:15 +02:00
|
|
|
|
2025-02-14 08:57:30 +01:00
|
|
|
if ((device != NULL) && ((device->flags & DEVICE_BUS) != 0))
|
2025-02-14 07:10:55 +01:00
|
|
|
ret = machine_has_bus(mch, device->flags & DEVICE_BUS);
|
2023-08-15 01:27:16 +02:00
|
|
|
|
2025-02-14 07:10:55 +01:00
|
|
|
return ret;
|
2017-10-10 00:14:15 +02:00
|
|
|
}
|
|
|
|
|
|
2017-10-07 00:46:54 -04:00
|
|
|
int
|
2025-01-06 23:28:08 -05:00
|
|
|
machine_get_config_int(char *str)
|
2016-12-23 03:16:24 +01:00
|
|
|
{
|
2025-01-06 23:28:08 -05:00
|
|
|
const device_t *dev = machine_get_device(machine);
|
|
|
|
|
const device_config_t *cfg;
|
2016-12-23 03:16:24 +01:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
if (dev == NULL)
|
2023-05-11 03:02:36 -04:00
|
|
|
return 0;
|
2016-12-23 03:16:24 +01:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg = dev->config;
|
|
|
|
|
while (cfg && cfg->type != CONFIG_END) {
|
|
|
|
|
if (!strcmp(str, cfg->name))
|
|
|
|
|
return (config_get_int((char *) dev->name, str, cfg->default_int));
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-01-06 23:28:08 -05:00
|
|
|
cfg++;
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2023-05-11 03:02:36 -04:00
|
|
|
return 0;
|
2016-12-23 03:16:24 +01:00
|
|
|
}
|
|
|
|
|
|
2025-02-12 05:18:12 +01:00
|
|
|
const char *
|
2025-01-06 23:28:08 -05:00
|
|
|
machine_get_config_string(char *str)
|
2016-12-23 03:16:24 +01:00
|
|
|
{
|
2025-02-12 05:18:12 +01:00
|
|
|
const device_t *dev = machine_get_device(machine);
|
|
|
|
|
const char *ret = "";
|
2016-12-23 03:16:24 +01:00
|
|
|
|
2025-02-12 05:18:12 +01:00
|
|
|
if (dev != NULL) {
|
|
|
|
|
const device_config_t *cfg;
|
|
|
|
|
|
|
|
|
|
cfg = dev->config;
|
|
|
|
|
while ((cfg != NULL) && (cfg->type != CONFIG_END)) {
|
|
|
|
|
if (!strcmp(str, cfg->name)) {
|
|
|
|
|
const char *s = config_get_string((char *) dev->name, str,
|
|
|
|
|
(char *) cfg->default_string);
|
|
|
|
|
ret = (s == NULL) ? "" : s;
|
|
|
|
|
break;
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
|
2025-02-12 05:18:12 +01:00
|
|
|
cfg++;
|
|
|
|
|
}
|
2017-10-07 00:46:54 -04:00
|
|
|
}
|
|
|
|
|
|
2025-02-12 05:18:12 +01:00
|
|
|
return ret;
|
2016-12-23 03:16:24 +01:00
|
|
|
}
|
2024-01-10 01:26:50 +06:00
|
|
|
|
2025-02-03 20:00:58 -05:00
|
|
|
const device_t *
|
2024-01-10 01:26:50 +06:00
|
|
|
device_context_get_device(void)
|
|
|
|
|
{
|
|
|
|
|
return device_current.dev;
|
|
|
|
|
}
|
2024-06-30 22:18:15 -04:00
|
|
|
|
|
|
|
|
const device_t device_none = {
|
|
|
|
|
.name = "None",
|
|
|
|
|
.internal_name = "none",
|
|
|
|
|
.flags = 0,
|
|
|
|
|
.local = 0,
|
|
|
|
|
.init = NULL,
|
|
|
|
|
.close = NULL,
|
|
|
|
|
.reset = NULL,
|
2025-01-06 23:28:08 -05:00
|
|
|
.available = NULL,
|
2024-06-30 22:18:15 -04:00
|
|
|
.speed_changed = NULL,
|
|
|
|
|
.force_redraw = NULL,
|
|
|
|
|
.config = NULL
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const device_t device_internal = {
|
|
|
|
|
.name = "Internal",
|
|
|
|
|
.internal_name = "internal",
|
|
|
|
|
.flags = 0,
|
|
|
|
|
.local = 0,
|
|
|
|
|
.init = NULL,
|
|
|
|
|
.close = NULL,
|
|
|
|
|
.reset = NULL,
|
2025-01-06 23:28:08 -05:00
|
|
|
.available = NULL,
|
2024-06-30 22:18:15 -04:00
|
|
|
.speed_changed = NULL,
|
|
|
|
|
.force_redraw = NULL,
|
|
|
|
|
.config = NULL
|
|
|
|
|
};
|