mirror of
https://github.com/holub/mame
synced 2025-04-26 18:23:08 +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.
|
||||
|
||||
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"
|
||||
@ -18,24 +27,46 @@ class ccs300_state : public driver_device
|
||||
public:
|
||||
ccs300_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag)
|
||||
, m_ccs_ram(*this, "ccs_ram")
|
||||
, m_maincpu(*this, "maincpu")
|
||||
, m_terminal(*this, TERMINAL_TAG)
|
||||
{ }
|
||||
|
||||
DECLARE_DRIVER_INIT(ccs300);
|
||||
DECLARE_MACHINE_RESET(ccs300);
|
||||
DECLARE_READ8_MEMBER(port10_r);
|
||||
DECLARE_READ8_MEMBER(port11_r);
|
||||
DECLARE_WRITE8_MEMBER(port10_w);
|
||||
DECLARE_WRITE8_MEMBER(port40_w);
|
||||
DECLARE_WRITE8_MEMBER(kbd_put);
|
||||
required_shared_ptr<UINT8> m_ccs_ram;
|
||||
private:
|
||||
UINT8 m_term_data;
|
||||
virtual void machine_reset();
|
||||
required_device<cpu_device> m_maincpu;
|
||||
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 )
|
||||
{
|
||||
UINT8 ret = m_term_data;
|
||||
@ -53,32 +84,6 @@ WRITE8_MEMBER( ccs300_state::port10_w )
|
||||
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 )
|
||||
{
|
||||
m_term_data = data;
|
||||
@ -89,11 +94,37 @@ static GENERIC_TERMINAL_INTERFACE( terminal_intf )
|
||||
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 )
|
||||
/* basic machine hardware */
|
||||
MCFG_CPU_ADD("maincpu",Z80, XTAL_4MHz)
|
||||
MCFG_CPU_PROGRAM_MAP(ccs300_mem)
|
||||
MCFG_CPU_IO_MAP(ccs300_io)
|
||||
MCFG_MACHINE_RESET_OVERRIDE(ccs300_state, ccs300)
|
||||
|
||||
/* video hardware */
|
||||
MCFG_GENERIC_TERMINAL_ADD(TERMINAL_TAG, terminal_intf)
|
||||
@ -101,11 +132,11 @@ MACHINE_CONFIG_END
|
||||
|
||||
/* ROM definition */
|
||||
ROM_START( ccs300 )
|
||||
ROM_REGION( 0x10000, "user1", ROMREGION_ERASEFF )
|
||||
ROM_LOAD( "ccs300.rom", 0x0000, 0x0800, CRC(6cf22e31) SHA1(9aa3327cd8c23d0eab82cb6519891aff13ebe1d0))
|
||||
ROM_REGION( 0x10800, "maincpu", ROMREGION_ERASEFF )
|
||||
ROM_LOAD( "ccs300.rom", 0x10000, 0x0800, CRC(6cf22e31) SHA1(9aa3327cd8c23d0eab82cb6519891aff13ebe1d0))
|
||||
ROM_END
|
||||
|
||||
/* Driver */
|
||||
|
||||
/* 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 )
|
||||
/* YEAR NAME PARENT COMPAT MACHINE INPUT CLASS INIT COMPANY FULLNAME FLAGS */
|
||||
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