mirror of
https://github.com/holub/mame
synced 2025-04-27 02:33:13 +03:00
(MESS) ccs : Last part (nw)
This commit is contained in:
parent
9112614335
commit
eaf58835d5
@ -6,6 +6,15 @@
|
|||||||
|
|
||||||
It requires a floppy disk to boot from.
|
It requires a floppy disk to boot from.
|
||||||
|
|
||||||
|
There's no info available on this system, however the bankswitching
|
||||||
|
appears to be the same as their other systems.
|
||||||
|
|
||||||
|
Early on, it does a read from port F2. If bit 3 is low, the system becomes
|
||||||
|
a Model 400.
|
||||||
|
|
||||||
|
Since IM2 is used, it is assumed there are Z80 peripherals on board.
|
||||||
|
There's unknown usage of ports 11 thru 1B, 34, and F0 thru F2.
|
||||||
|
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "emu.h"
|
#include "emu.h"
|
||||||
@ -18,24 +27,46 @@ class ccs300_state : public driver_device
|
|||||||
public:
|
public:
|
||||||
ccs300_state(const machine_config &mconfig, device_type type, const char *tag)
|
ccs300_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||||
: driver_device(mconfig, type, tag)
|
: driver_device(mconfig, type, tag)
|
||||||
, m_ccs_ram(*this, "ccs_ram")
|
|
||||||
, m_maincpu(*this, "maincpu")
|
, m_maincpu(*this, "maincpu")
|
||||||
, m_terminal(*this, TERMINAL_TAG)
|
, m_terminal(*this, TERMINAL_TAG)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
|
DECLARE_DRIVER_INIT(ccs300);
|
||||||
|
DECLARE_MACHINE_RESET(ccs300);
|
||||||
DECLARE_READ8_MEMBER(port10_r);
|
DECLARE_READ8_MEMBER(port10_r);
|
||||||
DECLARE_READ8_MEMBER(port11_r);
|
DECLARE_READ8_MEMBER(port11_r);
|
||||||
DECLARE_WRITE8_MEMBER(port10_w);
|
DECLARE_WRITE8_MEMBER(port10_w);
|
||||||
|
DECLARE_WRITE8_MEMBER(port40_w);
|
||||||
DECLARE_WRITE8_MEMBER(kbd_put);
|
DECLARE_WRITE8_MEMBER(kbd_put);
|
||||||
required_shared_ptr<UINT8> m_ccs_ram;
|
|
||||||
private:
|
private:
|
||||||
UINT8 m_term_data;
|
UINT8 m_term_data;
|
||||||
virtual void machine_reset();
|
|
||||||
required_device<cpu_device> m_maincpu;
|
required_device<cpu_device> m_maincpu;
|
||||||
required_device<generic_terminal_device> m_terminal;
|
required_device<generic_terminal_device> m_terminal;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static ADDRESS_MAP_START(ccs300_mem, AS_PROGRAM, 8, ccs300_state)
|
||||||
|
ADDRESS_MAP_UNMAP_HIGH
|
||||||
|
AM_RANGE(0x0000, 0x07ff) AM_READ_BANK("bankr0") AM_WRITE_BANK("bankw0")
|
||||||
|
AM_RANGE(0x0800, 0xffff) AM_RAM
|
||||||
|
ADDRESS_MAP_END
|
||||||
|
|
||||||
|
static ADDRESS_MAP_START( ccs300_io, AS_IO, 8, ccs300_state)
|
||||||
|
ADDRESS_MAP_UNMAP_HIGH
|
||||||
|
ADDRESS_MAP_GLOBAL_MASK(0xff)
|
||||||
|
AM_RANGE(0x10, 0x10) AM_READWRITE(port10_r,port10_w)
|
||||||
|
AM_RANGE(0x11, 0x11) AM_READ(port11_r)
|
||||||
|
AM_RANGE(0x40, 0x40) AM_WRITE(port40_w)
|
||||||
|
ADDRESS_MAP_END
|
||||||
|
|
||||||
|
/* Input ports */
|
||||||
|
static INPUT_PORTS_START( ccs300 )
|
||||||
|
INPUT_PORTS_END
|
||||||
|
|
||||||
|
//*************************************
|
||||||
|
//
|
||||||
|
// Keyboard
|
||||||
|
//
|
||||||
|
//*************************************
|
||||||
READ8_MEMBER( ccs300_state::port10_r )
|
READ8_MEMBER( ccs300_state::port10_r )
|
||||||
{
|
{
|
||||||
UINT8 ret = m_term_data;
|
UINT8 ret = m_term_data;
|
||||||
@ -53,32 +84,6 @@ WRITE8_MEMBER( ccs300_state::port10_w )
|
|||||||
m_terminal->write(space, 0, data & 0x7f);
|
m_terminal->write(space, 0, data & 0x7f);
|
||||||
}
|
}
|
||||||
|
|
||||||
static ADDRESS_MAP_START(ccs300_mem, AS_PROGRAM, 8, ccs300_state)
|
|
||||||
ADDRESS_MAP_UNMAP_HIGH
|
|
||||||
AM_RANGE(0x0000, 0xefff) AM_RAM AM_SHARE("ccs_ram")
|
|
||||||
AM_RANGE(0xf000, 0xf7ff) AM_ROM AM_REGION("user1", 0xf000)
|
|
||||||
ADDRESS_MAP_END
|
|
||||||
|
|
||||||
static ADDRESS_MAP_START( ccs300_io, AS_IO, 8, ccs300_state)
|
|
||||||
ADDRESS_MAP_UNMAP_HIGH
|
|
||||||
ADDRESS_MAP_GLOBAL_MASK(0xff)
|
|
||||||
AM_RANGE(0x10, 0x10) AM_READWRITE(port10_r,port10_w)
|
|
||||||
AM_RANGE(0x11, 0x11) AM_READ(port11_r)
|
|
||||||
ADDRESS_MAP_END
|
|
||||||
|
|
||||||
/* Input ports */
|
|
||||||
static INPUT_PORTS_START( ccs300 )
|
|
||||||
INPUT_PORTS_END
|
|
||||||
|
|
||||||
|
|
||||||
void ccs300_state::machine_reset()
|
|
||||||
{
|
|
||||||
UINT8* user1 = memregion("user1")->base();
|
|
||||||
memcpy((UINT8*)m_ccs_ram, user1, 0x0800);
|
|
||||||
|
|
||||||
// this should be rom/ram banking
|
|
||||||
}
|
|
||||||
|
|
||||||
WRITE8_MEMBER( ccs300_state::kbd_put )
|
WRITE8_MEMBER( ccs300_state::kbd_put )
|
||||||
{
|
{
|
||||||
m_term_data = data;
|
m_term_data = data;
|
||||||
@ -89,11 +94,37 @@ static GENERIC_TERMINAL_INTERFACE( terminal_intf )
|
|||||||
DEVCB_DRIVER_MEMBER(ccs300_state, kbd_put)
|
DEVCB_DRIVER_MEMBER(ccs300_state, kbd_put)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//*************************************
|
||||||
|
//
|
||||||
|
// Machine
|
||||||
|
//
|
||||||
|
//*************************************
|
||||||
|
WRITE8_MEMBER( ccs300_state::port40_w )
|
||||||
|
{
|
||||||
|
membank("bankr0")->set_entry( (data) ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
MACHINE_RESET_MEMBER( ccs300_state, ccs300 )
|
||||||
|
{
|
||||||
|
membank("bankr0")->set_entry(0); // point at rom
|
||||||
|
membank("bankw0")->set_entry(0); // always write to ram
|
||||||
|
}
|
||||||
|
|
||||||
|
DRIVER_INIT_MEMBER( ccs300_state, ccs300 )
|
||||||
|
{
|
||||||
|
UINT8 *main = memregion("maincpu")->base();
|
||||||
|
|
||||||
|
membank("bankr0")->configure_entry(1, &main[0x0000]);
|
||||||
|
membank("bankr0")->configure_entry(0, &main[0x10000]);
|
||||||
|
membank("bankw0")->configure_entry(0, &main[0x0000]);
|
||||||
|
}
|
||||||
|
|
||||||
static MACHINE_CONFIG_START( ccs300, ccs300_state )
|
static MACHINE_CONFIG_START( ccs300, ccs300_state )
|
||||||
/* basic machine hardware */
|
/* basic machine hardware */
|
||||||
MCFG_CPU_ADD("maincpu",Z80, XTAL_4MHz)
|
MCFG_CPU_ADD("maincpu",Z80, XTAL_4MHz)
|
||||||
MCFG_CPU_PROGRAM_MAP(ccs300_mem)
|
MCFG_CPU_PROGRAM_MAP(ccs300_mem)
|
||||||
MCFG_CPU_IO_MAP(ccs300_io)
|
MCFG_CPU_IO_MAP(ccs300_io)
|
||||||
|
MCFG_MACHINE_RESET_OVERRIDE(ccs300_state, ccs300)
|
||||||
|
|
||||||
/* video hardware */
|
/* video hardware */
|
||||||
MCFG_GENERIC_TERMINAL_ADD(TERMINAL_TAG, terminal_intf)
|
MCFG_GENERIC_TERMINAL_ADD(TERMINAL_TAG, terminal_intf)
|
||||||
@ -101,11 +132,11 @@ MACHINE_CONFIG_END
|
|||||||
|
|
||||||
/* ROM definition */
|
/* ROM definition */
|
||||||
ROM_START( ccs300 )
|
ROM_START( ccs300 )
|
||||||
ROM_REGION( 0x10000, "user1", ROMREGION_ERASEFF )
|
ROM_REGION( 0x10800, "maincpu", ROMREGION_ERASEFF )
|
||||||
ROM_LOAD( "ccs300.rom", 0x0000, 0x0800, CRC(6cf22e31) SHA1(9aa3327cd8c23d0eab82cb6519891aff13ebe1d0))
|
ROM_LOAD( "ccs300.rom", 0x10000, 0x0800, CRC(6cf22e31) SHA1(9aa3327cd8c23d0eab82cb6519891aff13ebe1d0))
|
||||||
ROM_END
|
ROM_END
|
||||||
|
|
||||||
/* Driver */
|
/* Driver */
|
||||||
|
|
||||||
/* YEAR NAME PARENT COMPAT MACHINE INPUT CLASS INIT COMPANY FULLNAME FLAGS */
|
/* YEAR NAME PARENT COMPAT MACHINE INPUT CLASS INIT COMPANY FULLNAME FLAGS */
|
||||||
COMP( 19??, ccs300, ccs2810, 0, ccs300, ccs300, driver_device, 0, "California Computer Systems", "CCS Model 300", GAME_IS_SKELETON )
|
COMP( 19??, ccs300, ccs2810, 0, ccs300, ccs300, ccs300_state, ccs300, "California Computer Systems", "CCS Model 300", GAME_IS_SKELETON )
|
||||||
|
Loading…
Reference in New Issue
Block a user