Files
86Box/src/sio/sio_detect.c

117 lines
3.6 KiB
C
Raw Normal View History

/*
2023-01-06 15:36:05 -05: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.
*
2023-01-06 15:36:05 -05:00
* This file is part of the 86Box distribution.
*
2023-01-06 15:36:05 -05:00
* Super I/O chip detection code.
*
2020-03-25 00:46:02 +02:00
*
*
2023-01-06 15:36:05 -05:00
* Authors: Miran Grca, <mgrca8@gmail.com>
*
2023-01-06 15:36:05 -05:00
* Copyright 2016-2018 Miran Grca.
*/
#include <stdio.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#include <wchar.h>
#include <86box/86box.h>
#include <86box/device.h>
#include <86box/io.h>
#include <86box/timer.h>
#include <86box/fdd.h>
#include <86box/fdc.h>
#include <86box/sio.h>
2023-06-28 13:46:28 -04:00
#include <86box/plat_unused.h>
2023-06-28 13:46:28 -04:00
typedef struct sio_detect_t {
uint8_t regs[2];
} sio_detect_t;
static void
sio_detect_write(uint16_t port, uint8_t val, void *priv)
{
sio_detect_t *dev = (sio_detect_t *) priv;
pclog("sio_detect_write : port=%04x = %02X\n", port, val);
dev->regs[port & 1] = val;
return;
}
static uint8_t
sio_detect_read(uint16_t port, void *priv)
{
2023-08-21 20:24:33 -04:00
const sio_detect_t *dev = (sio_detect_t *) priv;
pclog("sio_detect_read : port=%04x = %02X\n", port, dev->regs[port & 1]);
return 0xff /*dev->regs[port & 1]*/;
}
static void
sio_detect_close(void *priv)
{
sio_detect_t *dev = (sio_detect_t *) priv;
free(dev);
}
static void *
2023-06-28 13:46:28 -04:00
sio_detect_init(UNUSED(const device_t *info))
{
2025-01-07 00:42:06 -05:00
sio_detect_t *dev = (sio_detect_t *) calloc(1, sizeof(sio_detect_t));
device_add(&fdc_at_smc_device);
io_sethandler(0x0022, 0x0006,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x002e, 0x0002,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x0044, 0x0004,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x004e, 0x0002,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x0108, 0x0002,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x015c, 0x0002,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x0250, 0x0003,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x026e, 0x0002,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x0279, 0x0001,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
2022-03-11 22:04:57 -05:00
io_sethandler(FDC_SECONDARY_ADDR, 0x0002,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x0398, 0x0002,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x03e3, 0x0001,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
2022-03-11 22:04:57 -05:00
io_sethandler(FDC_PRIMARY_ADDR, 0x0002,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
io_sethandler(0x0a79, 0x0001,
2022-09-18 17:17:00 -04:00
sio_detect_read, NULL, NULL, sio_detect_write, NULL, NULL, dev);
return dev;
}
const device_t sio_detect_device = {
2022-09-18 17:17:00 -04:00
.name = "Super I/O Detection Helper",
2022-03-13 09:57:57 -04:00
.internal_name = "sio_detect",
2022-09-18 17:17:00 -04:00
.flags = 0,
.local = 0,
.init = sio_detect_init,
.close = sio_detect_close,
.reset = NULL,
2025-01-07 01:12:42 -05:00
.available = NULL,
2022-03-13 09:57:57 -04:00
.speed_changed = NULL,
2022-09-18 17:17:00 -04:00
.force_redraw = NULL,
.config = NULL
};