Files
86Box/src/device/postcard.c

151 lines
3.3 KiB
C
Raw Normal View History

2020-03-23 17:03:28 -03: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.
*
* This file is part of the 86Box distribution.
*
* Implementation of a port 80h POST diagnostic card.
*
2020-03-25 00:46:02 +02:00
*
2020-03-23 17:03:28 -03:00
*
* Author: RichardG, <richardg867@gmail.com>
2020-06-07 16:03:15 -03:00
*
2020-03-23 17:03:28 -03:00
* Copyright 2020 RichardG.
*/
#include <stdarg.h>
#include <stdio.h>
#include <stdint.h>
#include <string.h>
#include <wchar.h>
#define HAVE_STDARG_H
#include <86box/86box.h>
#include <86box/io.h>
#include <86box/device.h>
#include <86box/machine.h>
#include <86box/plat.h>
#include <86box/ui.h>
#include <86box/postcard.h>
#include "cpu.h"
2020-03-23 17:03:28 -03:00
static uint16_t postcard_port;
static uint8_t postcard_written;
static uint8_t postcard_code, postcard_prev_code;
#define UISTR_LEN 13
static char postcard_str[UISTR_LEN]; /* UI output string */
extern void ui_sb_bugui(char *__str);
#ifdef ENABLE_POSTCARD_LOG
int postcard_do_log = ENABLE_POSTCARD_LOG;
static void
postcard_log(const char *fmt, ...)
{
va_list ap;
if (postcard_do_log) {
va_start(ap, fmt);
pclog_ex(fmt, ap);
va_end(ap);
}
}
#else
int postcard_do_log = 0;
#define postcard_log(fmt, ...)
#endif
static void
postcard_setui(void)
{
if (!postcard_written)
2020-10-30 20:54:47 -03:00
sprintf(postcard_str, "POST: -- --");
2020-03-23 17:03:28 -03:00
else if (postcard_written == 1)
2020-10-30 20:54:47 -03:00
sprintf(postcard_str, "POST: %02X --", postcard_code);
2020-03-23 17:03:28 -03:00
else
2020-10-30 20:54:47 -03:00
sprintf(postcard_str, "POST: %02X %02X", postcard_code, postcard_prev_code);
2020-03-23 17:03:28 -03:00
ui_sb_bugui(postcard_str);
if (postcard_do_log) {
2020-10-30 20:54:47 -03:00
/* log same string sent to the UI */
2020-07-14 22:24:22 -03:00
postcard_log("[%04X:%08X] %s\n", CS, cpu_state.pc, postcard_str);
2020-03-23 17:03:28 -03:00
}
}
static void
postcard_reset(void)
{
postcard_written = 0;
postcard_code = postcard_prev_code = 0x00;
postcard_setui();
}
static void
postcard_write(uint16_t port, uint8_t val, void *priv)
{
if (postcard_written && (val == postcard_code))
2020-10-30 20:54:47 -03:00
return;
2020-03-23 17:03:28 -03:00
postcard_prev_code = postcard_code;
postcard_code = val;
if (postcard_written < 2)
2020-10-30 20:54:47 -03:00
postcard_written++;
2020-03-23 17:03:28 -03:00
postcard_setui();
}
static void *
postcard_init(const device_t *info)
{
postcard_reset();
if (machine_has_bus(machine, MACHINE_BUS_MCA))
2020-10-30 20:54:47 -03:00
postcard_port = 0x680; /* MCA machines */
else if (strstr(machines[machine].name, " PS/2 ") || strstr(machine_getname_ex(machine), " PS/1 "))
2020-10-30 20:54:47 -03:00
postcard_port = 0x190; /* ISA PS/2 machines */
else if (strstr(machines[machine].name, " IBM XT "))
postcard_port = 0x60; /* IBM XT */
else if (strstr(machines[machine].name, " IBM PCjr"))
postcard_port = 0x10; /* IBM PCjr */
else if (strstr(machines[machine].name, " Compaq ") && !machine_has_bus(machine, MACHINE_BUS_PCI))
2020-10-30 20:54:47 -03:00
postcard_port = 0x84; /* ISA Compaq machines */
2020-03-23 17:03:28 -03:00
else
2020-10-30 20:54:47 -03:00
postcard_port = 0x80; /* AT and clone machines */
2020-03-23 17:03:28 -03:00
postcard_log("POST card initializing on port %04Xh\n", postcard_port);
if (postcard_port) io_sethandler(postcard_port, 1,
NULL, NULL, NULL, postcard_write, NULL, NULL, NULL);
return postcard_write;
}
static void
postcard_close(UNUSED(void *priv))
{
if (postcard_port) io_removehandler(postcard_port, 1,
NULL, NULL, NULL, postcard_write, NULL, NULL, NULL);
}
const device_t postcard_device = {
"POST Card",
DEVICE_ISA,
0,
postcard_init, postcard_close, NULL,
WARNING: CONFIGS MIGHT PARTIALLY BREAK WHERE DEVICE NAMES HAVE CHANGED. Changes to device_t struct to accomodate the upcoming PCI IRQ arbitration rewrite; Added device.c/h API to obtain name from the device_t struct; Significant changes to win/win_settings.c to clean up the code a bit and fix bugs; Ported all the CPU and AudioPCI commits from PCem; Added an API call to allow ACPI soft power off to gracefully stop the emulator; Removed the Siemens PCD-2L from the Dev branch because it now works; Removed the Socket 5 HP Vectra from the Dev branch because it now works; Fixed the Compaq Presario and the Micronics Spitfire; Give the IBM PC330 its own list of 486 CPU so it can have DX2's with CPUID 0x470; SMM fixes; Rewrote the SYSENTER, SYSEXIT, SYSCALL, and SYSRET instructions; Changed IDE reset period to match the specification, fixes #929; The keyboard input and output ports are now forced in front of the queue when read, fixes a number of bugs, including the AMI Apollo hanging on soft reset; Added the Intel AN430TX but Dev branched because it does not work; The network code no longer drops packets if the emulated network card has failed to receive them (eg. when the buffer is full); Changes to PCI card adding and renamed some PCI slot types, also added proper AGP bridge slot types; USB UHCI emulation is no longer a stub (still doesn't fully work, but at least Windows XP chk with Debug no longer ASSERT's on it); Fixed NVR on the the SMC FDC37C932QF and APM variants; A number of fixes to Intel 4x0 chipsets, including fixing every register of the 440LX and 440EX; Some ACPI changes.
2020-11-16 00:01:21 +01:00
{ NULL }, NULL, NULL,
2020-03-23 17:03:28 -03:00
NULL
};