Bring the AN430TX out of the Dev branch in form of the Packard Bell PB790.
This commit is contained in:
@@ -173,7 +173,6 @@ endif()
|
|||||||
# Option Description Def. Condition Otherwise
|
# Option Description Def. Condition Otherwise
|
||||||
# ------ ----------- ---- ------------ ---------
|
# ------ ----------- ---- ------------ ---------
|
||||||
cmake_dependent_option(AMD_K5 "AMD K5" ON "DEV_BRANCH" OFF)
|
cmake_dependent_option(AMD_K5 "AMD K5" ON "DEV_BRANCH" OFF)
|
||||||
cmake_dependent_option(AN430TX "Intel AN430TX" ON "DEV_BRANCH" OFF)
|
|
||||||
cmake_dependent_option(CDROM_MITSUMI "Mitsumi CDROM" ON "DEV_BRANCH" OFF)
|
cmake_dependent_option(CDROM_MITSUMI "Mitsumi CDROM" ON "DEV_BRANCH" OFF)
|
||||||
cmake_dependent_option(G100 "Matrox Productiva G100" ON "DEV_BRANCH" OFF)
|
cmake_dependent_option(G100 "Matrox Productiva G100" ON "DEV_BRANCH" OFF)
|
||||||
cmake_dependent_option(GUSMAX "Gravis UltraSound MAX" ON "DEV_BRANCH" OFF)
|
cmake_dependent_option(GUSMAX "Gravis UltraSound MAX" ON "DEV_BRANCH" OFF)
|
||||||
|
|||||||
@@ -1013,7 +1013,8 @@ i4x0_write(int func, int addr, uint8_t val, void *priv)
|
|||||||
case INTEL_430TX:
|
case INTEL_430TX:
|
||||||
if (!dev->smram_locked) {
|
if (!dev->smram_locked) {
|
||||||
i4x0_smram_handler_phase0(dev);
|
i4x0_smram_handler_phase0(dev);
|
||||||
regs[0x71] = (regs[0x71] & 0x20) | (val & 0xdf);
|
regs[0x71] = (regs[0x71] & 0x60) | (val & 0x9f);
|
||||||
|
regs[0x71] &= (val & 0x40);
|
||||||
i4x0_smram_handler_phase1(dev);
|
i4x0_smram_handler_phase1(dev);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -1041,10 +1042,12 @@ i4x0_write(int func, int addr, uint8_t val, void *priv)
|
|||||||
regs[0x72] = (val & 0x7f);
|
regs[0x72] = (val & 0x7f);
|
||||||
else
|
else
|
||||||
regs[0x72] = (regs[0x72] & 0x87) | (val & 0x78);
|
regs[0x72] = (regs[0x72] & 0x87) | (val & 0x78);
|
||||||
|
if (val & 0x08) {
|
||||||
dev->smram_locked = (val & 0x10);
|
dev->smram_locked = (val & 0x10);
|
||||||
if (dev->smram_locked)
|
if (dev->smram_locked)
|
||||||
regs[0x72] &= 0xbf;
|
regs[0x72] &= 0xbf;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (dev->smram_locked)
|
if (dev->smram_locked)
|
||||||
regs[0x72] = (regs[0x72] & 0xef) | (val & 0x10);
|
regs[0x72] = (regs[0x72] & 0xef) | (val & 0x10);
|
||||||
@@ -1577,6 +1580,8 @@ i4x0_reset(void *priv)
|
|||||||
dev->regs[0x68 + i] = 0x00;
|
dev->regs[0x68 + i] = 0x00;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dev->smram_locked = 0;
|
||||||
|
|
||||||
if (dev->type >= INTEL_430FX) {
|
if (dev->type >= INTEL_430FX) {
|
||||||
dev->regs[0x72] &= 0xef; /* Forcibly unlock the SMRAM register. */
|
dev->regs[0x72] &= 0xef; /* Forcibly unlock the SMRAM register. */
|
||||||
i4x0_write(0, 0x72, 0x02, priv);
|
i4x0_write(0, 0x72, 0x02, priv);
|
||||||
|
|||||||
@@ -57,14 +57,6 @@ add_library(mch OBJECT
|
|||||||
m_at_misc.c
|
m_at_misc.c
|
||||||
)
|
)
|
||||||
|
|
||||||
if(AN430TX)
|
|
||||||
target_compile_definitions(mch PRIVATE USE_AN430TX)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(DESKPRO386)
|
|
||||||
target_compile_definitions(mch PRIVATE USE_DESKPRO386)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(OLIVETTI)
|
if(OLIVETTI)
|
||||||
target_compile_definitions(mch PRIVATE USE_OLIVETTI)
|
target_compile_definitions(mch PRIVATE USE_OLIVETTI)
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
@@ -1007,27 +1007,17 @@ machine_at_optiplex_gn_init(const machine_t *model)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_AN430TX
|
|
||||||
int
|
int
|
||||||
machine_at_an430tx_init(const machine_t *model)
|
machine_at_an430tx_init(const machine_t *model)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
# if 1
|
ret = bios_load_linear_combined2("roms/machines/an430tx/ANP0911A.BIO",
|
||||||
ret = bios_load_linear_combined2("roms/machines/an430tx/P10-0095.BIO",
|
"roms/machines/an430tx/ANP0911A.BI1",
|
||||||
"roms/machines/an430tx/P10-0095.BI1",
|
"roms/machines/an430tx/ANP0911A.BI2",
|
||||||
"roms/machines/an430tx/P10-0095.BI2",
|
"roms/machines/an430tx/ANP0911A.BI3",
|
||||||
"roms/machines/an430tx/P10-0095.BI3",
|
"roms/machines/an430tx/ANP0911A.RCV",
|
||||||
"roms/machines/an430tx/P10-0095.RCV",
|
|
||||||
0x3a000, 160);
|
0x3a000, 160);
|
||||||
# else
|
|
||||||
ret = bios_load_linear_combined2("roms/machines/an430tx/P06-0062.BIO",
|
|
||||||
"roms/machines/an430tx/P06-0062.BI1",
|
|
||||||
"roms/machines/an430tx/P06-0062.BI2",
|
|
||||||
"roms/machines/an430tx/P06-0062.BI3",
|
|
||||||
"roms/machines/an430tx/P10-0095.RCV",
|
|
||||||
0x3a000, 160);
|
|
||||||
# endif
|
|
||||||
|
|
||||||
if (bios_only || !ret)
|
if (bios_only || !ret)
|
||||||
return ret;
|
return ret;
|
||||||
@@ -1036,21 +1026,25 @@ machine_at_an430tx_init(const machine_t *model)
|
|||||||
|
|
||||||
pci_init(PCI_CONFIG_TYPE_1);
|
pci_init(PCI_CONFIG_TYPE_1);
|
||||||
pci_register_slot(0x00, PCI_CARD_NORTHBRIDGE, 0, 0, 0, 0);
|
pci_register_slot(0x00, PCI_CARD_NORTHBRIDGE, 0, 0, 0, 0);
|
||||||
pci_register_slot(0x07, PCI_CARD_SOUTHBRIDGE, 1, 2, 3, 4); /* PIIX4 */
|
pci_register_slot(0x07, PCI_CARD_SOUTHBRIDGE, 0, 0, 0, 4); /* PIIX4 */
|
||||||
// pci_register_slot(0x08, PCI_CARD_VIDEO, 4, 0, 0, 0);
|
|
||||||
pci_register_slot(0x0D, PCI_CARD_NORMAL, 1, 2, 3, 4);
|
pci_register_slot(0x0D, PCI_CARD_NORMAL, 1, 2, 3, 4);
|
||||||
pci_register_slot(0x0E, PCI_CARD_NORMAL, 2, 3, 4, 1);
|
pci_register_slot(0x0E, PCI_CARD_NORMAL, 2, 3, 4, 1);
|
||||||
pci_register_slot(0x0F, PCI_CARD_NORMAL, 3, 4, 1, 2);
|
pci_register_slot(0x0F, PCI_CARD_NORMAL, 3, 4, 1, 2);
|
||||||
pci_register_slot(0x10, PCI_CARD_NORMAL, 4, 1, 2, 3);
|
pci_register_slot(0x10, PCI_CARD_NORMAL, 4, 1, 2, 3);
|
||||||
|
pci_register_slot(0x08, PCI_CARD_VIDEO, 4, 0, 0, 0);
|
||||||
device_add(&i430tx_device);
|
device_add(&i430tx_device);
|
||||||
device_add(&piix4_device);
|
device_add(&piix4_device);
|
||||||
|
#ifdef FOLLOW_THE_SPECIFICATION
|
||||||
device_add_params(&pc87307_device, (void *) (PCX730X_PHOENIX_42I | PCX7307_PC97307));
|
device_add_params(&pc87307_device, (void *) (PCX730X_PHOENIX_42I | PCX7307_PC97307));
|
||||||
|
#else
|
||||||
|
/* The technical specification says Phoenix, a real machnine HWINFO dump says AMI '5'. */
|
||||||
|
device_add_params(&pc87307_device, (void *) (PCX730X_AMI | PCX7307_PC97307));
|
||||||
|
#endif
|
||||||
device_add(&intel_flash_bxt_ami_device);
|
device_add(&intel_flash_bxt_ami_device);
|
||||||
spd_register(SPD_TYPE_SDRAM, 0x3, 128);
|
spd_register(SPD_TYPE_SDRAM, 0x3, 128);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
#endif /* USE_AN430TX */
|
|
||||||
|
|
||||||
int
|
int
|
||||||
machine_at_ym430tx_init(const machine_t *model)
|
machine_at_ym430tx_init(const machine_t *model)
|
||||||
|
|||||||
@@ -13275,49 +13275,6 @@ const machine_t machines[] = {
|
|||||||
.snd_device = &cs4236b_device,
|
.snd_device = &cs4236b_device,
|
||||||
.net_device = &pcnet_am79c973_onboard_device
|
.net_device = &pcnet_am79c973_onboard_device
|
||||||
},
|
},
|
||||||
#ifdef USE_AN430TX
|
|
||||||
/* This has the Phoenix MultiKey KBC firmware. */
|
|
||||||
{
|
|
||||||
.name = "[i430TX] Intel AN430TX (Anchorage)",
|
|
||||||
.internal_name = "an430tx",
|
|
||||||
.type = MACHINE_TYPE_SOCKET7,
|
|
||||||
.chipset = MACHINE_CHIPSET_INTEL_430TX,
|
|
||||||
.init = machine_at_an430tx_init,
|
|
||||||
.p1_handler = NULL,
|
|
||||||
.gpio_handler = NULL,
|
|
||||||
.available_flag = MACHINE_AVAILABLE,
|
|
||||||
.gpio_acpi_handler = NULL,
|
|
||||||
.cpu = {
|
|
||||||
.package = CPU_PKG_SOCKET5_7,
|
|
||||||
.block = CPU_BLOCK(CPU_K5, CPU_5K86, CPU_K6, CPU_K6_2, CPU_K6_2C, CPU_K6_3, CPU_K6_2P,
|
|
||||||
CPU_K6_3P, CPU_Cx6x86, CPU_Cx6x86MX, CPU_Cx6x86L),
|
|
||||||
.min_bus = 60000000,
|
|
||||||
.max_bus = 66666667,
|
|
||||||
.min_voltage = 2800,
|
|
||||||
.max_voltage = 3520,
|
|
||||||
.min_multi = 1.5,
|
|
||||||
.max_multi = 3.5
|
|
||||||
},
|
|
||||||
.bus_flags = MACHINE_PS2_PCI,
|
|
||||||
.flags = MACHINE_IDE_DUAL | MACHINE_APM | MACHINE_ACPI,
|
|
||||||
.ram = {
|
|
||||||
.min = 8192,
|
|
||||||
.max = 262144,
|
|
||||||
.step = 8192
|
|
||||||
},
|
|
||||||
.nvrmask = 255,
|
|
||||||
.kbc_device = NULL,
|
|
||||||
.kbc_p1 = 0xff,
|
|
||||||
.gpio = 0xffffffff,
|
|
||||||
.gpio_acpi = 0xffffffff,
|
|
||||||
.device = NULL,
|
|
||||||
.fdc_device = NULL,
|
|
||||||
.sio_device = NULL,
|
|
||||||
.vid_device = NULL,
|
|
||||||
.snd_device = NULL,
|
|
||||||
.net_device = NULL
|
|
||||||
},
|
|
||||||
#endif /* USE_AN430TX */
|
|
||||||
/* This has the AMIKey KBC firmware, which is an updated 'F' type. */
|
/* This has the AMIKey KBC firmware, which is an updated 'F' type. */
|
||||||
{
|
{
|
||||||
.name = "[i430TX] Intel YM430TX (Yamamoto)",
|
.name = "[i430TX] Intel YM430TX (Yamamoto)",
|
||||||
@@ -13359,9 +13316,13 @@ const machine_t machines[] = {
|
|||||||
.snd_device = NULL,
|
.snd_device = NULL,
|
||||||
.net_device = NULL
|
.net_device = NULL
|
||||||
},
|
},
|
||||||
/* PhoenixBIOS 4.0 Rel 6.0 for 430TX, has onboard Yamaha YMF701 which is not emulated yet. */
|
/*
|
||||||
/* Has a SM(S)C FDC37C935 Super I/O chip with on-chip KBC with Phoenix
|
PhoenixBIOS 4.0 Rel 6.0 for 430TX, has onboard Yamaha YMF701 which
|
||||||
MultiKey/42 (version 1.38) KBC firmware. */
|
is not emulated yet.
|
||||||
|
|
||||||
|
Has a SM(S)C FDC37C935 Super I/O chip with on-chip KBC with Phoenix
|
||||||
|
MultiKey/42 (version 1.38) KBC firmware.
|
||||||
|
*/
|
||||||
{
|
{
|
||||||
.name = "[i430TX] Micronics Thunderbolt",
|
.name = "[i430TX] Micronics Thunderbolt",
|
||||||
.internal_name = "thunderbolt",
|
.internal_name = "thunderbolt",
|
||||||
@@ -13383,7 +13344,8 @@ const machine_t machines[] = {
|
|||||||
.max_multi = 3.5
|
.max_multi = 3.5
|
||||||
},
|
},
|
||||||
.bus_flags = MACHINE_PS2_PCI | MACHINE_BUS_USB,
|
.bus_flags = MACHINE_PS2_PCI | MACHINE_BUS_USB,
|
||||||
.flags = MACHINE_IDE_DUAL | MACHINE_APM | MACHINE_ACPI | MACHINE_GAMEPORT | MACHINE_USB, /* Machine has internal sound: Yamaha YMF701-S */
|
/* Machine has internal sound: Yamaha YMF701-S */
|
||||||
|
.flags = MACHINE_IDE_DUAL | MACHINE_APM | MACHINE_ACPI | MACHINE_GAMEPORT | MACHINE_USB,
|
||||||
.ram = {
|
.ram = {
|
||||||
.min = 8192,
|
.min = 8192,
|
||||||
.max = 262144,
|
.max = 262144,
|
||||||
@@ -13442,6 +13404,47 @@ const machine_t machines[] = {
|
|||||||
.snd_device = NULL,
|
.snd_device = NULL,
|
||||||
.net_device = NULL
|
.net_device = NULL
|
||||||
},
|
},
|
||||||
|
/* This has the Phoenix MultiKey KBC firmware. */
|
||||||
|
{
|
||||||
|
.name = "[i430TX] Packard Bell PB790",
|
||||||
|
.internal_name = "an430tx",
|
||||||
|
.type = MACHINE_TYPE_SOCKET7,
|
||||||
|
.chipset = MACHINE_CHIPSET_INTEL_430TX,
|
||||||
|
.init = machine_at_an430tx_init,
|
||||||
|
.p1_handler = NULL,
|
||||||
|
.gpio_handler = NULL,
|
||||||
|
.available_flag = MACHINE_AVAILABLE,
|
||||||
|
.gpio_acpi_handler = NULL,
|
||||||
|
.cpu = {
|
||||||
|
.package = CPU_PKG_SOCKET5_7,
|
||||||
|
.block = CPU_BLOCK(CPU_K5, CPU_5K86, CPU_K6, CPU_K6_2, CPU_K6_2C, CPU_K6_3, CPU_K6_2P,
|
||||||
|
CPU_K6_3P, CPU_Cx6x86, CPU_Cx6x86MX, CPU_Cx6x86L),
|
||||||
|
.min_bus = 60000000,
|
||||||
|
.max_bus = 66666667,
|
||||||
|
.min_voltage = 2800,
|
||||||
|
.max_voltage = 3520,
|
||||||
|
.min_multi = 1.5,
|
||||||
|
.max_multi = 3.5
|
||||||
|
},
|
||||||
|
.bus_flags = MACHINE_PS2_PCI,
|
||||||
|
.flags = MACHINE_IDE_DUAL | MACHINE_APM | MACHINE_ACPI,
|
||||||
|
.ram = {
|
||||||
|
.min = 8192,
|
||||||
|
.max = 262144,
|
||||||
|
.step = 8192
|
||||||
|
},
|
||||||
|
.nvrmask = 255,
|
||||||
|
.kbc_device = NULL,
|
||||||
|
.kbc_p1 = 0xff,
|
||||||
|
.gpio = 0xffffffff,
|
||||||
|
.gpio_acpi = 0xffffffff,
|
||||||
|
.device = NULL,
|
||||||
|
.fdc_device = NULL,
|
||||||
|
.sio_device = NULL,
|
||||||
|
.vid_device = NULL,
|
||||||
|
.snd_device = NULL,
|
||||||
|
.net_device = NULL
|
||||||
|
},
|
||||||
/* The BIOS sends KBC command BB and expects it to output a byte, which is AMI KBC behavior.
|
/* The BIOS sends KBC command BB and expects it to output a byte, which is AMI KBC behavior.
|
||||||
A picture shows a VIA VT82C42N KBC though, so it could be a case of that KBC with AMI firmware. */
|
A picture shows a VIA VT82C42N KBC though, so it could be a case of that KBC with AMI firmware. */
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user