New Not Working machine : LSI M3

This commit is contained in:
Robbbert 2017-11-20 03:54:53 +11:00
parent 978fabb6b3
commit 4106d1404e
4 changed files with 149 additions and 0 deletions

View File

@ -3514,6 +3514,7 @@ files {
MAME_DIR .. "src/mame/drivers/lg-dvd.cpp",
MAME_DIR .. "src/mame/drivers/lola8a.cpp",
MAME_DIR .. "src/mame/drivers/lilith.cpp",
MAME_DIR .. "src/mame/drivers/m3.cpp",
MAME_DIR .. "src/mame/drivers/m79152pc.cpp",
MAME_DIR .. "src/mame/drivers/mccpm.cpp",
MAME_DIR .. "src/mame/drivers/mes.cpp",

144
src/mame/drivers/m3.cpp Normal file
View File

@ -0,0 +1,144 @@
// license:BSD-3-Clause
// copyright-holders:
/***********************************************************************************************************************************
2017-11-20 Skeleton
LSI M3
From disassembly: chips: Z80, 6845, 8251, 2x 8255, Z80CTC
************************************************************************************************************************************/
#include "emu.h"
#include "cpu/z80/z80.h"
#include "video/mc6845.h"
#include "screen.h"
class m3_state : public driver_device
{
public:
m3_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag)
, m_maincpu(*this, "maincpu")
, m_p_chargen(*this, "chargen")
, m_p_videoram(*this, "videoram")
, m_palette(*this, "palette")
{ }
MC6845_UPDATE_ROW(crtc_update_row);
private:
virtual void machine_reset() override;
required_device<cpu_device> m_maincpu;
required_region_ptr<u8> m_p_chargen;
required_shared_ptr<u8> m_p_videoram;
required_device<palette_device> m_palette;
};
static ADDRESS_MAP_START( mem_map, AS_PROGRAM, 8, m3_state )
AM_RANGE(0x0000, 0xe7ff) AM_RAM
AM_RANGE(0xe800, 0xefff) AM_RAM AM_SHARE("videoram")
AM_RANGE(0xf000, 0xffff) AM_ROM AM_REGION("roms", 0)
ADDRESS_MAP_END
static ADDRESS_MAP_START( io_map, AS_PROGRAM, 8, m3_state )
ADDRESS_MAP_GLOBAL_MASK (0xff)
AM_RANGE(0x84, 0x84) AM_DEVREADWRITE("crtc", mc6845_device, status_r, address_w)
AM_RANGE(0x85, 0x85) AM_DEVREADWRITE("crtc", mc6845_device, register_r, register_w)
ADDRESS_MAP_END
static INPUT_PORTS_START( m3 )
INPUT_PORTS_END
MC6845_UPDATE_ROW( m3_state::crtc_update_row )
{
const rgb_t *pens = m_palette->palette()->entry_list_raw();
uint8_t chr,gfx,inv;
uint16_t mem,x;
uint32_t *p = &bitmap.pix32(y);
for (x = 0; x < x_count; x++)
{
inv = (x == cursor_x) ? 0xff : 0;
mem = (ma + x) & 0x7ff;
chr = m_p_videoram[mem];
if (BIT(chr, 7))
{
inv ^= 0xff;
chr &= 0x7f;
}
/* get pattern of pixels for that character scanline */
gfx = m_p_chargen[(chr<<4) | ra] ^ inv;
/* Display a scanline of a character (8 pixels) */
*p++ = pens[BIT(gfx, 6)];
*p++ = pens[BIT(gfx, 5)];
*p++ = pens[BIT(gfx, 4)];
*p++ = pens[BIT(gfx, 3)];
*p++ = pens[BIT(gfx, 2)];
*p++ = pens[BIT(gfx, 1)];
*p++ = pens[BIT(gfx, 0)];
}
}
/* F4 Character Displayer */
static const gfx_layout charlayout =
{
7, 16, /* 7 x 16 characters */
128, /* 128 characters */
1, /* 1 bits per pixel */
{ 0 }, /* no bitplanes */
/* x offsets */
{ 1, 2, 3, 4, 5, 6, 7 },
/* y offsets */
{ 0, 8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8, 8*8, 9*8 },
8*16 /* every char takes 16 bytes */
};
static GFXDECODE_START( f4disp )
GFXDECODE_ENTRY( "chargen", 0x0000, charlayout, 0, 1 )
GFXDECODE_END
void m3_state::machine_reset()
{
m_maincpu->set_pc(0xf000);
}
static MACHINE_CONFIG_START( m3 )
MCFG_CPU_ADD("maincpu", Z80, 2'000'000) // no idea of clock.
MCFG_CPU_PROGRAM_MAP(mem_map)
MCFG_CPU_IO_MAP(io_map)
/* video hardware */
MCFG_SCREEN_ADD_MONOCHROME("screen", RASTER, rgb_t::green())
MCFG_SCREEN_REFRESH_RATE(60)
MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500)) // not correct
MCFG_SCREEN_UPDATE_DEVICE("crtc", mc6845_device, screen_update)
MCFG_SCREEN_SIZE(640, 480)
MCFG_SCREEN_VISIBLE_AREA(0, 639, 0, 479)
MCFG_GFXDECODE_ADD("gfxdecode", "palette", f4disp)
MCFG_PALETTE_ADD_MONOCHROME("palette")
/* Devices */
MCFG_MC6845_ADD("crtc", MC6845, "screen", 2'000'000) // clk unknown
MCFG_MC6845_SHOW_BORDER_AREA(false)
MCFG_MC6845_CHAR_WIDTH(7)
MCFG_MC6845_UPDATE_ROW_CB(m3_state, crtc_update_row)
MACHINE_CONFIG_END
ROM_START( m3 )
ROM_REGION( 0x3000, "roms", 0 )
ROM_LOAD( "bootstrap_prom_(034).bin", 0x0000, 0x0800, CRC(7fdb051e) SHA1(7aa24d4f44b6a0c8f7f647667f4997432c186cac) )
ROM_LOAD( "monitor_prom_v1.7_2015-12-09.bin", 0x0800, 0x0800, CRC(85b5c541) SHA1(92b4ec87a4d0d8c0f7b49eec0c5457f237de0a01) )
ROM_REGION( 0x0800, "chargen", 0 ) // bit 7 set on every byte - bad?
ROM_LOAD( "6845crt_font_prom_(033).bin", 0x0000, 0x0800, CRC(cc29f664) SHA1(4197530d9455d665fd4773f95bb6394f6b056dec) )
ROM_REGION( 0x0800, "keyboard", 0 )
ROM_LOAD( "keyboard_prom_(032).bin", 0x0000, 0x0800, CRC(21548355) SHA1(ee4ce4af9c78474263dd58e0f19e79e5b00926fa) )
ROM_END
COMP( 19??, m3, 0, 0, m3, m3, m3_state, 0, "LSI", "M3", MACHINE_IS_SKELETON )

View File

@ -17895,6 +17895,9 @@ m40 //
m24 //
m240 //
@source:m3.cpp
m3 //
@source:m5.cpp
m5 //
m5p //

View File

@ -345,6 +345,7 @@ lwriter.cpp
lynx.cpp
m20.cpp
m24.cpp
m3.cpp
m5.cpp
m6805evs.cpp
m68705prg.cpp