mame/src/mess/machine/isa.c

634 lines
22 KiB
C

/***************************************************************************
ISA bus device
***************************************************************************/
#include "emu.h"
#include "emuopts.h"
#include "machine/isa.h"
//**************************************************************************
// GLOBAL VARIABLES
//**************************************************************************
const device_type ISA8_SLOT = &device_creator<isa8_slot_device>;
//**************************************************************************
// LIVE DEVICE
//**************************************************************************
//-------------------------------------------------
// isa8_slot_device - constructor
//-------------------------------------------------
isa8_slot_device::isa8_slot_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
device_t(mconfig, ISA8_SLOT, "ISA8_SLOT", tag, owner, clock, "isa8_slot", __FILE__),
device_slot_interface(mconfig, *this)
{
}
isa8_slot_device::isa8_slot_device(const machine_config &mconfig, device_type type, const char *name, const char *tag, device_t *owner, UINT32 clock, const char *shortname, const char *source) :
device_t(mconfig, type, name, tag, owner, clock, shortname, source),
device_slot_interface(mconfig, *this)
{
}
void isa8_slot_device::static_set_isa8_slot(device_t &device, device_t *owner, const char *isa_tag)
{
isa8_slot_device &isa_card = dynamic_cast<isa8_slot_device &>(device);
isa_card.m_owner = owner;
isa_card.m_isa_tag = isa_tag;
}
//-------------------------------------------------
// device_start - device-specific startup
//-------------------------------------------------
void isa8_slot_device::device_start()
{
device_isa8_card_interface *dev = dynamic_cast<device_isa8_card_interface *>(get_card_device());
const device_isa16_card_interface *intf;
if (get_card_device()->interface(intf))
fatalerror("Error ISA16 device in ISA8 slot\n");
if (dev) device_isa8_card_interface::static_set_isabus(*dev,m_owner->subdevice(m_isa_tag));
}
//**************************************************************************
// GLOBAL VARIABLES
//**************************************************************************
const device_type ISA16_SLOT = &device_creator<isa16_slot_device>;
//**************************************************************************
// LIVE DEVICE
//**************************************************************************
//-------------------------------------------------
// isa16_slot_device - constructor
//-------------------------------------------------
isa16_slot_device::isa16_slot_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
isa8_slot_device(mconfig, ISA16_SLOT, "ISA16_SLOT", tag, owner, clock, "isa16_slot", __FILE__)
{
}
void isa16_slot_device::static_set_isa16_slot(device_t &device, device_t *owner, const char *isa_tag)
{
isa16_slot_device &isa_card = dynamic_cast<isa16_slot_device &>(device);
isa_card.m_owner = owner;
isa_card.m_isa_tag = isa_tag;
}
//-------------------------------------------------
// device_start - device-specific startup
//-------------------------------------------------
void isa16_slot_device::device_start()
{
device_isa8_card_interface *dev = dynamic_cast<device_isa8_card_interface *>(get_card_device());
if (dev) device_isa8_card_interface::static_set_isabus(*dev,m_owner->subdevice(m_isa_tag));
}
//**************************************************************************
// GLOBAL VARIABLES
//**************************************************************************
const device_type ISA8 = &device_creator<isa8_device>;
void isa8_device::static_set_cputag(device_t &device, const char *tag)
{
isa8_device &isa = downcast<isa8_device &>(device);
isa.m_cputag = tag;
}
//-------------------------------------------------
// device_config_complete - perform any
// operations now that the configuration is
// complete
//-------------------------------------------------
void isa8_device::device_config_complete()
{
// inherit a copy of the static data
const isa8bus_interface *intf = reinterpret_cast<const isa8bus_interface *>(static_config());
if (intf != NULL)
{
*static_cast<isa8bus_interface *>(this) = *intf;
}
// or initialize to defaults if none provided
else
{
memset(&m_out_irq2_cb, 0, sizeof(m_out_irq2_cb));
memset(&m_out_irq3_cb, 0, sizeof(m_out_irq3_cb));
memset(&m_out_irq4_cb, 0, sizeof(m_out_irq4_cb));
memset(&m_out_irq5_cb, 0, sizeof(m_out_irq5_cb));
memset(&m_out_irq6_cb, 0, sizeof(m_out_irq6_cb));
memset(&m_out_irq7_cb, 0, sizeof(m_out_irq7_cb));
memset(&m_out_drq1_cb, 0, sizeof(m_out_drq1_cb));
memset(&m_out_drq2_cb, 0, sizeof(m_out_drq2_cb));
memset(&m_out_drq3_cb, 0, sizeof(m_out_drq3_cb));
}
m_maincpu = subdevice<cpu_device>(m_cputag);
}
//**************************************************************************
// LIVE DEVICE
//**************************************************************************
//-------------------------------------------------
// isa8_device - constructor
//-------------------------------------------------
isa8_device::isa8_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
device_t(mconfig, ISA8, "ISA8", tag, owner, clock, "isa8", __FILE__),
m_write_iochck(*this)
{
for(int i=0;i<8;i++)
{
m_dma_device[i] = NULL;
m_dma_eop[i] = false;
}
m_nmi_enabled = false;
}
isa8_device::isa8_device(const machine_config &mconfig, device_type type, const char *name, const char *tag, device_t *owner, UINT32 clock, const char *shortname, const char *source) :
device_t(mconfig, type, name, tag, owner, clock, shortname, source),
m_write_iochck(*this)
{
for(int i=0;i<8;i++)
{
m_dma_device[i] = NULL;
m_dma_eop[i] = false;
}
m_nmi_enabled = false;
}
void isa8_device::set_dma_channel(UINT8 channel, device_isa8_card_interface *dev, bool do_eop)
{
m_dma_device[channel] = dev;
m_dma_eop[channel] = do_eop;
}
//-------------------------------------------------
// device_start - device-specific startup
//-------------------------------------------------
void isa8_device::device_start()
{
// resolve callbacks
m_write_iochck.resolve_safe();
m_out_irq2_func.resolve(m_out_irq2_cb, *this);
m_out_irq3_func.resolve(m_out_irq3_cb, *this);
m_out_irq4_func.resolve(m_out_irq4_cb, *this);
m_out_irq5_func.resolve(m_out_irq5_cb, *this);
m_out_irq6_func.resolve(m_out_irq6_cb, *this);
m_out_irq7_func.resolve(m_out_irq7_cb, *this);
m_out_drq1_func.resolve(m_out_drq1_cb, *this);
m_out_drq2_func.resolve(m_out_drq2_cb, *this);
m_out_drq3_func.resolve(m_out_drq3_cb, *this);
}
//-------------------------------------------------
// device_reset - device-specific reset
//-------------------------------------------------
void isa8_device::device_reset()
{
}
void isa8_device::install_space(address_spacenum spacenum, offs_t start, offs_t end, offs_t mask, offs_t mirror, read8_space_func rhandler, const char* rhandler_name, write8_space_func whandler, const char *whandler_name)
{
int buswidth = m_maincpu->space_config(spacenum)->m_databus_width;
address_space &space = m_maincpu->space(spacenum);
switch(buswidth)
{
case 8:
space.install_legacy_readwrite_handler(start, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0);
break;
case 16:
space.install_legacy_readwrite_handler(start, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0xffff);
break;
case 32:
if ((start % 4) == 0) {
if ((end-start)==1) {
space.install_legacy_readwrite_handler(start, end+2, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0x0000ffff);
} else {
space.install_legacy_readwrite_handler(start, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0xffffffff);
}
} else {
// we handle just misalligned by 2
space.install_legacy_readwrite_handler(start-2, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0xffff0000);
}
break;
default:
fatalerror("ISA8: Bus width %d not supported\n", buswidth);
break;
}
}
void isa8_device::install_space(address_spacenum spacenum, offs_t start, offs_t end, offs_t mask, offs_t mirror, read8_delegate rhandler, write8_delegate whandler)
{
int buswidth = m_maincpu->space_config(spacenum)->m_databus_width;
address_space &space = m_maincpu->space(spacenum);
switch(buswidth)
{
case 8:
space.install_readwrite_handler(start, end, mask, mirror, rhandler, whandler, 0);
break;
case 16:
space.install_readwrite_handler(start, end, mask, mirror, rhandler, whandler, 0xffff);
break;
case 32:
if ((start % 4) == 0) {
if ((end-start)==1) {
space.install_readwrite_handler(start, end+2, mask, mirror, rhandler, whandler, 0x0000ffff);
} else {
space.install_readwrite_handler(start, end, mask, mirror, rhandler, whandler, 0xffffffff);
}
} else {
// we handle just misalligned by 2
space.install_readwrite_handler(start-2, end, mask, mirror, rhandler, whandler, 0xffff0000);
}
break;
default:
fatalerror("ISA8: Bus width %d not supported\n", buswidth);
break;
}
}
void isa8_device::install_space(address_spacenum spacenum, device_t *dev, offs_t start, offs_t end, offs_t mask, offs_t mirror, read8_device_func rhandler, const char* rhandler_name, write8_device_func whandler, const char *whandler_name)
{
int buswidth = m_maincpu->space_config(spacenum)->m_databus_width;
address_space &space = m_maincpu->space(spacenum);
switch(buswidth)
{
case 8:
space.install_legacy_readwrite_handler(*dev, start, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0);
break;
case 16:
space.install_legacy_readwrite_handler(*dev, start, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0xffff);
break;
case 32:
if ((start % 4) == 0) {
if ((end-start)==1) {
space.install_legacy_readwrite_handler(*dev, start, end+2, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0x0000ffff);
} else {
space.install_legacy_readwrite_handler(*dev, start, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0xffffffff);
}
} else {
// we handle just misalligned by 2
space.install_legacy_readwrite_handler(*dev, start-2, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name,0xffff0000);
}
break;
default:
fatalerror("ISA8: Bus width %d not supported\n", buswidth);
break;
}
}
void isa8_device::install_memory(offs_t start, offs_t end, offs_t mask, offs_t mirror, read8_delegate rhandler, write8_delegate whandler)
{
install_space(AS_PROGRAM, start, end, mask, mirror, rhandler, whandler);
}
void isa8_device::install_device(device_t *dev, offs_t start, offs_t end, offs_t mask, offs_t mirror, read8_device_func rhandler, const char* rhandler_name, write8_device_func whandler, const char *whandler_name)
{
install_space(AS_IO, dev, start, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name);
}
void isa8_device::install_device(offs_t start, offs_t end, offs_t mask, offs_t mirror, read8_space_func rhandler, const char* rhandler_name, write8_space_func whandler, const char *whandler_name)
{
install_space(AS_IO, start, end, mask, mirror, rhandler, rhandler_name, whandler, whandler_name);
}
void isa8_device::install_device(offs_t start, offs_t end, offs_t mask, offs_t mirror, read8_delegate rhandler, write8_delegate whandler)
{
install_space(AS_IO, start, end, mask, mirror, rhandler, whandler);
}
void isa8_device::install_bank(offs_t start, offs_t end, offs_t mask, offs_t mirror, const char *tag, UINT8 *data)
{
address_space &space = m_maincpu->space(AS_PROGRAM);
space.install_readwrite_bank(start, end, mask, mirror, tag );
machine().root_device().membank(tag)->set_base(data);
}
void isa8_device::unmap_bank(offs_t start, offs_t end, offs_t mask, offs_t mirror)
{
address_space &space = m_maincpu->space(AS_PROGRAM);
space.unmap_readwrite(start, end, mask, mirror);
}
void isa8_device::install_rom(device_t *dev, offs_t start, offs_t end, offs_t mask, offs_t mirror, const char *tag, const char *region)
{
astring tempstring;
if (machine().root_device().memregion("isa")) {
UINT8 *src = dev->memregion(region)->base();
UINT8 *dest = machine().root_device().memregion("isa")->base() + start - 0xc0000;
memcpy(dest,src, end - start + 1);
} else {
address_space &space = m_maincpu->space(AS_PROGRAM);
space.install_read_bank(start, end, mask, mirror, tag);
space.unmap_write(start, end, mask, mirror);
machine().root_device().membank(tag)->set_base(machine().root_device().memregion(dev->subtag(tempstring, region))->base());
}
}
void isa8_device::unmap_rom(offs_t start, offs_t end, offs_t mask, offs_t mirror)
{
address_space &space = m_maincpu->space(AS_PROGRAM);
space.unmap_read(start, end, mask, mirror);
}
bool isa8_device::is_option_rom_space_available(offs_t start, int size)
{
m_maincpu = machine().device<cpu_device>(m_cputag);
address_space &space = m_maincpu->space(AS_PROGRAM);
for(int i = 0; i < size; i += 4096) // 4KB granularity should be enough
if(space.get_read_ptr(start + i)) return false;
return true;
}
// interrupt request from isa card
WRITE_LINE_MEMBER( isa8_device::irq2_w ) { m_out_irq2_func(state); }
WRITE_LINE_MEMBER( isa8_device::irq3_w ) { m_out_irq3_func(state); }
WRITE_LINE_MEMBER( isa8_device::irq4_w ) { m_out_irq4_func(state); }
WRITE_LINE_MEMBER( isa8_device::irq5_w ) { m_out_irq5_func(state); }
WRITE_LINE_MEMBER( isa8_device::irq6_w ) { m_out_irq6_func(state); }
WRITE_LINE_MEMBER( isa8_device::irq7_w ) { m_out_irq7_func(state); }
// dma request from isa card
WRITE_LINE_MEMBER( isa8_device::drq1_w ) { m_out_drq1_func(state); }
WRITE_LINE_MEMBER( isa8_device::drq2_w ) { m_out_drq2_func(state); }
WRITE_LINE_MEMBER( isa8_device::drq3_w ) { m_out_drq3_func(state); }
UINT8 isa8_device::dack_r(int line)
{
if (m_dma_device[line])
return m_dma_device[line]->dack_r(line);
return 0xff;
}
void isa8_device::dack_w(int line,UINT8 data)
{
if (m_dma_device[line])
return m_dma_device[line]->dack_w(line,data);
}
void isa8_device::eop_w(int channel, int state)
{
if (m_dma_eop[channel] && m_dma_device[channel])
m_dma_device[channel]->eop_w(state);
}
void isa8_device::nmi()
{
if (m_write_iochck.isnull())
{
if (m_nmi_enabled)
{
m_maincpu->set_input_line(INPUT_LINE_NMI, PULSE_LINE );
}
}
else
{
m_write_iochck(0);
m_write_iochck(1);
}
}
//**************************************************************************
// DEVICE CONFIG ISA8 CARD INTERFACE
//**************************************************************************
//**************************************************************************
// DEVICE ISA8 CARD INTERFACE
//**************************************************************************
//-------------------------------------------------
// device_isa8_card_interface - constructor
//-------------------------------------------------
device_isa8_card_interface::device_isa8_card_interface(const machine_config &mconfig, device_t &device)
: device_slot_card_interface(mconfig, device),
m_isa(NULL)
{
}
//-------------------------------------------------
// ~device_isa8_card_interface - destructor
//-------------------------------------------------
device_isa8_card_interface::~device_isa8_card_interface()
{
}
UINT8 device_isa8_card_interface::dack_r(int line)
{
return 0;
}
void device_isa8_card_interface::dack_w(int line,UINT8 data)
{
}
void device_isa8_card_interface::eop_w(int state)
{
}
void device_isa8_card_interface::static_set_isabus(device_t &device, device_t *isa_device)
{
device_isa8_card_interface &isa_card = dynamic_cast<device_isa8_card_interface &>(device);
isa_card.m_isa_dev = isa_device;
}
void device_isa8_card_interface::set_isa_device()
{
m_isa = dynamic_cast<isa8_device *>(m_isa_dev);
}
const device_type ISA16 = &device_creator<isa16_device>;
//-------------------------------------------------
// isa16_device - constructor
//-------------------------------------------------
isa16_device::isa16_device(const machine_config &mconfig, const char *tag, device_t *owner, UINT32 clock) :
isa8_device(mconfig, ISA16, "ISA16", tag, owner, clock, "isa16", __FILE__)
{
}
//-------------------------------------------------
// device_config_complete - perform any
// operations now that the configuration is
// complete
//-------------------------------------------------
void isa16_device::device_config_complete()
{
// inherit a copy of the static data
const isa16bus_interface *intf = reinterpret_cast<const isa16bus_interface *>(static_config());
if (intf != NULL)
{
*static_cast<isa16bus_interface *>(this) = *intf;
memcpy(&(isa8bus_interface::m_out_irq2_cb),&(isa16bus_interface::m_out_irq2_cb), sizeof(isa16bus_interface::m_out_irq2_cb));
memcpy(&(isa8bus_interface::m_out_irq3_cb),&(isa16bus_interface::m_out_irq3_cb), sizeof(isa16bus_interface::m_out_irq3_cb));
memcpy(&(isa8bus_interface::m_out_irq4_cb),&(isa16bus_interface::m_out_irq4_cb), sizeof(isa16bus_interface::m_out_irq4_cb));
memcpy(&(isa8bus_interface::m_out_irq5_cb),&(isa16bus_interface::m_out_irq5_cb), sizeof(isa16bus_interface::m_out_irq5_cb));
memcpy(&(isa8bus_interface::m_out_irq6_cb),&(isa16bus_interface::m_out_irq6_cb), sizeof(isa16bus_interface::m_out_irq6_cb));
memcpy(&(isa8bus_interface::m_out_irq7_cb),&(isa16bus_interface::m_out_irq7_cb), sizeof(isa16bus_interface::m_out_irq7_cb));
memcpy(&(isa8bus_interface::m_out_drq1_cb),&(isa16bus_interface::m_out_drq1_cb), sizeof(isa16bus_interface::m_out_drq1_cb));
memcpy(&(isa8bus_interface::m_out_drq2_cb),&(isa16bus_interface::m_out_drq2_cb), sizeof(isa16bus_interface::m_out_drq2_cb));
memcpy(&(isa8bus_interface::m_out_drq3_cb),&(isa16bus_interface::m_out_drq3_cb), sizeof(isa16bus_interface::m_out_drq3_cb));
}
// or initialize to defaults if none provided
else
{
memset(&(isa8bus_interface::m_out_irq2_cb), 0, sizeof(isa8bus_interface::m_out_irq2_cb));
memset(&(isa8bus_interface::m_out_irq3_cb), 0, sizeof(isa8bus_interface::m_out_irq3_cb));
memset(&(isa8bus_interface::m_out_irq4_cb), 0, sizeof(isa8bus_interface::m_out_irq4_cb));
memset(&(isa8bus_interface::m_out_irq5_cb), 0, sizeof(isa8bus_interface::m_out_irq5_cb));
memset(&(isa8bus_interface::m_out_irq6_cb), 0, sizeof(isa8bus_interface::m_out_irq6_cb));
memset(&(isa8bus_interface::m_out_irq7_cb), 0, sizeof(isa8bus_interface::m_out_irq7_cb));
memset(&m_out_irq10_cb, 0, sizeof(m_out_irq10_cb));
memset(&m_out_irq11_cb, 0, sizeof(m_out_irq11_cb));
memset(&m_out_irq12_cb, 0, sizeof(m_out_irq12_cb));
memset(&m_out_irq14_cb, 0, sizeof(m_out_irq14_cb));
memset(&m_out_irq15_cb, 0, sizeof(m_out_irq15_cb));
memset(&m_out_drq0_cb, 0, sizeof(m_out_drq0_cb));
memset(&(isa8bus_interface::m_out_drq1_cb), 0, sizeof(isa8bus_interface::m_out_drq1_cb));
memset(&(isa8bus_interface::m_out_drq2_cb), 0, sizeof(isa8bus_interface::m_out_drq2_cb));
memset(&(isa8bus_interface::m_out_drq3_cb), 0, sizeof(isa8bus_interface::m_out_drq3_cb));
memset(&m_out_drq5_cb, 0, sizeof(m_out_drq5_cb));
memset(&m_out_drq6_cb, 0, sizeof(m_out_drq6_cb));
memset(&m_out_drq7_cb, 0, sizeof(m_out_drq7_cb));
}
m_maincpu = mconfig().device<cpu_device>(m_cputag);
}
//-------------------------------------------------
// device_start - device-specific startup
//-------------------------------------------------
void isa16_device::device_start()
{
isa8_device::device_start();
// resolve callbacks
m_out_irq10_func.resolve(m_out_irq10_cb, *this);
m_out_irq11_func.resolve(m_out_irq11_cb, *this);
m_out_irq12_func.resolve(m_out_irq12_cb, *this);
m_out_irq14_func.resolve(m_out_irq14_cb, *this);
m_out_irq15_func.resolve(m_out_irq15_cb, *this);
m_out_drq0_func.resolve(m_out_drq0_cb, *this);
m_out_drq5_func.resolve(m_out_drq5_cb, *this);
m_out_drq6_func.resolve(m_out_drq6_cb, *this);
m_out_drq7_func.resolve(m_out_drq7_cb, *this);
}
void isa16_device::install16_device(offs_t start, offs_t end, offs_t mask, offs_t mirror, read16_delegate rhandler, write16_delegate whandler)
{
int buswidth = m_maincpu->space_config(AS_PROGRAM)->m_databus_width;
switch(buswidth)
{
case 16:
m_maincpu->space(AS_IO).install_readwrite_handler(start, end, mask, mirror, rhandler, whandler, 0);
break;
case 32:
m_maincpu->space(AS_IO).install_readwrite_handler(start, end, mask, mirror, rhandler, whandler, 0xffffffff);
if ((start % 4) == 0) {
if ((end-start)==1) {
m_maincpu->space(AS_IO).install_readwrite_handler(start, end+2, mask, mirror, rhandler, whandler, 0x0000ffff);
} else {
m_maincpu->space(AS_IO).install_readwrite_handler(start, end, mask, mirror, rhandler, whandler, 0xffffffff);
}
} else {
// we handle just misalligned by 2
m_maincpu->space(AS_IO).install_readwrite_handler(start-2, end, mask, mirror, rhandler, whandler, 0xffff0000);
}
break;
default:
fatalerror("ISA16: Bus width %d not supported\n", buswidth);
break;
}
}
// interrupt request from isa card
WRITE_LINE_MEMBER( isa16_device::irq10_w ) { m_out_irq10_func(state); }
WRITE_LINE_MEMBER( isa16_device::irq11_w ) { m_out_irq11_func(state); }
WRITE_LINE_MEMBER( isa16_device::irq12_w ) { m_out_irq12_func(state); }
WRITE_LINE_MEMBER( isa16_device::irq14_w ) { m_out_irq14_func(state); }
WRITE_LINE_MEMBER( isa16_device::irq15_w ) { m_out_irq15_func(state); }
// dma request from isa card
WRITE_LINE_MEMBER( isa16_device::drq0_w ) { m_out_drq0_func(state); }
WRITE_LINE_MEMBER( isa16_device::drq5_w ) { m_out_drq5_func(state); }
WRITE_LINE_MEMBER( isa16_device::drq6_w ) { m_out_drq6_func(state); }
WRITE_LINE_MEMBER( isa16_device::drq7_w ) { m_out_drq7_func(state); }
UINT16 isa16_device::dack16_r(int line)
{
if (m_dma_device[line])
return dynamic_cast<device_isa16_card_interface *>(m_dma_device[line])->dack16_r(line);
return 0xffff;
}
void isa16_device::dack16_w(int line,UINT16 data)
{
if (m_dma_device[line])
return dynamic_cast<device_isa16_card_interface *>(m_dma_device[line])->dack16_w(line,data);
}
//-------------------------------------------------
// device_isa16_card_interface - constructor
//-------------------------------------------------
device_isa16_card_interface::device_isa16_card_interface(const machine_config &mconfig, device_t &device)
: device_isa8_card_interface(mconfig,device)
{
}
//-------------------------------------------------
// ~device_isa16_card_interface - destructor
//-------------------------------------------------
device_isa16_card_interface::~device_isa16_card_interface()
{
}
void device_isa16_card_interface::set_isa_device()
{
m_isa = dynamic_cast<isa16_device *>(m_isa_dev);
}
UINT16 device_isa16_card_interface::dack16_r(int line)
{
return 0;
}
void device_isa16_card_interface::dack16_w(int line,UINT16 data)
{
}