mirror of
https://github.com/holub/mame
synced 2025-05-11 16:48:52 +03:00
182 lines
5.2 KiB
C
182 lines
5.2 KiB
C
/***************************************************************************
|
|
|
|
Sharp MZ-6500
|
|
|
|
|
|
|
|
****************************************************************************/
|
|
|
|
#include "emu.h"
|
|
#include "cpu/i86/i86.h"
|
|
#include "machine/upd765.h"
|
|
#include "video/upd7220.h"
|
|
|
|
class mz6500_state : public driver_device
|
|
{
|
|
public:
|
|
mz6500_state(const machine_config &mconfig, device_type type, const char *tag)
|
|
: driver_device(mconfig, type, tag),
|
|
m_hgdc(*this, "upd7220"),
|
|
m_fdc(*this, "upd765")
|
|
,
|
|
m_video_ram(*this, "video_ram"),
|
|
m_maincpu(*this, "maincpu") { }
|
|
|
|
required_device<upd7220_device> m_hgdc;
|
|
required_device<upd765a_device> m_fdc;
|
|
DECLARE_READ8_MEMBER(mz6500_vram_r);
|
|
DECLARE_WRITE8_MEMBER(mz6500_vram_w);
|
|
void fdc_irq(bool state);
|
|
void fdc_drq(bool state);
|
|
required_shared_ptr<UINT8> m_video_ram;
|
|
virtual void machine_reset();
|
|
virtual void video_start();
|
|
required_device<cpu_device> m_maincpu;
|
|
};
|
|
|
|
static UPD7220_DISPLAY_PIXELS( hgdc_display_pixels )
|
|
{
|
|
mz6500_state *state = device->machine().driver_data<mz6500_state>();
|
|
const rgb_t *palette = palette_entry_list_raw(bitmap.palette());
|
|
int gfx[3];
|
|
UINT8 i,pen;
|
|
|
|
gfx[0] = state->m_video_ram[address + 0x00000];
|
|
gfx[1] = state->m_video_ram[address + 0x10000];
|
|
gfx[2] = state->m_video_ram[address + 0x20000];
|
|
|
|
for(i=0; i<8; i++)
|
|
{
|
|
pen = (BIT(gfx[0], i)) | (BIT(gfx[1], i) << 1) | (BIT(gfx[2], i) << 2);
|
|
|
|
bitmap.pix32(y, x + i) = palette[pen];
|
|
}
|
|
}
|
|
|
|
|
|
void mz6500_state::video_start()
|
|
{
|
|
}
|
|
|
|
|
|
READ8_MEMBER( mz6500_state::mz6500_vram_r )
|
|
{
|
|
return m_video_ram[offset];
|
|
}
|
|
|
|
WRITE8_MEMBER( mz6500_state::mz6500_vram_w )
|
|
{
|
|
m_video_ram[offset] = data;
|
|
}
|
|
|
|
static ADDRESS_MAP_START(mz6500_map, AS_PROGRAM, 16, mz6500_state)
|
|
ADDRESS_MAP_UNMAP_HIGH
|
|
AM_RANGE(0x00000,0x9ffff) AM_RAM
|
|
// AM_RANGE(0xa0000,0xbffff) kanji/dictionary ROM
|
|
AM_RANGE(0xc0000,0xeffff) AM_READWRITE8(mz6500_vram_r,mz6500_vram_w,0xffff)
|
|
AM_RANGE(0xfc000,0xfffff) AM_ROM AM_REGION("ipl", 0)
|
|
ADDRESS_MAP_END
|
|
|
|
static ADDRESS_MAP_START(mz6500_io, AS_IO, 16, mz6500_state)
|
|
ADDRESS_MAP_UNMAP_HIGH
|
|
// AM_RANGE(0x0000, 0x000f) i8237 dma
|
|
// AM_RANGE(0x0010, 0x001f) i8255
|
|
AM_RANGE(0x0020, 0x0021) AM_MIRROR(0xe) AM_DEVICE8("upd765", upd765a_device, map, 0xffff)
|
|
// AM_RANGE(0x0030, 0x003f) i8259 master
|
|
// AM_RANGE(0x0040, 0x004f) i8259 slave
|
|
// AM_RANGE(0x0050, 0x0050) segment byte for DMA
|
|
// AM_RANGE(0x0060, 0x0060) system port A
|
|
// AM_RANGE(0x0070, 0x0070) system port C
|
|
// AM_RANGE(0x00cd, 0x00cd) MZ-1R32
|
|
AM_RANGE(0x0100, 0x0103) AM_MIRROR(0xc) AM_DEVREADWRITE8("upd7220", upd7220_device, read, write, 0x00ff)
|
|
// AM_RANGE(0x0110, 0x011f) video address / data registers (priority)
|
|
// AM_RANGE(0x0120, 0x012f) video registers
|
|
// AM_RANGE(0x0130, 0x013f) video register
|
|
// AM_RANGE(0x0140, 0x015f) palette pens
|
|
// AM_RANGE(0x0200, 0x020f) z80sio
|
|
// AM_RANGE(0x0210, 0x021f) z80ctc
|
|
// AM_RANGE(0x0220, 0x022f) rp5c01
|
|
// AM_RANGE(0x0230, 0x023f) ay-3-8912
|
|
// AM_RANGE(0x0240, 0x0240) z80ctc vector ack
|
|
// AM_RANGE(0x0250, 0x0250) z80sio vector ack
|
|
// AM_RANGE(0x0270, 0x0270) system port B
|
|
ADDRESS_MAP_END
|
|
|
|
/* Input ports */
|
|
static INPUT_PORTS_START( mz6500 )
|
|
INPUT_PORTS_END
|
|
|
|
|
|
void mz6500_state::machine_reset()
|
|
{
|
|
}
|
|
|
|
void mz6500_state::fdc_irq(bool state)
|
|
{
|
|
//printf("%02x IRQ\n",state);
|
|
}
|
|
|
|
void mz6500_state::fdc_drq(bool state)
|
|
{
|
|
//printf("%02x DRQ\n",state);
|
|
}
|
|
|
|
static SLOT_INTERFACE_START( mz6500_floppies )
|
|
SLOT_INTERFACE( "525hd", FLOPPY_525_HD )
|
|
SLOT_INTERFACE_END
|
|
|
|
static UPD7220_INTERFACE( hgdc_intf )
|
|
{
|
|
"screen",
|
|
hgdc_display_pixels,
|
|
NULL,
|
|
DEVCB_NULL,
|
|
DEVCB_NULL,
|
|
DEVCB_NULL
|
|
};
|
|
|
|
static ADDRESS_MAP_START( upd7220_map, AS_0, 8, mz6500_state )
|
|
AM_RANGE(0x00000, 0x3ffff) AM_RAM AM_SHARE("video_ram")
|
|
ADDRESS_MAP_END
|
|
|
|
|
|
static MACHINE_CONFIG_START( mz6500, mz6500_state )
|
|
/* basic machine hardware */
|
|
MCFG_CPU_ADD("maincpu", I8086, 8000000) //unk clock
|
|
MCFG_CPU_PROGRAM_MAP(mz6500_map)
|
|
MCFG_CPU_IO_MAP(mz6500_io)
|
|
|
|
|
|
/* video hardware */
|
|
MCFG_SCREEN_ADD("screen", RASTER)
|
|
MCFG_SCREEN_REFRESH_RATE(50)
|
|
MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500)) /* not accurate */
|
|
MCFG_SCREEN_UPDATE_DEVICE("upd7220", upd7220_device, screen_update)
|
|
MCFG_SCREEN_SIZE(640, 480)
|
|
MCFG_SCREEN_VISIBLE_AREA(0, 640-1, 0, 480-1)
|
|
MCFG_PALETTE_LENGTH(8)
|
|
|
|
/* Devices */
|
|
MCFG_UPD7220_ADD("upd7220", 8000000/6, hgdc_intf, upd7220_map) // unk clock
|
|
MCFG_UPD765A_ADD("upd765", true, true)
|
|
MCFG_FLOPPY_DRIVE_ADD("upd765:0", mz6500_floppies, "525hd", floppy_image_device::default_floppy_formats)
|
|
MCFG_FLOPPY_DRIVE_ADD("upd765:1", mz6500_floppies, "525hd", floppy_image_device::default_floppy_formats)
|
|
MACHINE_CONFIG_END
|
|
|
|
/* ROM definition */
|
|
ROM_START( mz6500 )
|
|
ROM_REGION( 0x4000, "ipl", ROMREGION_ERASEFF )
|
|
ROM_LOAD( "ipl.rom", 0x0000, 0x4000,CRC(6c978ac4) SHA1(7872d7e6d9cda2ed9f47ed4833a5caa4dfe0e55c))
|
|
|
|
ROM_REGION( 0x40000, "dictionary", ROMREGION_ERASEFF )
|
|
ROM_LOAD( "dict.rom", 0x0000, 0x40000, CRC(2df3cfd3) SHA1(d420ede09658c2626b0bb650a063d88b1783e554))
|
|
|
|
ROM_REGION( 0x40000, "kanji", ROMREGION_ERASEFF )
|
|
ROM_LOAD( "kanji.rom", 0x0000, 0x40000, CRC(b618e25d) SHA1(1da93337fecde6c0f8a5bd68f3f0b3222a38d63e))
|
|
ROM_END
|
|
|
|
/* Driver */
|
|
|
|
/* YEAR NAME PARENT COMPAT MACHINE INPUT INIT COMPANY FULLNAME FLAGS */
|
|
COMP( 198?, mz6500, 0, 0, mz6500, mz6500, driver_device, 0, "Sharp", "MZ-6500", GAME_NOT_WORKING | GAME_NO_SOUND)
|