(MESS) indiana: preliminary hookup of ISA bus and peripherals and MFP. [R. Belmont]

nw: As noted, it puts lots of text in the VGA framebuffer which is never displayed.  Something off-spec with how the VGA is being accessed?
This commit is contained in:
R. Belmont 2014-01-21 02:53:23 +00:00
parent 418dca490b
commit 932a7cc8d2

View File

@ -2,9 +2,11 @@
Indiana University 68030 board
08/12/2009 Skeleton driver.
If 6001F7 is held at 40, then '>' will appear on screen.
08/12/2009 Skeleton driver.
01/20/2014 Added ISA bus and peripherals
TODO: Text appears in VGA f/b (0x6B8000), but doesn't display?
System often reads/writes 6003D4/5, might be a cut-down 6845,
as it only uses registers C,D,E,F.
@ -12,15 +14,21 @@
#include "emu.h"
#include "cpu/m68000/m68000.h"
#include "video/pc_vga.h"
#include "machine/isa.h"
#include "machine/isa_cards.h"
#include "machine/mc68901.h"
#include "machine/keyboard.h"
#define M68K_TAG "maincpu"
#define ISABUS_TAG "isa"
#define MFP_TAG "mfp"
class indiana_state : public driver_device
{
public:
indiana_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag) ,
m_maincpu(*this, "maincpu") { }
m_maincpu(*this, M68K_TAG) { }
DECLARE_DRIVER_INIT(indiana);
virtual void machine_reset();
required_device<cpu_device> m_maincpu;
@ -29,18 +37,15 @@ public:
static ADDRESS_MAP_START(indiana_mem, AS_PROGRAM, 32, indiana_state)
ADDRESS_MAP_UNMAP_HIGH
AM_RANGE(0x00000000, 0x0000ffff) AM_MIRROR(0x7f800000) AM_ROM AM_REGION("user1",0) // 64Kb of EPROM
AM_RANGE(0x00000000, 0x0000ffff) AM_MIRROR(0x7f800000) AM_ROM AM_REGION("user1", 0) // 64Kb of EPROM
AM_RANGE(0x00100000, 0x00107fff) AM_MIRROR(0x7f8f8000) AM_RAM // SRAM 32Kb of SRAM
AM_RANGE(0x00200000, 0x002fffff) AM_MIRROR(0x7f800000) AM_RAM // MFP
AM_RANGE(0x00400000, 0x004fffff) AM_MIRROR(0x7f800000) AM_RAM // 16 bit PC IO
AM_RANGE(0x00500000, 0x005fffff) AM_MIRROR(0x7f800000) AM_RAM // 16 bit PC MEM
AM_RANGE(0x00600000, 0x006fffff) AM_MIRROR(0x7f800000) AM_RAM // 8 bit PC IO
AM_RANGE(0x00700000, 0x007fffff) AM_MIRROR(0x7f800000) AM_RAM // 8 bit PC MEM
AM_RANGE(0x7f6003b0, 0x7f6003bf) AM_DEVREADWRITE8("vga", vga_device, port_03b0_r, port_03b0_w, 0xffffffff)
AM_RANGE(0x7f6003c0, 0x7f6003cf) AM_DEVREADWRITE8("vga", vga_device, port_03c0_r, port_03c0_w, 0xffffffff)
AM_RANGE(0x7f6003d0, 0x7f6003df) AM_DEVREADWRITE8("vga", vga_device, port_03d0_r, port_03d0_w, 0xffffffff)
AM_RANGE(0x7f7a0000, 0x7f7bffff) AM_DEVREADWRITE8("vga", vga_device, mem_r, mem_w, 0xffffffff)
AM_RANGE(0x80000000, 0x803fffff) AM_MIRROR(0x7fc00000) AM_RAM // 4 MB RAM
AM_RANGE(0x00200000, 0x002fffff) AM_DEVREADWRITE8(MFP_TAG, mc68901_device, read, write, 0xffffffff) AM_MIRROR(0x7f800000) // MFP
AM_RANGE(0x00400000, 0x004fffff) AM_DEVREADWRITE16(ISABUS_TAG, isa16_device, io16_r, io16_w, 0xffffffff) AM_MIRROR(0x7f800000) // 16 bit PC IO
AM_RANGE(0x00500000, 0x005fffff) AM_DEVREADWRITE16(ISABUS_TAG, isa16_device, prog16_r, prog16_w, 0xffffffff) AM_MIRROR(0x7f800000) // 16 bit PC MEM
AM_RANGE(0x00600000, 0x006fffff) AM_DEVREADWRITE8(ISABUS_TAG, isa16_device, io_r, io_w, 0xffffffff) AM_MIRROR(0x7f800000) // 8 bit PC IO
AM_RANGE(0x00700000, 0x007fffff) AM_DEVREADWRITE8(ISABUS_TAG, isa16_device, prog_r, prog_w, 0xffffffff) AM_MIRROR(0x7f800000) // 8 bit PC MEM
AM_RANGE(0x80000000, 0x803fffff) AM_RAM // 4 MB RAM
AM_RANGE(0xfffe0000, 0xfffe7fff) AM_RAM // SRAM mirror?
ADDRESS_MAP_END
@ -53,39 +58,83 @@ void indiana_state::machine_reset()
{
}
/* F4 Character Displayer */
static const gfx_layout indiana_charlayout =
{
8, 16, /* 8 x 16 characters */
128, /* 128 characters */
1, /* 1 bits per pixel */
{ 0 }, /* no bitplanes */
/* x offsets */
{ 0, 1, 2, 3, 4, 5, 6, 7 },
/* y offsets */
{ 3*8, 2*8, 1*8, 0*8, 7*8, 6*8, 5*8, 4*8, 11*8, 10*8, 9*8, 8*8, 15*8, 14*8, 13*8, 12*8 },
8*16 /* every char takes 16 bytes */
};
static GFXDECODE_START( indiana )
GFXDECODE_ENTRY( "user1", 0x6710, indiana_charlayout, 0, 4 ) // offset is for -bios 0
GFXDECODE_END
static MACHINE_CONFIG_START( indiana, indiana_state )
/* basic machine hardware */
MCFG_CPU_ADD("maincpu",M68030, XTAL_16MHz)
MCFG_CPU_PROGRAM_MAP(indiana_mem)
/* video hardware */
MCFG_GFXDECODE(indiana)
MCFG_FRAGMENT_ADD( pcvideo_vga )
MACHINE_CONFIG_END
DRIVER_INIT_MEMBER(indiana_state,indiana)
{
}
static const isa16bus_interface indiana_isabus_intf =
{
// interrupts 2-7
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
// high IRQs 10-15
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
// dma request 0-7
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
DEVCB_NULL,
};
SLOT_INTERFACE_START( indiana_isa_cards )
// 8-bit
SLOT_INTERFACE("fdc_at", ISA8_FDC_AT)
SLOT_INTERFACE("comat", ISA8_COM_AT)
SLOT_INTERFACE("vga", ISA8_VGA)
// 16-bit
SLOT_INTERFACE("ide", ISA16_IDE)
SLOT_INTERFACE_END
static MC68901_INTERFACE( mfp_interface )
{
XTAL_16MHz/4, /* timer clock */
0, /* receive clock */
0, /* transmit clock */
DEVCB_NULL, /* interrupt */
DEVCB_NULL, /* GPIO write */
DEVCB_NULL, /* TAO */
DEVCB_NULL, /* TBO */
DEVCB_NULL, /* TCO */
DEVCB_NULL, /* TDO */
DEVCB_DEVICE_LINE_MEMBER("keyboard", serial_keyboard_device, rx_w), /* serial output */
DEVCB_NULL,
DEVCB_NULL
};
static struct serial_keyboard_interface keyboard_interface =
{
DEVCB_DEVICE_LINE_MEMBER(MFP_TAG, mc68901_device, write_rx)
};
static MACHINE_CONFIG_START( indiana, indiana_state )
/* basic machine hardware */
MCFG_CPU_ADD(M68K_TAG, M68030, XTAL_16MHz)
MCFG_CPU_PROGRAM_MAP(indiana_mem)
MCFG_ISA16_BUS_ADD(ISABUS_TAG, ":"M68K_TAG, indiana_isabus_intf)
MCFG_ISA16_BUS_CUSTOM_SPACES()
MCFG_ISA16_SLOT_ADD(ISABUS_TAG, "isa1", indiana_isa_cards, "vga", false)
MCFG_ISA16_SLOT_ADD(ISABUS_TAG, "isa2", indiana_isa_cards, "fdc_at", false)
MCFG_ISA16_SLOT_ADD(ISABUS_TAG, "isa3", indiana_isa_cards, "comat", false)
MCFG_MC68901_ADD(MFP_TAG, XTAL_16MHz/4, mfp_interface)
MCFG_SERIAL_KEYBOARD_ADD("keyboard", keyboard_interface, 1200)
MACHINE_CONFIG_END
/* ROM definition */
ROM_START( indiana )
ROM_REGION32_BE( 0x10000, "user1", ROMREGION_ERASEFF )