mirror of
https://github.com/holub/mame
synced 2025-04-23 00:39:36 +03:00
bus/pci: add PDC20262 card [Guru]
This commit is contained in:
parent
0701ce97db
commit
9b2e02a839
@ -5506,6 +5506,8 @@ if (BUSES["PCI"]~=null) then
|
||||
MAME_DIR .. "src/devices/bus/pci/oti_spitfire.h",
|
||||
MAME_DIR .. "src/devices/bus/pci/opti82c861.cpp",
|
||||
MAME_DIR .. "src/devices/bus/pci/opti82c861.h",
|
||||
MAME_DIR .. "src/devices/bus/pci/pdc20262.cpp",
|
||||
MAME_DIR .. "src/devices/bus/pci/pdc20262.h",
|
||||
MAME_DIR .. "src/devices/bus/pci/promotion.cpp",
|
||||
MAME_DIR .. "src/devices/bus/pci/promotion.h",
|
||||
MAME_DIR .. "src/devices/bus/pci/riva128.cpp",
|
||||
|
@ -15,6 +15,7 @@
|
||||
#include "mga2064w.h"
|
||||
#include "opti82c861.h"
|
||||
#include "oti_spitfire.h"
|
||||
#include "pdc20262.h"
|
||||
#include "promotion.h"
|
||||
#include "riva128.h"
|
||||
#include "rivatnt.h"
|
||||
@ -112,6 +113,7 @@ void pci_cards(device_slot_interface &device)
|
||||
|
||||
// 0x01 - mass storage controllers
|
||||
device.option_add("aha2940au", AHA2940AU);
|
||||
device.option_add("pdc20262", PDC20262);
|
||||
|
||||
// 0x02 - network controllers
|
||||
device.option_add("rtl8029as", RTL8029AS_PCI);
|
||||
|
193
src/devices/bus/pci/pdc20262.cpp
Normal file
193
src/devices/bus/pci/pdc20262.cpp
Normal file
@ -0,0 +1,193 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders: Angelo Salese
|
||||
/**************************************************************************************************
|
||||
|
||||
Promise PDC20262
|
||||
|
||||
TODO:
|
||||
- how it sets compatible/native modes? Subvendor ID list suggests it can switch at will;
|
||||
- Marketed as RAID card, verify thru drivers;
|
||||
- ID and hookup Flash ROM type;
|
||||
|
||||
**************************************************************************************************/
|
||||
|
||||
#include "emu.h"
|
||||
#include "pdc20262.h"
|
||||
|
||||
#define LOG_WARN (1U << 1)
|
||||
|
||||
#define VERBOSE (LOG_GENERAL | LOG_WARN)
|
||||
//#define LOG_OUTPUT_FUNC osd_printf_info
|
||||
#include "logmacro.h"
|
||||
|
||||
#define LOGWARN(...) LOGMASKED(LOG_WARN, __VA_ARGS__)
|
||||
|
||||
|
||||
DEFINE_DEVICE_TYPE(PDC20262, pdc20262_device, "pdc20262", "Promise PDC20262 FastTrak66 EIDE controller")
|
||||
|
||||
|
||||
|
||||
pdc20262_device::pdc20262_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, uint32_t clock)
|
||||
: pci_card_device(mconfig, type, tag, owner, clock)
|
||||
// , m_ide1(*this, "ide1")
|
||||
// , m_ide2(*this, "ide2")
|
||||
, m_bios_rom(*this, "bios_rom")
|
||||
{
|
||||
// Subsystems:
|
||||
// 105a 4d30 Ultra Device on SuperTrak
|
||||
// 105a 4d33 Ultra66
|
||||
// 105a 4d39 FastTrak66
|
||||
// class code is trusted, bp 0xca09c
|
||||
set_ids(0x105a4d38, 0x00, 0x018000, 0x105a4d33);
|
||||
}
|
||||
|
||||
pdc20262_device::pdc20262_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock)
|
||||
: pdc20262_device(mconfig, PDC20262, tag, owner, clock)
|
||||
{
|
||||
}
|
||||
|
||||
ROM_START( pdc20262 )
|
||||
ROM_REGION32_LE( 0x8000, "bios_rom", ROMREGION_ERASEFF )
|
||||
ROM_SYSTEM_BIOS( 0, "promise4", "Promise Ultra66 BIOS v2.00 (Build 18)" )
|
||||
ROMX_LOAD( "ul200b18.bin", 0x0000, 0x4000, CRC(71e48d73) SHA1(84d8c72118a3e26181573412e2cbb859691672de), ROM_BIOS(0) )
|
||||
ROM_END
|
||||
|
||||
const tiny_rom_entry *pdc20262_device::device_rom_region() const
|
||||
{
|
||||
return ROM_NAME(pdc20262);
|
||||
}
|
||||
|
||||
|
||||
void pdc20262_device::device_add_mconfig(machine_config &config)
|
||||
{
|
||||
// BUS_MASTER_IDE_CONTROLLER(config, m_ide1).options(ata_devices, "hdd", nullptr, false);
|
||||
// m_ide1->irq_handler().set([this](int state) { m_irq_pri_callback(state); });
|
||||
// m_ide1->set_bus_master_space(get_pci_busmaster_space());
|
||||
|
||||
// BUS_MASTER_IDE_CONTROLLER(config, m_ide2).options(ata_devices, nullptr, nullptr, false);
|
||||
// m_ide2->irq_handler().set([this](int state) { m_irq_sec_callback(state); });
|
||||
// m_ide2->set_bus_master_space(get_pci_busmaster_space());
|
||||
}
|
||||
|
||||
// $1f0
|
||||
void pdc20262_device::ide1_command_map(address_map &map)
|
||||
{
|
||||
map(0, 7).rw(FUNC(pdc20262_device::ide1_read32_cs0_r), FUNC(pdc20262_device::ide1_write32_cs0_w));
|
||||
}
|
||||
|
||||
// $3f4
|
||||
void pdc20262_device::ide1_control_map(address_map &map)
|
||||
{
|
||||
map(2, 2).rw(FUNC(pdc20262_device::ide1_read_cs1_r), FUNC(pdc20262_device::ide1_write_cs1_w));
|
||||
}
|
||||
|
||||
// $170
|
||||
void pdc20262_device::ide2_command_map(address_map &map)
|
||||
{
|
||||
map(0, 7).rw(FUNC(pdc20262_device::ide2_read32_cs0_r), FUNC(pdc20262_device::ide2_write32_cs0_w));
|
||||
}
|
||||
|
||||
// $374
|
||||
void pdc20262_device::ide2_control_map(address_map &map)
|
||||
{
|
||||
map(2, 2).rw(FUNC(pdc20262_device::ide2_read_cs1_r), FUNC(pdc20262_device::ide2_write_cs1_w));
|
||||
}
|
||||
|
||||
void pdc20262_device::bus_master_ide_control_map(address_map &map)
|
||||
{
|
||||
// map(0x0, 0x7).rw(m_ide1, FUNC(bus_master_ide_controller_device::bmdma_r), FUNC(bus_master_ide_controller_device::bmdma_w));
|
||||
// map(0x8, 0xf).rw(m_ide2, FUNC(bus_master_ide_controller_device::bmdma_r), FUNC(bus_master_ide_controller_device::bmdma_w));
|
||||
}
|
||||
|
||||
void pdc20262_device::device_start()
|
||||
{
|
||||
pci_card_device::device_start();
|
||||
|
||||
add_map(8, M_IO, FUNC(pdc20262_device::ide1_command_map));
|
||||
add_map(4, M_IO, FUNC(pdc20262_device::ide1_control_map));
|
||||
add_map(8, M_IO, FUNC(pdc20262_device::ide2_command_map));
|
||||
add_map(4, M_IO, FUNC(pdc20262_device::ide2_control_map));
|
||||
// add_map(16, M_IO, FUNC(pdc20262_device::bus_master_ide_control_map));
|
||||
|
||||
add_rom((u8 *)m_bios_rom->base(), 0x4000);
|
||||
expansion_rom_base = 0xc8000;
|
||||
|
||||
// guess INTB#, more likely INTA#
|
||||
intr_pin = 2;
|
||||
}
|
||||
|
||||
void pdc20262_device::device_reset()
|
||||
{
|
||||
pci_card_device::device_reset();
|
||||
|
||||
command = 0x0000;
|
||||
command_mask = 5;
|
||||
status = 0x0000;
|
||||
|
||||
remap_cb();
|
||||
}
|
||||
|
||||
void pdc20262_device::config_map(address_map &map)
|
||||
{
|
||||
pci_card_device::config_map(map);
|
||||
}
|
||||
|
||||
/*
|
||||
* Start of legacy handling, to be moved out
|
||||
*/
|
||||
|
||||
uint32_t pdc20262_device::ide1_read32_cs0_r(offs_t offset, uint32_t mem_mask)
|
||||
{
|
||||
//if (!(command & 1))
|
||||
return 0xffffffff;
|
||||
//return m_ide1->read_cs0(offset, mem_mask);
|
||||
}
|
||||
|
||||
void pdc20262_device::ide1_write32_cs0_w(offs_t offset, uint32_t data, uint32_t mem_mask)
|
||||
{
|
||||
//if (!(command & 1))
|
||||
return;
|
||||
//m_ide1->write_cs0(offset, data, mem_mask);
|
||||
}
|
||||
|
||||
uint32_t pdc20262_device::ide2_read32_cs0_r(offs_t offset, uint32_t mem_mask)
|
||||
{
|
||||
//if (!(command & 1))
|
||||
return 0xffffffff;
|
||||
//return m_ide2->read_cs0(offset, mem_mask);
|
||||
}
|
||||
|
||||
void pdc20262_device::ide2_write32_cs0_w(offs_t offset, uint32_t data, uint32_t mem_mask)
|
||||
{
|
||||
//if (!(command & 1))
|
||||
return;
|
||||
//m_ide2->write_cs0(offset, data, mem_mask);
|
||||
}
|
||||
|
||||
uint8_t pdc20262_device::ide1_read_cs1_r()
|
||||
{
|
||||
//if (!(command & 1))
|
||||
return 0xff;
|
||||
//return m_ide1->read_cs1(1, 0xff0000) >> 16;
|
||||
}
|
||||
|
||||
void pdc20262_device::ide1_write_cs1_w(uint8_t data)
|
||||
{
|
||||
//if (!(command & 1))
|
||||
return;
|
||||
//m_ide1->write_cs1(1, data << 16, 0xff0000);
|
||||
}
|
||||
|
||||
uint8_t pdc20262_device::ide2_read_cs1_r()
|
||||
{
|
||||
//if (!(command & 1))
|
||||
return 0xff;
|
||||
//return m_ide2->read_cs1(1, 0xff0000) >> 16;
|
||||
}
|
||||
|
||||
void pdc20262_device::ide2_write_cs1_w(uint8_t data)
|
||||
{
|
||||
//if (!(command & 1))
|
||||
return;
|
||||
//m_ide2->write_cs1(1, data << 16, 0xff0000);
|
||||
}
|
59
src/devices/bus/pci/pdc20262.h
Normal file
59
src/devices/bus/pci/pdc20262.h
Normal file
@ -0,0 +1,59 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders: Angelo Salese
|
||||
|
||||
#ifndef MAME_BUS_PCI_PDC20262_H
|
||||
#define MAME_BUS_PCI_PDC20262_H
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "pci_slot.h"
|
||||
#include "machine/idectrl.h"
|
||||
|
||||
class pdc20262_device : public pci_card_device
|
||||
{
|
||||
public:
|
||||
pdc20262_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock);
|
||||
|
||||
static constexpr feature_type unemulated_features() { return feature::MEDIA; }
|
||||
|
||||
protected:
|
||||
pdc20262_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, uint32_t clock);
|
||||
|
||||
virtual void device_start() override;
|
||||
virtual void device_reset() override;
|
||||
virtual void device_add_mconfig(machine_config &config) override;
|
||||
|
||||
virtual const tiny_rom_entry *device_rom_region() const override;
|
||||
|
||||
// virtual void map_extra(uint64_t memory_window_start, uint64_t memory_window_end, uint64_t memory_offset, address_space *memory_space,
|
||||
// uint64_t io_window_start, uint64_t io_window_end, uint64_t io_offset, address_space *io_space) override;
|
||||
|
||||
virtual void config_map(address_map &map) override;
|
||||
|
||||
private:
|
||||
void ide1_command_map(address_map &map);
|
||||
void ide1_control_map(address_map &map);
|
||||
void ide2_command_map(address_map &map);
|
||||
void ide2_control_map(address_map &map);
|
||||
void bus_master_ide_control_map(address_map &map);
|
||||
|
||||
// required_device<bus_master_ide_controller_device> m_ide1;
|
||||
// required_device<bus_master_ide_controller_device> m_ide2;
|
||||
// devcb_write_line m_irq_pri_callback;
|
||||
// devcb_write_line m_irq_sec_callback;
|
||||
// required_address_space m_bus_master_space;
|
||||
required_memory_region m_bios_rom;
|
||||
|
||||
uint32_t ide1_read32_cs0_r(offs_t offset, uint32_t mem_mask = ~0);
|
||||
void ide1_write32_cs0_w(offs_t offset, uint32_t data, uint32_t mem_mask = ~0);
|
||||
uint32_t ide2_read32_cs0_r(offs_t offset, uint32_t mem_mask = ~0);
|
||||
void ide2_write32_cs0_w(offs_t offset, uint32_t data, uint32_t mem_mask = ~0);
|
||||
uint8_t ide1_read_cs1_r();
|
||||
void ide1_write_cs1_w(uint8_t data);
|
||||
uint8_t ide2_read_cs1_r();
|
||||
void ide2_write_cs1_w(uint8_t data);
|
||||
};
|
||||
|
||||
DECLARE_DEVICE_TYPE(PDC20262, pdc20262_device)
|
||||
|
||||
#endif // MAME_BUS_PCI_PDC20262_H
|
Loading…
Reference in New Issue
Block a user