mirror of
https://github.com/holub/mame
synced 2025-04-20 23:42:22 +03:00
Apple II: added 13-sector version of Disk II controller [R. Belmont]
This commit is contained in:
parent
a1f49b25d6
commit
8fc27ad928
@ -21,7 +21,8 @@
|
||||
// GLOBAL VARIABLES
|
||||
//**************************************************************************
|
||||
|
||||
DEFINE_DEVICE_TYPE(A2BUS_DISKIING, a2bus_diskiing_device, "a2diskiing", "Apple Disk II NG controller")
|
||||
DEFINE_DEVICE_TYPE(A2BUS_DISKIING, a2bus_diskiing_device, "a2diskiing", "Apple Disk II NG controller (16-sector)")
|
||||
DEFINE_DEVICE_TYPE(A2BUS_DISKIING13, a2bus_diskiing13_device, "diskii13", "Apple Disk II NG controller (13-sector)")
|
||||
|
||||
#define WOZFDC_TAG "wozfdc"
|
||||
#define DISKII_ROM_REGION "diskii_rom"
|
||||
@ -35,35 +36,55 @@ ROM_START( diskiing )
|
||||
ROM_LOAD( "341-0027-a.p5", 0x0000, 0x0100, CRC(ce7144f6) SHA1(d4181c9f046aafc3fb326b381baac809d9e38d16) ) /* 341-0027-a: 16-sector disk drive (older version), PROM P5 */
|
||||
ROM_END
|
||||
|
||||
FLOPPY_FORMATS_MEMBER( a2bus_diskiing_device::floppy_formats )
|
||||
ROM_START( diskiing13 )
|
||||
ROM_REGION(0x100, DISKII_ROM_REGION, 0)
|
||||
ROM_LOAD( "341-0009.bin", 0x000000, 0x000100, CRC(d34eb2ff) SHA1(afd060e6f35faf3bb0146fa889fc787adf56330a) )
|
||||
ROM_END
|
||||
|
||||
FLOPPY_FORMATS_MEMBER( diskiing_device::floppy_formats )
|
||||
FLOPPY_A216S_FORMAT, FLOPPY_RWTS18_FORMAT, FLOPPY_EDD_FORMAT, FLOPPY_WOZ_FORMAT
|
||||
FLOPPY_FORMATS_END
|
||||
|
||||
FLOPPY_FORMATS_MEMBER( a2bus_diskiing13_device::floppy_formats )
|
||||
FLOPPY_EDD_FORMAT, FLOPPY_WOZ_FORMAT
|
||||
FLOPPY_FORMATS_END
|
||||
|
||||
//-------------------------------------------------
|
||||
// device_add_mconfig - add device configuration
|
||||
//-------------------------------------------------
|
||||
|
||||
MACHINE_CONFIG_START(a2bus_diskiing_device::device_add_mconfig)
|
||||
MACHINE_CONFIG_START(diskiing_device::device_add_mconfig)
|
||||
MCFG_DEVICE_ADD(WOZFDC_TAG, DISKII_FDC, 1021800*2)
|
||||
MCFG_FLOPPY_DRIVE_ADD("0", a2_floppies, "525", a2bus_diskiing_device::floppy_formats)
|
||||
MCFG_FLOPPY_DRIVE_ADD("1", a2_floppies, "525", a2bus_diskiing_device::floppy_formats)
|
||||
MCFG_FLOPPY_DRIVE_ADD("0", a2_floppies, "525", diskiing_device::floppy_formats)
|
||||
MCFG_FLOPPY_DRIVE_ADD("1", a2_floppies, "525", diskiing_device::floppy_formats)
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
MACHINE_CONFIG_START(a2bus_diskiing13_device::device_add_mconfig)
|
||||
MCFG_DEVICE_ADD(WOZFDC_TAG, DISKII_FDC, 1021800*2)
|
||||
MCFG_FLOPPY_DRIVE_ADD("0", a2_floppies, "525", a2bus_diskiing13_device::floppy_formats)
|
||||
MCFG_FLOPPY_DRIVE_ADD("1", a2_floppies, "525", a2bus_diskiing13_device::floppy_formats)
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
//-------------------------------------------------
|
||||
// rom_region - device-specific ROM region
|
||||
//-------------------------------------------------
|
||||
|
||||
const tiny_rom_entry *a2bus_diskiing_device::device_rom_region() const
|
||||
const tiny_rom_entry *diskiing_device::device_rom_region() const
|
||||
{
|
||||
return ROM_NAME( diskiing );
|
||||
}
|
||||
|
||||
const tiny_rom_entry *a2bus_diskiing13_device::device_rom_region() const
|
||||
{
|
||||
return ROM_NAME( diskiing13 );
|
||||
}
|
||||
|
||||
//**************************************************************************
|
||||
// LIVE DEVICE
|
||||
//**************************************************************************
|
||||
|
||||
a2bus_diskiing_device::a2bus_diskiing_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock) :
|
||||
device_t(mconfig, A2BUS_DISKIING, tag, owner, clock),
|
||||
diskiing_device::diskiing_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, uint32_t clock) :
|
||||
device_t(mconfig, type, tag, owner, clock),
|
||||
device_a2bus_card_interface(mconfig, *this),
|
||||
m_wozfdc(*this, WOZFDC_TAG),
|
||||
floppy0(*this, "0"),
|
||||
@ -72,16 +93,26 @@ a2bus_diskiing_device::a2bus_diskiing_device(const machine_config &mconfig, cons
|
||||
{
|
||||
}
|
||||
|
||||
a2bus_diskiing_device::a2bus_diskiing_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock) :
|
||||
diskiing_device(mconfig, A2BUS_DISKIING, tag, owner, clock)
|
||||
{
|
||||
}
|
||||
|
||||
a2bus_diskiing13_device::a2bus_diskiing13_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock) :
|
||||
diskiing_device(mconfig, A2BUS_DISKIING13, tag, owner, clock)
|
||||
{
|
||||
}
|
||||
|
||||
//-------------------------------------------------
|
||||
// device_start - device-specific startup
|
||||
//-------------------------------------------------
|
||||
|
||||
void a2bus_diskiing_device::device_start()
|
||||
void diskiing_device::device_start()
|
||||
{
|
||||
m_rom = device().machine().root_device().memregion(this->subtag(DISKII_ROM_REGION).c_str())->base();
|
||||
}
|
||||
|
||||
void a2bus_diskiing_device::device_reset()
|
||||
void diskiing_device::device_reset()
|
||||
{
|
||||
m_wozfdc->set_floppies(floppy0, floppy1);
|
||||
}
|
||||
@ -90,7 +121,7 @@ void a2bus_diskiing_device::device_reset()
|
||||
read_c0nx - called for reads from this card's c0nx space
|
||||
-------------------------------------------------*/
|
||||
|
||||
uint8_t a2bus_diskiing_device::read_c0nx(uint8_t offset)
|
||||
uint8_t diskiing_device::read_c0nx(uint8_t offset)
|
||||
{
|
||||
return m_wozfdc->read(offset);
|
||||
}
|
||||
@ -100,7 +131,7 @@ uint8_t a2bus_diskiing_device::read_c0nx(uint8_t offset)
|
||||
write_c0nx - called for writes to this card's c0nx space
|
||||
-------------------------------------------------*/
|
||||
|
||||
void a2bus_diskiing_device::write_c0nx(uint8_t offset, uint8_t data)
|
||||
void diskiing_device::write_c0nx(uint8_t offset, uint8_t data)
|
||||
{
|
||||
m_wozfdc->write(offset, data);
|
||||
}
|
||||
@ -109,7 +140,7 @@ void a2bus_diskiing_device::write_c0nx(uint8_t offset, uint8_t data)
|
||||
read_cnxx - called for reads from this card's cnxx space
|
||||
-------------------------------------------------*/
|
||||
|
||||
uint8_t a2bus_diskiing_device::read_cnxx(uint8_t offset)
|
||||
uint8_t diskiing_device::read_cnxx(uint8_t offset)
|
||||
{
|
||||
return m_rom[offset];
|
||||
}
|
||||
|
@ -23,13 +23,13 @@
|
||||
//**************************************************************************
|
||||
|
||||
|
||||
class a2bus_diskiing_device:
|
||||
class diskiing_device:
|
||||
public device_t,
|
||||
public device_a2bus_card_interface
|
||||
{
|
||||
public:
|
||||
// construction/destruction
|
||||
a2bus_diskiing_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock);
|
||||
diskiing_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, uint32_t clock);
|
||||
|
||||
protected:
|
||||
virtual void device_start() override;
|
||||
@ -52,7 +52,27 @@ private:
|
||||
DECLARE_FLOPPY_FORMATS( floppy_formats );
|
||||
};
|
||||
|
||||
class a2bus_diskiing_device: public diskiing_device
|
||||
{
|
||||
public:
|
||||
a2bus_diskiing_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock);
|
||||
};
|
||||
|
||||
class a2bus_diskiing13_device: public diskiing_device
|
||||
{
|
||||
public:
|
||||
a2bus_diskiing13_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock);
|
||||
|
||||
protected:
|
||||
virtual void device_add_mconfig(machine_config &config) override;
|
||||
virtual const tiny_rom_entry *device_rom_region() const override;
|
||||
|
||||
private:
|
||||
DECLARE_FLOPPY_FORMATS( floppy_formats );
|
||||
};
|
||||
|
||||
// device type definition
|
||||
DECLARE_DEVICE_TYPE(A2BUS_DISKIING, a2bus_diskiing_device)
|
||||
DECLARE_DEVICE_TYPE(A2BUS_DISKIING13, a2bus_diskiing13_device)
|
||||
|
||||
#endif // MAME_BUS_A2BUS_A2DISKIING_H
|
||||
|
@ -1327,6 +1327,7 @@ SLOT_INTERFACE_END
|
||||
static SLOT_INTERFACE_START(apple2_cards)
|
||||
SLOT_INTERFACE("diskii", A2BUS_DISKII) /* Disk II Controller Card */
|
||||
SLOT_INTERFACE("diskiing", A2BUS_DISKIING) /* Disk II Controller Card, cycle-accurate version */
|
||||
SLOT_INTERFACE("diskiing13", A2BUS_DISKIING13) /* Disk II Controller Card, cycle-accurate version */
|
||||
SLOT_INTERFACE("mockingboard", A2BUS_MOCKINGBOARD) /* Sweet Micro Systems Mockingboard */
|
||||
SLOT_INTERFACE("phasor", A2BUS_PHASOR) /* Applied Engineering Phasor */
|
||||
SLOT_INTERFACE("cffa2", A2BUS_CFFA2) /* CFFA2000 Compact Flash for Apple II (www.dreher.net), 65C02/65816 firmware */
|
||||
|
@ -3830,6 +3830,7 @@ INPUT_PORTS_END
|
||||
static SLOT_INTERFACE_START(apple2_cards)
|
||||
SLOT_INTERFACE("diskii", A2BUS_DISKII) /* Disk II Controller Card */
|
||||
SLOT_INTERFACE("diskiing", A2BUS_DISKIING) /* Disk II Controller Card, cycle-accurate version */
|
||||
SLOT_INTERFACE("diskiing13", A2BUS_DISKIING13) /* Disk II Controller Card, cycle-accurate version */
|
||||
SLOT_INTERFACE("mockingboard", A2BUS_MOCKINGBOARD) /* Sweet Micro Systems Mockingboard */
|
||||
SLOT_INTERFACE("phasor", A2BUS_PHASOR) /* Applied Engineering Phasor */
|
||||
SLOT_INTERFACE("cffa2", A2BUS_CFFA2) /* CFFA2000 Compact Flash for Apple II (www.dreher.net), 65C02/65816 firmware */
|
||||
|
Loading…
Reference in New Issue
Block a user