mirror of
https://github.com/holub/mame
synced 2025-07-04 09:28:51 +03:00
fix/tidy tvboy driver (#3129)
* fix/tidy tvboy driver (nw) * missed file (nw)
This commit is contained in:
parent
3c954ba9a7
commit
ad11c8c9c9
@ -21,52 +21,32 @@ TODO:
|
||||
class tvboy_state : public a2600_state
|
||||
{
|
||||
public:
|
||||
tvboy_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: a2600_state(mconfig, type, tag)
|
||||
, m_crom(*this, "crom")
|
||||
, m_bank0(*this, "bank0")
|
||||
tvboy_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: a2600_state(mconfig, type, tag)
|
||||
, m_crom(*this, "crom")
|
||||
, m_rom(*this, "mainrom") {};
|
||||
|
||||
DECLARE_WRITE8_MEMBER(bank_write);
|
||||
|
||||
void tvboyii(machine_config &config);
|
||||
void supertvboy(machine_config &config);
|
||||
DECLARE_WRITE8_MEMBER(bank_write);
|
||||
|
||||
void tvboyii(machine_config &config);
|
||||
void supertvboy(machine_config &config);
|
||||
|
||||
private:
|
||||
required_device<address_map_bank_device> m_crom;
|
||||
required_memory_bank m_bank0;
|
||||
|
||||
required_region_ptr<uint8_t> m_rom;
|
||||
|
||||
virtual void machine_start() override;
|
||||
virtual void machine_start_tvboyii();
|
||||
virtual void machine_start_supertvboy();
|
||||
required_device<address_map_bank_device> m_crom;
|
||||
required_region_ptr<uint8_t> m_rom;
|
||||
|
||||
virtual void machine_reset() override;
|
||||
virtual void machine_reset() override;
|
||||
};
|
||||
|
||||
void tvboy_state::machine_start_tvboyii() {
|
||||
machine_start();
|
||||
}
|
||||
|
||||
void tvboy_state::machine_start_supertvboy() {
|
||||
machine_start();
|
||||
}
|
||||
|
||||
void tvboy_state::machine_start() {
|
||||
m_crom->set_bank(0);
|
||||
m_bank0->configure_entries(0, 128, &m_rom[0x00000], 0x1000);
|
||||
}
|
||||
|
||||
void tvboy_state::machine_reset() {
|
||||
m_bank0->set_entry(0);
|
||||
a2600_state::machine_reset();
|
||||
m_crom->set_bank(0);
|
||||
a2600_state::machine_reset();
|
||||
}
|
||||
|
||||
WRITE8_MEMBER(tvboy_state::bank_write) {
|
||||
logerror("banking (?) write %04x, %02x\n", offset, data);
|
||||
if((offset & 0xFF00) == 0x0800)
|
||||
m_bank0->set_entry(data);
|
||||
logerror("banking (?) write %04x, %02x\n", offset, data);
|
||||
if ((offset & 0xFF00) == 0x0800)
|
||||
m_crom->set_bank(data);
|
||||
}
|
||||
|
||||
static ADDRESS_MAP_START(tvboy_mem, AS_PROGRAM, 8, tvboy_state ) // 6507 has 13-bit address space, 0x0000 - 0x1fff
|
||||
@ -77,40 +57,35 @@ static ADDRESS_MAP_START(tvboy_mem, AS_PROGRAM, 8, tvboy_state ) // 6507 has 13-
|
||||
#else
|
||||
AM_RANGE(0x0280, 0x029f) AM_MIRROR(0x0d00) AM_DEVREADWRITE("riot", riot6532_device, read, write)
|
||||
#endif
|
||||
AM_RANGE(0x1000, 0x1fff) AM_WRITE(bank_write)
|
||||
AM_RANGE(0x1000, 0x1fff) AM_WRITE(bank_write)
|
||||
AM_RANGE(0x1000, 0x1fff) AM_DEVICE("crom", address_map_bank_device, amap8)
|
||||
ADDRESS_MAP_END
|
||||
|
||||
static ADDRESS_MAP_START( rom_map, AS_PROGRAM, 8, tvboy_state )
|
||||
AM_RANGE(0x0000, 0x0fff) AM_ROMBANK("bank0")
|
||||
AM_RANGE(0x00000, 0x7ffff) AM_ROM AM_REGION("mainrom", 0)
|
||||
ADDRESS_MAP_END
|
||||
|
||||
#define MASTER_CLOCK_PAL 3546894
|
||||
|
||||
|
||||
MACHINE_CONFIG_START(tvboy_state::tvboyii)
|
||||
/* basic machine hardware */
|
||||
MCFG_CPU_ADD("maincpu", M6507, MASTER_CLOCK_PAL / 3)
|
||||
MCFG_CPU_PROGRAM_MAP(tvboy_mem)
|
||||
MCFG_M6502_DISABLE_DIRECT()
|
||||
|
||||
MCFG_DEVICE_ADD("crom", ADDRESS_MAP_BANK, 0)
|
||||
MCFG_DEVICE_ADD("crom", ADDRESS_MAP_BANK, 0)
|
||||
MCFG_DEVICE_PROGRAM_MAP(rom_map)
|
||||
MCFG_ADDRESS_MAP_BANK_ENDIANNESS(ENDIANNESS_LITTLE)
|
||||
MCFG_ADDRESS_MAP_BANK_DATA_WIDTH(8)
|
||||
MCFG_ADDRESS_MAP_BANK_ADDR_WIDTH(12)
|
||||
MCFG_ADDRESS_MAP_BANK_ADDR_WIDTH(19)
|
||||
MCFG_ADDRESS_MAP_BANK_STRIDE(0x1000)
|
||||
|
||||
MCFG_M6502_DISABLE_DIRECT()
|
||||
|
||||
MCFG_MACHINE_START_OVERRIDE(tvboy_state, tvboyii)
|
||||
|
||||
/* video hardware */
|
||||
MCFG_DEVICE_ADD("tia_video", TIA_PAL_VIDEO, 0)
|
||||
MCFG_TIA_READ_INPUT_PORT_CB(READ16(tvboy_state, a2600_read_input_port))
|
||||
MCFG_TIA_DATABUS_CONTENTS_CB(READ8(tvboy_state, a2600_get_databus_contents))
|
||||
MCFG_TIA_VSYNC_CB(WRITE16(tvboy_state, a2600_tia_vsync_callback_pal))
|
||||
|
||||
|
||||
MCFG_SCREEN_ADD("screen", RASTER)
|
||||
MCFG_SCREEN_RAW_PARAMS( MASTER_CLOCK_PAL, 228, 26, 26 + 160 + 16, 312, 32, 32 + 228 + 31 )
|
||||
MCFG_SCREEN_UPDATE_DEVICE("tia_video", tia_video_device, screen_update)
|
||||
@ -140,7 +115,6 @@ MACHINE_CONFIG_START(tvboy_state::tvboyii)
|
||||
|
||||
MCFG_VCS_CONTROL_PORT_ADD(CONTROL1_TAG, vcs_control_port_devices, "joy")
|
||||
MCFG_VCS_CONTROL_PORT_ADD(CONTROL2_TAG, vcs_control_port_devices, nullptr)
|
||||
|
||||
MACHINE_CONFIG_END
|
||||
|
||||
MACHINE_CONFIG_DERIVED(tvboy_state::supertvboy, tvboyii)
|
||||
@ -165,21 +139,21 @@ static INPUT_PORTS_START( tvboyii )
|
||||
INPUT_PORTS_END
|
||||
|
||||
ROM_START( tvboyii )
|
||||
ROM_REGION( 0x2000, "maincpu", ROMREGION_ERASEFF )
|
||||
ROM_REGION( 0x2000, "maincpu", ROMREGION_ERASEFF )
|
||||
|
||||
ROM_REGION( 0x80000, "mainrom", 0 )
|
||||
ROM_LOAD( "HY23400P.bin", 0x00000, 0x80000, CRC(f8485173) SHA1(cafbaa0c5437f192cb4fb49f9a672846aa038870) )
|
||||
ROM_LOAD( "HY23400P.bin", 0x00000, 0x80000, CRC(f8485173) SHA1(cafbaa0c5437f192cb4fb49f9a672846aa038870) )
|
||||
ROM_END
|
||||
|
||||
|
||||
ROM_START( supertvboy )
|
||||
ROM_REGION( 0x2000, "maincpu", ROMREGION_ERASEFF )
|
||||
ROM_START( stvboy )
|
||||
ROM_REGION( 0x2000, "maincpu", ROMREGION_ERASEFF )
|
||||
|
||||
ROM_REGION( 0x80000, "mainrom", 0 )
|
||||
ROM_LOAD( "supertvboy.bin", 0x00000, 0x80000, CRC(af2e73e8) SHA1(04b9ddc3b30b0e5b81b9f868d455e902a0151491) )
|
||||
ROM_LOAD( "supertvboy.bin", 0x00000, 0x80000, CRC(af2e73e8) SHA1(04b9ddc3b30b0e5b81b9f868d455e902a0151491) )
|
||||
ROM_END
|
||||
|
||||
|
||||
/* YEAR NAME PARENT COMPAT MACHINE INPUT STATE INIT COMPANY FULLNAME */
|
||||
CONS( 199?, tvboyii, a2600, 0, tvboyii, tvboyii, tvboy_state, 0, "Systema", "TV Boy II (PAL)" , MACHINE_SUPPORTS_SAVE )
|
||||
CONS( 1995, supertvboy, a2600, 0, supertvboy, tvboyii, tvboy_state, 0, "Akor", "Super TV Boy" , MACHINE_SUPPORTS_SAVE )
|
||||
CONS( 199?, tvboyii, 0, 0, tvboyii, tvboyii, tvboy_state, 0, "Systema", "TV Boy II (PAL)" , MACHINE_SUPPORTS_SAVE )
|
||||
CONS( 1995, stvboy, 0, 0, supertvboy, tvboyii, tvboy_state, 0, "Akor", "Super TV Boy (PAL)" , MACHINE_SUPPORTS_SAVE )
|
||||
|
@ -40,57 +40,56 @@
|
||||
class a2600_state : public driver_device
|
||||
{
|
||||
public:
|
||||
a2600_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag),
|
||||
m_riot_ram(*this, "riot_ram"),
|
||||
m_joy1(*this, CONTROL1_TAG),
|
||||
m_joy2(*this, CONTROL2_TAG) ,
|
||||
m_cart(*this, "cartslot"),
|
||||
m_tia(*this, "tia_video"),
|
||||
m_maincpu(*this, "maincpu"),
|
||||
m_screen(*this, "screen"),
|
||||
m_swb(*this, "SWB"),
|
||||
m_riot(*this,"riot")
|
||||
{ }
|
||||
a2600_state(const machine_config &mconfig, device_type type, const char *tag)
|
||||
: driver_device(mconfig, type, tag),
|
||||
m_riot_ram(*this, "riot_ram"),
|
||||
m_joy1(*this, CONTROL1_TAG),
|
||||
m_joy2(*this, CONTROL2_TAG),
|
||||
m_cart(*this, "cartslot"),
|
||||
m_tia(*this, "tia_video"),
|
||||
m_maincpu(*this, "maincpu"),
|
||||
m_screen(*this, "screen"),
|
||||
m_swb(*this, "SWB"),
|
||||
m_riot(*this, "riot")
|
||||
{ }
|
||||
|
||||
required_shared_ptr<uint8_t> m_riot_ram;
|
||||
uint16_t m_current_screen_height;
|
||||
required_shared_ptr<uint8_t> m_riot_ram;
|
||||
uint16_t m_current_screen_height;
|
||||
|
||||
DECLARE_MACHINE_START(a2600);
|
||||
DECLARE_WRITE8_MEMBER(switch_A_w);
|
||||
DECLARE_READ8_MEMBER(switch_A_r);
|
||||
DECLARE_WRITE8_MEMBER(switch_B_w);
|
||||
DECLARE_WRITE_LINE_MEMBER(irq_callback);
|
||||
DECLARE_READ8_MEMBER(riot_input_port_8_r);
|
||||
DECLARE_READ16_MEMBER(a2600_read_input_port);
|
||||
DECLARE_READ8_MEMBER(a2600_get_databus_contents);
|
||||
DECLARE_WRITE16_MEMBER(a2600_tia_vsync_callback);
|
||||
DECLARE_WRITE16_MEMBER(a2600_tia_vsync_callback_pal);
|
||||
DECLARE_WRITE8_MEMBER(cart_over_tia_w);
|
||||
// investigate how the carts mapped here (Mapper JVP) interact with the RIOT device
|
||||
DECLARE_READ8_MEMBER(cart_over_riot_r);
|
||||
DECLARE_WRITE8_MEMBER(cart_over_riot_w);
|
||||
DECLARE_READ8_MEMBER(cart_over_all_r);
|
||||
DECLARE_WRITE8_MEMBER(cart_over_all_w);
|
||||
DECLARE_MACHINE_START(a2600);
|
||||
DECLARE_WRITE8_MEMBER(switch_A_w);
|
||||
DECLARE_READ8_MEMBER(switch_A_r);
|
||||
DECLARE_WRITE8_MEMBER(switch_B_w);
|
||||
DECLARE_WRITE_LINE_MEMBER(irq_callback);
|
||||
DECLARE_READ8_MEMBER(riot_input_port_8_r);
|
||||
DECLARE_READ16_MEMBER(a2600_read_input_port);
|
||||
DECLARE_READ8_MEMBER(a2600_get_databus_contents);
|
||||
DECLARE_WRITE16_MEMBER(a2600_tia_vsync_callback);
|
||||
DECLARE_WRITE16_MEMBER(a2600_tia_vsync_callback_pal);
|
||||
DECLARE_WRITE8_MEMBER(cart_over_tia_w);
|
||||
// investigate how the carts mapped here (Mapper JVP) interact with the RIOT device
|
||||
DECLARE_READ8_MEMBER(cart_over_riot_r);
|
||||
DECLARE_WRITE8_MEMBER(cart_over_riot_w);
|
||||
DECLARE_READ8_MEMBER(cart_over_all_r);
|
||||
DECLARE_WRITE8_MEMBER(cart_over_all_w);
|
||||
|
||||
void a2600p(machine_config &config);
|
||||
void a2600(machine_config &config);
|
||||
void a2600_cartslot(machine_config &config);
|
||||
void a2600p(machine_config &config);
|
||||
void a2600(machine_config &config);
|
||||
void a2600_cartslot(machine_config &config);
|
||||
protected:
|
||||
required_device<vcs_control_port_device> m_joy1;
|
||||
required_device<vcs_control_port_device> m_joy2;
|
||||
optional_device<vcs_cart_slot_device> m_cart;
|
||||
required_device<tia_video_device> m_tia;
|
||||
required_device<vcs_control_port_device> m_joy1;
|
||||
required_device<vcs_control_port_device> m_joy2;
|
||||
optional_device<vcs_cart_slot_device> m_cart;
|
||||
required_device<tia_video_device> m_tia;
|
||||
|
||||
required_device<m6507_device> m_maincpu;
|
||||
required_device<screen_device> m_screen;
|
||||
required_ioport m_swb;
|
||||
required_device<m6507_device> m_maincpu;
|
||||
required_device<screen_device> m_screen;
|
||||
required_ioport m_swb;
|
||||
#if USE_NEW_RIOT
|
||||
required_device<mos6532_t> m_riot;
|
||||
required_device<mos6532_t> m_riot;
|
||||
#else
|
||||
required_device<riot6532_device> m_riot;
|
||||
required_device<riot6532_device> m_riot;
|
||||
#endif
|
||||
|
||||
};
|
||||
|
||||
|
||||
|
@ -37359,7 +37359,7 @@ tv990 // 1992? TeleVideo
|
||||
tv995 // 1994 TeleVideo
|
||||
|
||||
@source:tvboy.cpp
|
||||
supertvboy
|
||||
stvboy
|
||||
tvboyii //
|
||||
|
||||
@source:tvc.cpp
|
||||
|
Loading…
Reference in New Issue
Block a user