diff --git a/scripts/target/mame/mess.lua b/scripts/target/mame/mess.lua index a9d9c2ffa74..5bbfbd61ee6 100644 --- a/scripts/target/mame/mess.lua +++ b/scripts/target/mame/mess.lua @@ -3051,7 +3051,9 @@ files { MAME_DIR .. "src/mame/includes/nes.h", MAME_DIR .. "src/mame/machine/nes.cpp", MAME_DIR .. "src/mame/video/nes.cpp", - MAME_DIR .. "src/mame/drivers/nes_vt.cpp", + MAME_DIR .. "src/mame/drivers/nes_vt02_vt03.cpp", + MAME_DIR .. "src/mame/drivers/nes_vt09.cpp", + MAME_DIR .. "src/mame/drivers/nes_vt32_vt369.cpp", MAME_DIR .. "src/mame/machine/nes_vt_soc.cpp", MAME_DIR .. "src/mame/machine/nes_vt_soc.h", MAME_DIR .. "src/mame/drivers/nes_sh6578.cpp", diff --git a/src/mame/drivers/nes_vt.cpp b/src/mame/drivers/nes_vt02_vt03.cpp similarity index 54% rename from src/mame/drivers/nes_vt.cpp rename to src/mame/drivers/nes_vt02_vt03.cpp index b54e044ff6d..bc18923d595 100644 --- a/src/mame/drivers/nes_vt.cpp +++ b/src/mame/drivers/nes_vt02_vt03.cpp @@ -4,14 +4,10 @@ nes_vt.cpp - TODO + VT02/VT03 systems go in here - Add more Famiclone roms here, there should be plenty more dumps of VTxx - based systems floating about. - - Make sure that none of the unenhanced sets were actually sold as cartridges - instead, there is a lack of information for some of the older dumps and - still some dumps in nes.xml that might belong here. + - 2KB RAM + - VT03 adds alt palette style (not available on VT02?) NON-bugs (same happens on real hardware) @@ -29,11 +25,7 @@ public: driver_device(mconfig, type, tag), m_io0(*this, "IO0"), m_io1(*this, "IO1"), - m_cartsel(*this, "CARTSEL"), - m_exin0(*this, "EXTRAIN0"), - m_exin1(*this, "EXTRAIN1"), - m_exin2(*this, "EXTRAIN2"), - m_exin3(*this, "EXTRAIN3"), + m_exin(*this, "EXTRAIN%u", 0U), m_prgrom(*this, "mainrom") { } @@ -54,37 +46,22 @@ protected: uint8_t m_latch1; uint8_t m_previous_port0; - optional_ioport m_cartsel; - optional_ioport m_exin0; - optional_ioport m_exin1; - optional_ioport m_exin2; - optional_ioport m_exin3; - - /* Misc */ - uint32_t m_ahigh; // external banking bits - uint8_t m_4242; - uint8_t m_411c; - uint8_t m_411d; + optional_ioport_array<4> m_exin; required_region_ptr m_prgrom; uint8_t vt_rom_r(offs_t offset); void vtspace_w(offs_t offset, uint8_t data); - void configure_soc(nes_vt_soc_device* soc); + void configure_soc(nes_vt02_vt03_soc_device* soc); uint8_t upper_412c_r(); uint8_t upper_412d_r(); void upper_412c_w(uint8_t data); private: - /* APU handling */ - /* Extra IO */ - uint8_t extrain_0_r(); - uint8_t extrain_1_r(); - uint8_t extrain_2_r(); - uint8_t extrain_3_r(); + template uint8_t extrain_r(); }; class nes_vt_state : public nes_vt_base_state @@ -102,19 +79,12 @@ public: void nes_vt_512kb(machine_config& config); void nes_vt_1mb(machine_config& config); void nes_vt_2mb(machine_config& config); - void nes_vt_1mb_baddma(machine_config& config); - void nes_vt_2mb_baddma(machine_config& config); - void nes_vt_4mb_baddma(machine_config& config); - void nes_vt_4mb_baddma_rasterhack(machine_config& config); void nes_vt_4mb(machine_config& config); void nes_vt_8mb(machine_config& config); void nes_vt_16mb(machine_config& config); void nes_vt_32mb(machine_config& config); - void nes_vt_4k_ram(machine_config& config); - void nes_vt_4k_ram_16mb(machine_config& config); - - void nes_vt_4k_ram_pal(machine_config& config); + void nes_vt_1mb_majkon(machine_config& config); void vt_external_space_map_32mbyte(address_map& map); void vt_external_space_map_16mbyte(address_map& map); @@ -124,13 +94,12 @@ public: void vt_external_space_map_1mbyte(address_map& map); void vt_external_space_map_512kbyte(address_map& map); - void nes_vt_1mb_majkon(machine_config& config); void vt_external_space_map_1mbyte_majkon(address_map& map); void init_protpp(); protected: - required_device m_soc; + required_device m_soc; }; @@ -263,133 +232,6 @@ private: void ablping_extraio_w(uint8_t data); }; -class nes_vt_cy_state : public nes_vt_state -{ -public: - nes_vt_cy_state(const machine_config& mconfig, device_type type, const char* tag) : - nes_vt_state(mconfig, type, tag) - { } - - void nes_vt_cy(machine_config& config); - - void nes_vt_cy_bigger(machine_config& config); - - - void nes_vt_bt(machine_config& config); - void nes_vt_bt_2x16mb(machine_config& config); - - void vt_external_space_map_bitboy_2x16mbyte(address_map& map); - -private: - void nes_vt_cy_map(address_map& map); - void nes_vt_bt_map(address_map& map); - - void bittboy_412c_w(uint8_t data); - - uint8_t vt_rom_banked_r(offs_t offset); -}; - -class nes_vt_cy_lexibook_state : public nes_vt_cy_state -{ -public: - nes_vt_cy_lexibook_state(const machine_config& mconfig, device_type type, const char* tag) : - nes_vt_cy_state(mconfig, type, tag), - m_latch0_bit(0), - m_latch1_bit(0) - { } - - void init_lxcmcypp(); - -protected: - virtual uint8_t in0_r() override; - virtual uint8_t in1_r() override; - virtual void in0_w(uint8_t data) override; - -private: - uint8_t m_latch0_bit; - uint8_t m_latch1_bit; -}; - - -class nes_vt_dg_state : public nes_vt_state -{ -public: - nes_vt_dg_state(const machine_config& mconfig, device_type type, const char* tag) : - nes_vt_state(mconfig, type, tag) - { } - - void nes_vt_dg(machine_config& config); - void nes_vt_dg_baddma_16mb(machine_config& config); - void nes_vt_dg_1mb(machine_config& config); - - void nes_vt_fa(machine_config& config); - void nes_vt_fa_4x16mb(machine_config& config); - -protected: - -private: - uint8_t vt_rom_banked_r(offs_t offset); - void vt_external_space_map_fapocket_4x16mbyte(address_map& map); - - void nes_vt_dg_map(address_map& map); - void nes_vt_dg_baddma_map(address_map& map); - void nes_vt_fa_map(address_map& map); - - uint8_t fapocket_412c_r(); - void fapocket_412c_w(uint8_t data); - -}; - -class nes_vt_dg_fapocket_state : public nes_vt_dg_state -{ -public: - nes_vt_dg_fapocket_state(const machine_config& mconfig, device_type type, const char* tag) : - nes_vt_dg_state(mconfig, type, tag) - { } - -protected: - virtual void machine_reset() override; -}; - - - - -class nes_vt_hh_state : public nes_vt_dg_state -{ -public: - nes_vt_hh_state(const machine_config& mconfig, device_type type, const char* tag) : - nes_vt_dg_state(mconfig, type, tag) - { } - - void nes_vt_hh(machine_config& config); - void nes_vt_hh_4mb(machine_config& config); - void nes_vt_hh_8mb(machine_config& config); - - void nes_vt_vg(machine_config& config); - void nes_vt_vg_2mb(machine_config& config); - void nes_vt_vg_4mb(machine_config& config); - void nes_vt_vg_4mb_rasterhack(machine_config& config); - void nes_vt_vg_8mb(machine_config& config); - void nes_vt_vg_16mb(machine_config& config); - - void nes_vt_fp(machine_config& config); - void nes_vt_fp_16mb(machine_config& config); - void nes_vt_fp_32mb(machine_config& config); - void nes_vt_fp_bigger(machine_config& config); - void nes_vt_fp_4x16mb(machine_config& config); - - void nes_vt_fp_pal(machine_config& config); - void nes_vt_fp_pal_32mb(machine_config& config); - -private: - uint8_t vt_rom_banked_r(offs_t offset); - void vt_external_space_map_fp_2x32mbyte(address_map& map); - - void nes_vt_fp_map(address_map& map); - - uint8_t fcpocket_412d_r(); - void fcpocket_412c_w(uint8_t data); -}; class nes_vt_ablpinb_state : public nes_vt_state { @@ -419,15 +261,6 @@ private: required_ioport m_plunger; }; -class nes_vt_vg_1mb_majgnc_state : public nes_vt_state -{ -public: - nes_vt_vg_1mb_majgnc_state(const machine_config& mconfig, device_type type, const char* tag) : - nes_vt_state(mconfig, type, tag) - { } - - void nes_vt_vg_1mb_majgnc(machine_config& config); -}; uint8_t nes_vt_base_state::vt_rom_r(offs_t offset) { @@ -489,81 +322,17 @@ void nes_vt_state::vt_external_space_map_1mbyte_majkon(address_map &map) map(0x1400000, 0x1401fff).ram(); // rush'n attack writes to chr space, after setting the program and character outer bank to a mirror, is the correct way to handle it? } -// bitboy is 2 16Mbyte banks -uint8_t nes_vt_cy_state::vt_rom_banked_r(offs_t offset) +template uint8_t nes_vt_base_state::extrain_r() { - return m_prgrom[m_ahigh | offset]; -} - -void nes_vt_cy_state::vt_external_space_map_bitboy_2x16mbyte(address_map &map) -{ - map(0x0000000, 0x0ffffff).mirror(0x1000000).r(FUNC(nes_vt_cy_state::vt_rom_banked_r)); -} - -// fapocket is 4 16Mbyte banks -uint8_t nes_vt_dg_state::vt_rom_banked_r(offs_t offset) -{ - return m_prgrom[m_ahigh | offset]; -} - -void nes_vt_dg_state::vt_external_space_map_fapocket_4x16mbyte(address_map &map) -{ - map(0x0000000, 0x0ffffff).mirror(0x1000000).r(FUNC(nes_vt_dg_state::vt_rom_banked_r)); -} - -uint8_t nes_vt_hh_state::vt_rom_banked_r(offs_t offset) -{ - return m_prgrom[m_ahigh | offset]; -} - -void nes_vt_hh_state::vt_external_space_map_fp_2x32mbyte(address_map &map) -{ - map(0x0000000, 0x1ffffff).r(FUNC(nes_vt_hh_state::vt_rom_banked_r)); -} - -uint8_t nes_vt_base_state::extrain_0_r() -{ - if (m_exin0) - return m_exin0->read(); + if (m_exin[NUM]) + return m_exin[NUM]->read(); else { - logerror("%s: extrain_0_r (not hooked up)\n", machine().describe_context()); + logerror("%s: extrain_r (port %d) (not hooked up)\n", NUM, machine().describe_context()); } return 0x00; } -uint8_t nes_vt_base_state::extrain_1_r() -{ - if (m_exin1) - return m_exin1->read(); - else - { - logerror("%s: extrain_1_r (not hooked up)\n", machine().describe_context()); - } - return 0x00; -} - -uint8_t nes_vt_base_state::extrain_2_r() -{ - if (m_exin2) - return m_exin2->read(); - else - { - logerror("%s: extrain_2_r (not hooked up)\n", machine().describe_context()); - } - return 0x00; -} - -uint8_t nes_vt_base_state::extrain_3_r() -{ - if (m_exin3) - return m_exin3->read(); - else - { - logerror("%s: extrain_3_r (not hooked up)\n", machine().describe_context()); - } - return 0x00; -} /* Standard I/O handlers (NES Controller clone) */ @@ -602,43 +371,6 @@ void nes_vt_base_state::in0_w(uint8_t data) m_previous_port0 = data; } -/* Lexibook I/O handlers */ - -uint8_t nes_vt_cy_lexibook_state::in0_r() -{ - //logerror("%s: in0_r\n", machine().describe_context()); - uint8_t ret = m_latch0_bit; - return ret; -} - -uint8_t nes_vt_cy_lexibook_state::in1_r() -{ - //logerror("%s: in1_r\n", machine().describe_context()); - uint8_t ret = m_latch1_bit; - return ret; -} - -void nes_vt_cy_lexibook_state::in0_w(uint8_t data) -{ - //logerror("%s: in0_w %02x\n", machine().describe_context(), data); - if ((!(data & 0x01)) && (m_previous_port0 & 0x01)) // 0x03 -> 0x02 transition - { - m_latch0 = m_io0->read(); - m_latch1 = m_io1->read(); - } - - if ((!(data & 0x02)) && (m_previous_port0 & 0x02)) // 0x02 -> 0x00 transition - { - m_latch0_bit = m_latch0 & 0x01; - m_latch0 >>= 1; - m_latch1_bit = m_latch1 & 0x01; - m_latch1 >>= 1; - } - - m_previous_port0 = data; -} - - // ablping polls this (also writes here) what is it? 4-bit DAC? PCM? (inputs only start responding once it finishes writing data on startup but takes longer than a sample should) // (this is the extended IO port on VT) @@ -660,19 +392,9 @@ void nes_vt_base_state::machine_start() m_latch1 = 0; m_previous_port0 = 0; - m_ahigh = 0; - m_4242 = 0; - m_411c = 0; - m_411d = 0; - save_item(NAME(m_latch0)); save_item(NAME(m_latch1)); save_item(NAME(m_previous_port0)); - - save_item(NAME(m_ahigh)); - save_item(NAME(m_4242)); - save_item(NAME(m_411c)); - save_item(NAME(m_411d)); } void nes_vt_base_state::machine_reset() @@ -680,16 +402,6 @@ void nes_vt_base_state::machine_reset() } -void nes_vt_dg_fapocket_state::machine_reset() -{ - nes_vt_base_state::machine_reset(); - - // fapocket needs this, fcpocket instead reads the switch in software? - if (m_cartsel) - m_ahigh = (m_cartsel->read() == 0x01) ? (1 << 25) : 0x0; - else - m_ahigh = 0; -} void nes_vt_ablpinb_state::machine_start() { @@ -763,125 +475,94 @@ void nes_vt_ablpinb_state::in0_w(uint8_t data) } -void nes_vt_base_state::configure_soc(nes_vt_soc_device* soc) +void nes_vt_base_state::configure_soc(nes_vt02_vt03_soc_device* soc) { soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_32mbyte); soc->read_0_callback().set(FUNC(nes_vt_base_state::in0_r)); soc->read_1_callback().set(FUNC(nes_vt_base_state::in1_r)); soc->write_0_callback().set(FUNC(nes_vt_base_state::in0_w)); - soc->extra_read_0_callback().set(FUNC(nes_vt_base_state::extrain_0_r)); - soc->extra_read_1_callback().set(FUNC(nes_vt_base_state::extrain_1_r)); - soc->extra_read_2_callback().set(FUNC(nes_vt_base_state::extrain_2_r)); - soc->extra_read_3_callback().set(FUNC(nes_vt_base_state::extrain_3_r)); -} - -void nes_vt_vg_1mb_majgnc_state::nes_vt_vg_1mb_majgnc(machine_config &config) -{ - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_vg_1mb_majgnc_state::vt_external_space_map_1mbyte); + soc->extra_read_0_callback().set(FUNC(nes_vt_base_state::extrain_r<0>)); + soc->extra_read_1_callback().set(FUNC(nes_vt_base_state::extrain_r<1>)); + soc->extra_read_2_callback().set(FUNC(nes_vt_base_state::extrain_r<2>)); + soc->extra_read_3_callback().set(FUNC(nes_vt_base_state::extrain_r<3>)); } void nes_vt_state::nes_vt_512kb(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_512kbyte); } void nes_vt_state::nes_vt_1mb(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_1mbyte); } void nes_vt_state::nes_vt_2mb(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_2mbyte); } -void nes_vt_state::nes_vt_1mb_baddma(machine_config& config) -{ - nes_vt_1mb(config); - m_soc->force_bad_dma(); -} - -void nes_vt_state::nes_vt_2mb_baddma(machine_config& config) -{ - nes_vt_2mb(config); - m_soc->force_bad_dma(); -} - -void nes_vt_state::nes_vt_4mb_baddma(machine_config& config) -{ - nes_vt_4mb(config); - m_soc->force_bad_dma(); - -} - -void nes_vt_state::nes_vt_4mb_baddma_rasterhack(machine_config& config) -{ - nes_vt_2mb_baddma(config); - m_soc->force_raster_timing_hack(); -} void nes_vt_state::nes_vt_4mb(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_4mbyte); } void nes_vt_state::nes_vt_8mb(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_8mbyte); } void nes_vt_state::nes_vt_16mb(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_16mbyte); } void nes_vt_state::nes_vt_32mb(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_32mbyte); } void nes_vt_state::nes_vt_pal_2mb(machine_config& config) { - NES_VT_SOC_PAL(config, m_soc, PAL_APU_CLOCK); + NES_VT02_VT03_SOC_PAL(config, m_soc, PAL_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_2mbyte); } void nes_vt_state::nes_vt_pal_4mb(machine_config& config) { - NES_VT_SOC_PAL(config, m_soc, PAL_APU_CLOCK); + NES_VT02_VT03_SOC_PAL(config, m_soc, PAL_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_4mbyte); } void nes_vt_state::nes_vt_pal_8mb(machine_config& config) { - NES_VT_SOC_PAL(config, m_soc, PAL_APU_CLOCK); + NES_VT02_VT03_SOC_PAL(config, m_soc, PAL_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_8mbyte); } void nes_vt_waixing_state::nes_vt_waixing_512kb(machine_config &config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_waixing_state::vt_external_space_map_512kbyte); m_soc->set_201x_descramble(0x3, 0x2, 0x7, 0x6, 0x5, 0x4); @@ -896,7 +577,7 @@ void nes_vt_waixing_state::nes_vt_waixing_512kb_rasterhack(machine_config &confi void nes_vt_waixing_state::nes_vt_waixing_2mb(machine_config &config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_waixing_state::vt_external_space_map_2mbyte); m_soc->set_201x_descramble(0x3, 0x2, 0x7, 0x6, 0x5, 0x4); @@ -904,7 +585,7 @@ void nes_vt_waixing_state::nes_vt_waixing_2mb(machine_config &config) void nes_vt_waixing_alt_state::nes_vt_waixing_alt_4mb(machine_config &config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_waixing_state::vt_external_space_map_4mbyte); m_soc->set_201x_descramble(0x3, 0x2, 0x7, 0x6, 0x5, 0x4); @@ -913,7 +594,7 @@ void nes_vt_waixing_alt_state::nes_vt_waixing_alt_4mb(machine_config &config) void nes_vt_waixing_alt_state::nes_vt_waixing_alt_pal_8mb(machine_config &config) { - NES_VT_SOC_PAL(config, m_soc, PAL_APU_CLOCK); + NES_VT02_VT03_SOC_PAL(config, m_soc, PAL_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_waixing_alt_state::vt_external_space_map_8mbyte); m_soc->set_201x_descramble(0x3, 0x2, 0x7, 0x6, 0x5, 0x4); @@ -922,7 +603,7 @@ void nes_vt_waixing_alt_state::nes_vt_waixing_alt_pal_8mb(machine_config &config void nes_vt_waixing_alt_sporzpp_state::nes_vt_waixing_alt_4mb_sporzpp(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_ablping_state::vt_external_space_map_4mbyte); @@ -933,7 +614,7 @@ void nes_vt_waixing_alt_sporzpp_state::nes_vt_waixing_alt_4mb_sporzpp(machine_co void nes_vt_hum_state::nes_vt_hummer_2mb(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_sp69_state::vt_external_space_map_2mbyte); m_soc->set_201x_descramble(0x7, 0x6, 0x5, 0x4, 0x2, 0x3); @@ -948,7 +629,7 @@ void nes_vt_hum_state::nes_vt_hummer_4mb(machine_config& config) void nes_vt_pjoy_state::nes_vt_pjoy_4mb(machine_config &config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_sp69_state::vt_external_space_map_4mbyte); m_soc->set_201x_descramble(0x2, 0x3, 0x4, 0x5, 0x6, 0x7); @@ -959,7 +640,7 @@ void nes_vt_pjoy_state::nes_vt_pjoy_4mb(machine_config &config) void nes_vt_sp69_state::nes_vt_4mb_sp69(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_sp69_state::vt_external_space_map_4mbyte); m_soc->set_201x_descramble(0x4, 0x7, 0x2, 0x6, 0x5, 0x3); @@ -968,7 +649,7 @@ void nes_vt_sp69_state::nes_vt_4mb_sp69(machine_config& config) void nes_vt_ablping_state::nes_vt_2mb_ablping(machine_config &config) { - NES_VT_SOC_PAL(config, m_soc, PAL_APU_CLOCK); + NES_VT02_VT03_SOC_PAL(config, m_soc, PAL_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_ablping_state::vt_external_space_map_2mbyte); @@ -999,177 +680,9 @@ void nes_vt_base_state::upper_412c_w(uint8_t data) } -void nes_vt_state::nes_vt_4k_ram(machine_config &config) -{ - /* basic machine hardware */ - NES_VT_SOC_4KRAM(config, m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); - - dynamic_cast(*m_soc).upper_read_412c_callback().set(FUNC(nes_vt_state::upper_412c_r)); - dynamic_cast(*m_soc).upper_read_412d_callback().set(FUNC(nes_vt_state::upper_412d_r)); - dynamic_cast(*m_soc).upper_write_412c_callback().set(FUNC(nes_vt_state::upper_412c_w)); -} - -void nes_vt_state::nes_vt_4k_ram_16mb(machine_config &config) -{ - nes_vt_4k_ram(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_16mbyte); -} - -void nes_vt_state::nes_vt_4k_ram_pal(machine_config &config) -{ - nes_vt_4k_ram(config); // TODO, use PAL -} - -void nes_vt_cy_state::nes_vt_cy(machine_config &config) -{ - nes_vt_4k_ram(config); - - NES_VT_SOC_4KRAM_CY(config.replace(), m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); -} - -void nes_vt_cy_state::nes_vt_cy_bigger(machine_config &config) -{ - nes_vt_cy(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_cy_state::vt_external_space_map_32mbyte); // must be some banking of this kind of VT can address over 32mb -} - -void nes_vt_cy_state::nes_vt_bt(machine_config &config) -{ - nes_vt_4k_ram(config); - - NES_VT_SOC_4KRAM_BT(config.replace(), m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); -} - - -void nes_vt_cy_state::bittboy_412c_w(uint8_t data) -{ - //bittboy (ok), mc_pg150 (not working) - logerror("%s: vt03_412c_extbank_w %02x\n", machine().describe_context(), data); - m_ahigh = (data & 0x04) ? (1 << 24) : 0x0; -} - -void nes_vt_cy_state::nes_vt_bt_2x16mb(machine_config& config) -{ - nes_vt_bt(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_cy_state::vt_external_space_map_bitboy_2x16mbyte); - - dynamic_cast(*m_soc).upper_write_412c_callback().set(FUNC(nes_vt_cy_state::bittboy_412c_w)); -} - -void nes_vt_dg_state::nes_vt_dg(machine_config &config) -{ - nes_vt_4k_ram(config); - - NES_VT_SOC_8KRAM_DG(config.replace(), m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); - - /* - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_dg_state::nes_vt_dg_map); - - m_screen->set_refresh_hz(50.0070); - m_screen->set_vblank_time(ATTOSECONDS_IN_USEC((106.53/(PAL_APU_CLOCK.dvalue()/1000000)) * - (ppu2c0x_device::VBLANK_LAST_SCANLINE_PAL-ppu2c0x_device::VBLANK_FIRST_SCANLINE+1+2))); - m_screen->set_size(32*8, 312); - m_screen->set_visarea(0*8, 32*8-1, 0*8, 30*8-1); - */ -} - -void nes_vt_dg_state::nes_vt_dg_1mb(machine_config& config) -{ - nes_vt_dg(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_dg_state::vt_external_space_map_1mbyte); -} - -void nes_vt_dg_state::nes_vt_dg_baddma_16mb(machine_config& config) -{ - nes_vt_dg(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_dg_state::vt_external_space_map_16mbyte); - -} - -void nes_vt_hh_state::nes_vt_vg(machine_config &config) -{ - nes_vt_dg(config); - - NES_VT_SOC_8KRAM_DG(config.replace(), m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); - - m_soc->force_bad_dma(); -} - -void nes_vt_hh_state::nes_vt_vg_8mb(machine_config& config) -{ - nes_vt_vg(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_8mbyte); -} - -void nes_vt_hh_state::nes_vt_vg_2mb(machine_config& config) -{ - nes_vt_vg(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_2mbyte); -} - -void nes_vt_hh_state::nes_vt_vg_4mb(machine_config& config) -{ - nes_vt_vg(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_4mbyte); -} - -void nes_vt_hh_state::nes_vt_vg_4mb_rasterhack(machine_config& config) -{ - nes_vt_vg_4mb(config); - m_soc->force_raster_timing_hack(); -} - - -void nes_vt_hh_state::nes_vt_vg_16mb(machine_config& config) -{ - nes_vt_vg(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_16mbyte); -} - - -// New mystery handheld architecture, VTxx derived -void nes_vt_hh_state::nes_vt_hh(machine_config &config) -{ - nes_vt_4k_ram(config); - - NES_VT_SOC_4KRAM_HH(config.replace(), m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); - - m_soc->set_default_palette_mode(PAL_MODE_NEW_RGB); - m_soc->force_bad_dma(); - - /* - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::nes_vt_hh_map); - - m_screen->set_refresh_hz(50.0070); - m_screen->set_vblank_time(ATTOSECONDS_IN_USEC((106.53/(PAL_APU_CLOCK.dvalue()/1000000)) * - (ppu2c0x_device::VBLANK_LAST_SCANLINE_PAL-ppu2c0x_device::VBLANK_FIRST_SCANLINE+1+2))); - m_screen->set_size(32*8, 312); - m_screen->set_visarea(0*8, 32*8-1, 0*8, 30*8-1); - */ -} - -void nes_vt_hh_state::nes_vt_hh_8mb(machine_config& config) -{ - nes_vt_hh(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_8mbyte); -} - -void nes_vt_hh_state::nes_vt_hh_4mb(machine_config& config) -{ - nes_vt_hh(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_4mbyte); -} - - void nes_vt_state::nes_vt_1mb_majkon(machine_config& config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); m_soc->set_addrmap(AS_PROGRAM, &nes_vt_state::vt_external_space_map_1mbyte_majkon); m_soc->force_raster_timing_hack(); @@ -1198,36 +711,6 @@ static INPUT_PORTS_START( nes_vt ) PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(2) PORT_8WAY INPUT_PORTS_END -static INPUT_PORTS_START( nes_vt_msi ) - PORT_START("IO0") - PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(1) PORT_NAME("A") - PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(1) PORT_NAME("B") - PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(1) - PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(1) - PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(1) PORT_8WAY - PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(1) PORT_8WAY - PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(1) PORT_8WAY - PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(1) PORT_8WAY - - PORT_START("IO1") - PORT_BIT( 0xff, IP_ACTIVE_HIGH, IPT_UNUSED ) -INPUT_PORTS_END - -static INPUT_PORTS_START( nes_vt_msi_mm2 ) - PORT_START("IO0") - PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(1) PORT_NAME("A") - PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(1) PORT_NAME("B") - PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(1) - PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(1) - PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(1) PORT_8WAY - PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(1) PORT_8WAY - PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(1) PORT_8WAY - PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(1) PORT_8WAY - - PORT_START("IO1") - PORT_BIT( 0xff, IP_ACTIVE_HIGH, IPT_UNUSED ) -INPUT_PORTS_END - static INPUT_PORTS_START( nes_vt_ddr ) PORT_START("IO0") PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_UNUSED ) @@ -1267,124 +750,12 @@ static INPUT_PORTS_START( dbdancem ) INPUT_PORTS_END -uint8_t nes_vt_hh_state::fcpocket_412d_r() -{ - if (m_cartsel) - return m_cartsel->read(); - else - return 0; -} - -void nes_vt_hh_state::fcpocket_412c_w(uint8_t data) -{ - // fcpocket - logerror("%s: vtfp_412c_extbank_w %02x\n", machine().describe_context(), data); - m_ahigh = (data & 0x01) ? (1 << 25) : 0x0; -} - -void nes_vt_hh_state::nes_vt_fp(machine_config &config) -{ - nes_vt_4k_ram(config); - - NES_VT_SOC_4KRAM_FP(config.replace(), m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); - - m_soc->set_default_palette_mode(PAL_MODE_NEW_RGB12); - m_soc->force_bad_dma(); -} - - - -void nes_vt_hh_state::nes_vt_fp_4x16mb(machine_config& config) -{ - nes_vt_fp(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_fp_2x32mbyte); - - dynamic_cast(*m_soc).upper_write_412c_callback().set(FUNC(nes_vt_hh_state::fcpocket_412c_w)); - dynamic_cast(*m_soc).upper_read_412d_callback().set(FUNC(nes_vt_hh_state::fcpocket_412d_r)); -} - -void nes_vt_hh_state::nes_vt_fp_32mb(machine_config& config) -{ - nes_vt_fp(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_32mbyte); -} - -void nes_vt_hh_state::nes_vt_fp_bigger(machine_config& config) -{ - nes_vt_fp(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_32mbyte); // must be some kind of banking, or this VT can address > 32Mbyte -} - -void nes_vt_hh_state::nes_vt_fp_16mb(machine_config& config) -{ - nes_vt_fp(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_16mbyte); -} - -void nes_vt_hh_state::nes_vt_fp_pal(machine_config &config) -{ - nes_vt_fp(config); - - // set to PAL -} - -void nes_vt_hh_state::nes_vt_fp_pal_32mb(machine_config& config) -{ - nes_vt_4k_ram(config); - - NES_VT_SOC_4KRAM_FP_PAL(config.replace(), m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); - - m_soc->set_default_palette_mode(PAL_MODE_NEW_RGB12); - m_soc->force_bad_dma(); - - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_hh_state::vt_external_space_map_32mbyte); -} - - -void nes_vt_dg_state::nes_vt_fa(machine_config& config) -{ - nes_vt_4k_ram(config); - - NES_VT_SOC_8KRAM_FA(config.replace(), m_soc, NTSC_APU_CLOCK); - configure_soc(m_soc); -} - - -uint8_t nes_vt_dg_state::fapocket_412c_r() -{ - if (m_cartsel) - return m_cartsel->read(); - else - return 0; -} - -void nes_vt_dg_state::fapocket_412c_w(uint8_t data) -{ - // fapocket (ok?) (also uses bank from config switch for fake cartridge slot) - logerror("%s: vtfa_412c_extbank_w %02x\n", machine().describe_context(), data); - m_ahigh = 0; - m_ahigh |= (data & 0x01) ? (1 << 25) : 0x0; - m_ahigh |= (data & 0x02) ? (1 << 24) : 0x0; -} - -void nes_vt_dg_state::nes_vt_fa_4x16mb(machine_config& config) // fapocket -{ - nes_vt_fa(config); - m_soc->set_addrmap(AS_PROGRAM, &nes_vt_dg_state::vt_external_space_map_fapocket_4x16mbyte); - - dynamic_cast(*m_soc).upper_read_412c_callback().set(FUNC(nes_vt_dg_state::fapocket_412c_r)); - dynamic_cast(*m_soc).upper_write_412c_callback().set(FUNC(nes_vt_dg_state::fapocket_412c_w)); -} - - void nes_vt_swap_op_d5_d6_state::nes_vt_vh2009(machine_config &config) { - NES_VT_SOC(config, m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); - NES_VT_SOC_SCRAMBLE(config.replace(), m_soc, NTSC_APU_CLOCK); + NES_VT02_VT03_SOC_SCRAMBLE(config.replace(), m_soc, NTSC_APU_CLOCK); configure_soc(m_soc); } @@ -1418,23 +789,7 @@ void nes_vt_swap_op_d5_d6_state::nes_vt_senwld_512kb(machine_config &config) m_soc->set_addrmap(AS_PROGRAM, &nes_vt_swap_op_d5_d6_state::vt_external_space_map_senwld_512kbyte); } -static INPUT_PORTS_START( nes_vt_fp ) - PORT_INCLUDE(nes_vt) - PORT_START("CARTSEL") - PORT_DIPNAME( 0x06, 0x00, "Cartridge Select" ) PORT_CODE(KEYCODE_3) PORT_TOGGLE - PORT_DIPSETTING( 0x00, "472-in-1" ) - PORT_DIPSETTING( 0x06, "128-in-1" ) -INPUT_PORTS_END - -static INPUT_PORTS_START( nes_vt_fa ) - PORT_INCLUDE(nes_vt) - - PORT_START("CARTSEL") - PORT_DIPNAME( 0x01, 0x00, "Cartridge Select" ) PORT_CODE(KEYCODE_3) PORT_TOGGLE - PORT_DIPSETTING( 0x00, "508-in-1" ) - PORT_DIPSETTING( 0x01, "130-in-1" ) -INPUT_PORTS_END static INPUT_PORTS_START( ablpinb ) @@ -1616,41 +971,6 @@ ROM_START( vtboxing ) ROM_LOAD( "rom.bin", 0x00000, 0x80000, CRC(c115b1af) SHA1(82106e1c11c3279c5d8731c112f713fa3f290125) ) ROM_END -ROM_START( msiwwe ) - ROM_REGION( 0x200000, "mainrom", 0 ) // the first half of this ROM is unused code from the Ms. Pac-Man game! - ROM_LOAD( "wrestlemania_es29lv160fb_004a2249.bin", 0x00000, 0x200000, CRC(f524382d) SHA1(0c8d1c29c76e3e3c58018354f1eca9445c9ab945) ) -ROM_END - -ROM_START( msiwwea ) - ROM_REGION( 0x100000, "mainrom", 0 ) - ROM_LOAD( "wrestlemania_en29lv800bb_007f225b.bin", 0x00000, 0x100000, CRC(52102de3) SHA1(f858ad18e05d3de24dfab4c98798efb4d30e2987) ) -ROM_END - -ROM_START( msidd ) - ROM_REGION( 0x200000, "mainrom", 0 ) - ROM_LOAD( "doubledragon_m29w160eb_00202249.bin", 0x00000, 0x200000, CRC(44df5bb6) SHA1(a984aa1644d2d313d4263afdfed1cd64009f1137) ) -ROM_END - -ROM_START( msimm2 ) - ROM_REGION( 0x400000, "mainrom", 0 ) - ROM_LOAD( "megaman2_s99jl032hbt1_001227e_readas_s29jl032h.bin", 0x00000, 0x400000, CRC(f537a053) SHA1(bd9353df34c0c0ee7d0e5e9808fc36f1a5eecc22) ) -ROM_END - -ROM_START( msimpac ) - ROM_REGION( 0x100000, "mainrom", 0 ) - ROM_LOAD( "mspacman_29dl800ba_000422cb.bin", 0x00000, 0x100000, CRC(c66300e3) SHA1(3fc0bdfbf449d884151f1b581e848243cd2df3a5) ) -ROM_END - -ROM_START( msisinv ) - ROM_REGION( 0x100000, "mainrom", 0 ) - ROM_LOAD( "spaceinvaders_en29lv800bb_007f225b.bin", 0x00000, 0x100000, CRC(e444d129) SHA1(33742bc3a6250337cc42b73812e797023818282a) ) -ROM_END - -ROM_START( msifrog ) - ROM_REGION( 0x400000, "mainrom", 0 ) - ROM_LOAD( "frogger_39vf3201_00bf235b.bin", 0x00000, 0x400000, CRC(c46c29c0) SHA1(b8f26445c2086b97db8ee98bf36dff9d63ca414b) ) -ROM_END - ROM_START( sudopptv ) ROM_REGION( 0x80000, "mainrom", ROMREGION_ERASEFF ) ROM_LOAD( "sudokupnptvgame_29lv400tc_000422b9.bin", 0x00000, 0x80000, CRC(722cc36d) SHA1(1f6d1f57478cf175a36722b39c52eded4b669f81) ) @@ -1661,110 +981,11 @@ ROM_START( mc_dgear ) ROM_LOAD( "dreamgear 75-in-1.prg", 0x00000, 0x400000, CRC(9aabcb8f) SHA1(aa9446b7777fa64503871225fcaf2a17aafd9af1) ) ROM_END -ROM_START( dgun2500 ) - ROM_REGION( 0x1000000, "mainrom", 0 ) - ROM_LOAD( "dgun2500.bin", 0x00000, 0x1000000, CRC(a2f963f3) SHA1(e29ed20ccdcf25b5640a607b3d2c9e6a4944e172) ) // 1ST AND 2ND HALF IDENTICAL - ROM_IGNORE(0x1000000) -ROM_END - -ROM_START( dgun2561 ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - ROM_LOAD( "dgun2561.bin", 0x00000, 0x4000000, CRC(a6e627b4) SHA1(2667d2feb02de349387f9dcfa5418e7ed3afeef6) ) -ROM_END - -ROM_START( dgun2593 ) - ROM_REGION( 0x8000000, "mainrom", 0 ) - ROM_LOAD( "dreamgear300.bin", 0x00000, 0x8000000, CRC(4fe0ed02) SHA1(a55590557bacca65ed9a17c5bcf0a4e5cb223126) ) -ROM_END - -ROM_START( rtvgc300 ) - ROM_REGION( 0x8000000, "mainrom", 0 ) - // some of the higher address lines might be swapped - ROM_LOAD( "lexibook300.bin", 0x00000, 0x4000000, CRC(015c4067) SHA1(a12986c4a366a23c4c7ca7b3d33e421a8dfdffc0) ) -ROM_END - -ROM_START( rtvgc300fz ) - ROM_REGION( 0x8000000, "mainrom", 0 ) - // some of the higher address lines might be swapped - ROM_LOAD( "jg7800fz.bin", 0x00000, 0x4000000, CRC(c9d319d2) SHA1(9d0d1435b802f63ce11b94ce54d11f4065b324cc) ) -ROM_END - -// The maximum address space a VT chip can see is 32MB, so these 64MB roms are actually 2 programs (there are vectors in the first half and the 2nd half) -// there must be a bankswitch bit that switches the whole 32MB space. Loading the 2nd half in Star Wars does actually boot straight to a game. -ROM_START( lxcmcy ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - ROM_LOAD( "lxcmcy.bin", 0x00000, 0x4000000, CRC(3f3af72c) SHA1(76127054291568fcce1431d21af71f775cfb05a6) ) -ROM_END - -ROM_START( lxcmcysw ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - ROM_LOAD( "jl2365swr-1.u2", 0x2000000, 0x2000000, CRC(60ece391) SHA1(655de6b36ba596d873de2839522b948ccf45e006) ) - ROM_CONTINUE(0x0000000, 0x2000000) -ROM_END - -ROM_START( lxcmcyfz ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - // sub-board was marked for 2GB capacity (A0-A26 address lines), but only address lines A0-A24 are connected to the chip - ROM_LOAD( "jl2365_frozen.u1", 0x00000, 0x4000000, CRC(64d4c708) SHA1(1bc2d161326ce3039ab9ba46ad62695060cfb2e1) ) -ROM_END - -ROM_START( lxcmcydp ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - // sub-board was marked for 2GB capacity (A0-A26 address lines), but only address lines A0-A24 are connected to the chip - ROM_LOAD( "cyberarcade-disneyprincess.bin", 0x00000, 0x4000000, CRC(05946f81) SHA1(33eea2b70f5427e7613c836b8a08148731fac231) ) -ROM_END - -ROM_START( lxcmcysp ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - // sub-board was marked for 2GB capacity (A0-A26 address lines), but only address lines A0-A24 are connected to the chip - ROM_LOAD( "lexibookspiderman.bin", 0x00000, 0x4000000, CRC(ef6e8847) SHA1(0012df193c52fd48595d85886fd431619c5d5e3e) ) -ROM_END - -ROM_START( lxcmcycr ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - ROM_LOAD( "lexibook cars.bin", 0x00000, 0x4000000, CRC(198fe11b) SHA1(5e35caa3fc319ec69812c187a3ec89f01749f749) ) -ROM_END - -ROM_START( lxcmcypp ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - // marked 512mbit, possible A22 / A23 are swapped as they were marked on the board in a different way. - ROM_LOAD( "pawpatrol_compact.bin", 0x00000, 0x4000000, CRC(bf536762) SHA1(80dde8426a636bae33a82d779e564fa743eb3776) ) -ROM_END - -ROM_START( lxcmc250 ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - // sub-board was marked for 2GB capacity (A0-A26 address lines), but only address lines A0-A24 are connected to the chip - ROM_LOAD( "cca250in1.u1", 0x00000, 0x4000000, CRC(6ccd6ad6) SHA1(fafed339097c3d1538faa306021a8373c1b799b3) ) -ROM_END - -ROM_START( lxccminn ) - ROM_REGION( 0x4000000, "mainrom", 0 ) // sub-board was hardwired to only be able to address the lower 64MByte, was rewired to also dump upper half when dumping, upper half contains only garbage, hence ROM_IGNORE - ROM_LOAD( "minnie_lexibook.bin", 0x00000, 0x4000000, CRC(3f8e5a69) SHA1(c9f11f3e5f9b73832a191f4d1620a85c1b70f79e) ) - ROM_IGNORE(0x4000000) -ROM_END - -ROM_START( lxccplan ) - ROM_REGION( 0x4000000, "mainrom", 0 ) // sub-board was hardwired to only be able to address the lower 64MByte, was rewired to also dump upper half when dumping, upper half contains only garbage, hence ROM_IGNORE - ROM_LOAD( "planes_lexibook.bin", 0x00000, 0x4000000, CRC(76e1a962) SHA1(83b801c0e0e941ceb1c93e565e833b07c09412c3)) - ROM_IGNORE(0x4000000) -ROM_END - -ROM_START( red5mam ) - ROM_REGION( 0x8000000, "mainrom", 0 ) - ROM_LOAD( "mam.u3", 0x00000, 0x8000000, CRC(0c0a0ecd) SHA1(2dfd8437de17fc9975698f1933dd81fbac78466d) ) -ROM_END - -ROM_START( cybar120 ) - ROM_REGION( 0x1000000, "mainrom", 0 ) - ROM_LOAD( "m2500p-vt09-epson,20091222ver05,_30r-sx1067-01_pcb,_12r0cob128m_12001-3d05_fw.bin", 0x00000, 0x1000000, CRC(f7138980) SHA1(de31264ee3a5a5c77a86733b2e2d6845fee91ea5) ) -ROM_END - ROM_START( sen101 ) ROM_REGION( 0x400000, "mainrom", 0 ) ROM_LOAD( "101n1.bin", 0x00000, 0x400000, CRC(b03e1824) SHA1(c9ac4e16220414c1aa679133191140ced9986e9c) ) ROM_END - ROM_START( mc_dg101 ) ROM_REGION( 0x400000, "mainrom", 0 ) ROM_LOAD( "dreamgear 101-in-1.prg", 0x00000, 0x400000, CRC(6a7cd8f4) SHA1(9a5ceb8e5e38eb93699dbb14c2c36f3a501d9c45) ) @@ -1785,28 +1006,16 @@ ROM_START( mc_sp69 ) ROM_LOAD( "sports game 69-in-1.prg", 0x00000, 0x400000, CRC(1242da7f) SHA1(bb8f99b1f4a4783b3f7e54d74f1f2a6a628da154) ) ROM_END -ROM_START( vsmaxtx2 ) - ROM_REGION( 0x400000, "mainrom", 0 ) - ROM_LOAD( "tx2.bin", 0x00000, 0x400000, CRC(eddf0ca8) SHA1(b87c5c3e945d1efdcb953325425d4ddb0fded00a) ) -ROM_END - ROM_START( vsmaxx17 ) ROM_REGION( 0x200000, "mainrom", 0 ) ROM_LOAD( "vsmaxx17.bin", 0x00000, 0x200000, CRC(f3fccbb9) SHA1(8b70b10d28f03e72f6b35199001955033a65fd5d) ) // M6MG3D641RB ROM_END -ROM_START( senario25 ) - ROM_REGION( 0x200000, "mainrom", 0 ) - ROM_LOAD( "senario25.bin", 0x00000, 0x200000, CRC(270c4517) SHA1(c099096d1c86f55f2b0826484cd3d3f68c90c794) ) -ROM_END - - ROM_START( dgun851 ) ROM_REGION( 0x400000, "mainrom", 0 ) ROM_LOAD( "dgun851.bin", 0x00000, 0x400000, CRC(9d51c9fc) SHA1(6f49ea3343eb6e90938aabc9660783f1fc7f6084) ) ROM_END - ROM_START( vsmaxx77 ) ROM_REGION( 0x800000, "mainrom", 0 ) ROM_LOAD( "vsmaxx77.bin", 0x00000, 0x800000, CRC(03f1f4b5) SHA1(13f7ecea3765cffcd3065de713abdabd24946b99) ) @@ -1817,16 +1026,6 @@ ROM_START( vsmaxxvd ) ROM_LOAD( "vsmaxxvideo.bin", 0x00000, 0x800000, CRC(af365a77) SHA1(8119fcef3e1a2ade93d36740d5df451919f0e541) ) ROM_END -ROM_START( dturbogt ) - ROM_REGION( 0x800000, "mainrom", 0 ) - ROM_LOAD( "dgturbogt.bin", 0x00000, 0x800000, CRC(9532fb78) SHA1(cd188672f9b8e9c12069612ad0d0b70d3dd6c1b1) ) -ROM_END - -ROM_START( rcapnp ) - ROM_REGION( 0x200000, "mainrom", 0 ) - ROM_LOAD( "rcapnp_mx29lv160ab_00c22249.bin", 0x00000, 0x200000, CRC(8cc30a47) SHA1(815bfc26360b01ed3fa077016222939d2184408c) ) -ROM_END - ROM_START( polmega ) ROM_REGION( 0x400000, "mainrom", 0 ) ROM_LOAD( "megamax.bin", 0x00000, 0x400000, CRC(ef3aade3) SHA1(0c130080ace000cbe43e70a805d4301e05840294) ) @@ -1837,11 +1036,6 @@ ROM_START( silv35 ) ROM_LOAD( "silverlit35.bin", 0x00000, 0x400000, CRC(7540e350) SHA1(a0cb456136560fa4d8a365dd44d815ec0e9fc2e7) ) ROM_END -ROM_START( ventur25 ) - ROM_REGION( 0x400000, "mainrom", 0 ) - ROM_LOAD( "25games_m5m29gt320vp_001c0020.bin", 0x00000, 0x400000, CRC(3f78a45a) SHA1(3e97333c13e09c580e66518dd2e1e031371d399c) ) -ROM_END - ROM_START( sporzpp ) ROM_REGION( 0x400000, "mainrom", 0 ) ROM_LOAD( "gamesporzduetpingpong.bin", 0x00000, 0x400000, CRC(96af199b) SHA1(c14ff15683545c1edf03376cebcee7ac408da733) ) @@ -1867,11 +1061,6 @@ ROM_START( solargm ) ROM_LOAD( "solargames.bin", 0x00000, 0x800000, CRC(b49f0985) SHA1(68231614b333911c25168c533f1ae9bc79c36c38) ) ROM_END -ROM_START( lpgm240 ) - ROM_REGION( 0x800000, "mainrom", 0 ) - ROM_LOAD( "w25q64jv.u1", 0x00000, 0x800000, CRC(b973e65b) SHA1(36ff137068ea56b4679c2db386ac0067de0a9eaf) ) -ROM_END - ROM_START( pjoyn50 ) ROM_REGION( 0x400000, "mainrom", 0 ) ROM_LOAD( "power joy navigator 50-in-1.prg", 0x00000, 0x400000, CRC(d1bbadd4) SHA1(2186c71bcedf6c2eedf58233faa26fca9586aa40) ) @@ -1951,11 +1140,6 @@ ROM_START( mc_dcat8a ) ROM_LOAD( "s29gl064.u6", 0x00000, 0x800000, CRC(e28b1ef8) SHA1(4a6f107d2189cbe1bb0b86b3738d0af58e24e0f7) ) ROM_END -ROM_START( vgtablet ) - ROM_REGION( 0x400000, "mainrom", 0 ) - ROM_LOAD( "vgtablet.bin", 0x00000, 0x400000, CRC(99ef3978) SHA1(0074445708d66a04ab02b4993069ce1ae0514c2f) ) -ROM_END - ROM_START( gprnrs1 ) ROM_REGION( 0x800000, "mainrom", 0 ) ROM_LOAD( "gprnrs1.bin", 0x00000, 0x800000, CRC(c3ffcec8) SHA1(313a790fb51d0b155257f9de84726ed67da43a8f) ) @@ -1966,28 +1150,6 @@ ROM_START( gprnrs16 ) ROM_LOAD( "gprnrs16.bin", 0x00000, 0x2000000, CRC(bdffa40a) SHA1(3d01907211f18e8415171dfc6c1d23cf5952e7bb) ) ROM_END -ROM_START( vgpocket ) - ROM_REGION( 0x400000, "mainrom", 0 ) - ROM_LOAD( "vgpocket.bin", 0x00000, 0x400000, CRC(843634c6) SHA1(c59dab0e43d364f59eb3a138abb585bc54e5d674) ) - // there was a dump of a 'secure' area with this, but it was just the top 0x10000 bytes of the existing rom. -ROM_END - -ROM_START( vgpmini ) - ROM_REGION( 0x400000, "mainrom", 0 ) - ROM_LOAD( "vgpmini.bin", 0x00000, 0x400000, CRC(a1121843) SHA1(c96013ae6cf2f8173e65a167d45685cb61536d36) ) - // there was a dump of a 'secure' area with this, but it was just the bottom 0x10000 bytes of the existing rom. -ROM_END - -ROM_START( sy889 ) - ROM_REGION( 0x800000, "mainrom", 0 ) - ROM_LOAD( "sy889_w25q64.bin", 0x00000, 0x800000, CRC(fcdaa6fc) SHA1(0493747facf2172b8af22010851668bb18cbb3e4) ) -ROM_END - -ROM_START( sy888b ) - ROM_REGION( 0x400000, "mainrom", 0 ) - ROM_LOAD( "sy888b_f25q32.bin", 0x00000, 0x400000, CRC(a8298c33) SHA1(7112dd13d5fb5f9f9d496816758defd22773ec6e) ) -ROM_END - ROM_START( ddrdismx ) ROM_REGION( 0x200000, "mainrom", 0 ) ROM_LOAD( "disney-ddr.bin", 0x00000, 0x200000, CRC(17fb3abb) SHA1(4d0eda4069ff46173468e579cdf9cc92b350146a) ) // 29LV160 Flash @@ -1998,7 +1160,6 @@ ROM_START( dbdancem ) ROM_LOAD( "dancemania_29lv160bt_00c222a7.bin", 0x00000, 0x200000, CRC(7250a837) SHA1(7205936215df84e3642c34a8b5991e8125da1785) ) ROM_END - ROM_START( megapad ) ROM_REGION( 0x200000, "mainrom", 0 ) ROM_LOAD( "megapad.bin", 0x00000, 0x200000, CRC(1eb603a8) SHA1(3de6f0620a0db0558daa7fd7ccf08d9d5607a6af) ) @@ -2029,7 +1190,6 @@ ROM_START( majgnc ) ROM_LOAD( "majescogoldennuggetcasino_st29w800at_002000d7.bin", 0x00000, 0x100000, CRC(1a156a9d) SHA1(08be4079dd68c9cf05bb92e11a3da4f092d7cfea) ) ROM_END - ROM_START( zudugo ) ROM_REGION( 0x400000, "mainrom", ROMREGION_ERASEFF ) ROM_LOAD( "zudugo.bin", 0x00000, 0x400000, CRC(0fa9d9ad) SHA1(7533eaf51785d8fcced900ea0498281b0cf49dbf) ) @@ -2040,49 +1200,11 @@ ROM_START( ablping ) ROM_LOAD( "abl_pingpong.bin", 0x00000, 0x200000, CRC(b31de1fb) SHA1(94e8afb2315ba1fa0892191c8e1832391e401c70) ) ROM_END - - - -ROM_START( dgun2573 ) // this one lacked a DreamGear logo but was otherwise physically identical, is it a clone product or did DreamGear drop the logo in favor of just using the 'My Arcade' brand? - ROM_REGION( 0x2000000, "mainrom", 0 ) - ROM_LOAD( "myarcadegamerportable_s29gl256p10tfi01_0001227e.bin", 0x00000, 0x2000000, CRC(8f8c8da7) SHA1(76a18458922e39abe1982f05f184babb5e65acf2) ) -ROM_END - -ROM_START( dgun2573a ) - ROM_REGION( 0x2000000, "mainrom", 0 ) - ROM_LOAD( "myarcadegamerportabledreamgear_s29gl256p10tfi01_0001227e.bin", 0x00000, 0x2000000, CRC(928c41ad) SHA1(c0119a13a47a5b784d0b834d1451973ff0b4a84f) ) -ROM_END - -ROM_START( bittboy ) - ROM_REGION( 0x2000000, "mainrom", 0 ) - ROM_LOAD( "bittboy_flash_read_s29gl256n-tf-v2.bin", 0x00000, 0x2000000, CRC(24c802d7) SHA1(c1300ff799b93b9b53060b94d3985db4389c5d3a) ) -ROM_END - ROM_START( mc_89in1 ) ROM_REGION( 0x400000, "mainrom", 0 ) ROM_LOAD( "89in1.bin", 0x00000, 0x400000, CRC(b97f8ce5) SHA1(1a8e67f2b58a671ceec2b0ed18ec5954a71ae63a) ) ROM_END -ROM_START( mc_cb280 ) - ROM_REGION( 0x400000, "mainrom", 0 ) - ROM_LOAD( "w25q32.u5", 0x00000, 0x400000, CRC(c9541bdf) SHA1(f0ce46f18658ca5dbed881e5a80460e59820bbd0) ) -ROM_END - -ROM_START( mc_pg150 ) - ROM_REGION( 0x2000000, "mainrom", 0 ) - ROM_LOAD( "pocketgames150-in1.bin", 0x00000, 0x2000000, CRC(32f1176b) SHA1(2cfd9b61ebdfc328f020ae9bd5e5e2219321e828) ) -ROM_END - -ROM_START( mc_hh210 ) - ROM_REGION( 0x1000000, "mainrom", 0 ) - ROM_LOAD( "msp55lv128t.u4", 0x00000, 0x1000000, CRC(9ba520d4) SHA1(627f811b24314197e289a2ade668ff4115421bed) ) -ROM_END - -ROM_START( dvnimbus ) - ROM_REGION( 0x1000000, "mainrom", 0 ) - ROM_LOAD( "2012-7-4-v1.bin", 0x00000, 0x1000000, CRC(a91d7aa6) SHA1(9421b70b281bb630752bc352c3715258044c0bbe) ) -ROM_END - ROM_START( cbrs8 ) ROM_REGION( 0x1000000, "mainrom", 0 ) ROM_LOAD( "rs-8.bin", 0x00000, 0x1000000, BAD_DUMP CRC(10b2bed0) SHA1(0453a1e6769818ccf25dcf22b2c6198a5688a1d4) ) @@ -2113,78 +1235,27 @@ ROM_START( techni4 ) ROM_LOAD( "technigame.bin", 0x00000, 0x200000, CRC(3c96b1b1) SHA1(1acc81b26e740327bd6d9faa5a96ab027a48dd77) ) ROM_END - ROM_START( protpp ) ROM_REGION( 0x100000, "mainrom", 0 ) ROM_LOAD( "vpingpong_s29al008d70tfi02_0001225b.bin", 0x00000, 0x100000, CRC(8cf46272) SHA1(298a6341d26712ec1f282e7514e995a7af5ac012) ) ROM_END -ROM_START( unkra200 ) // "Winbond 25Q64FVSIG 1324" SPI ROM - ROM_REGION( 0x800000, "mainrom", 0 ) - ROM_LOAD( "retro_machine_rom", 0x00000, 0x800000, CRC(0e824aa7) SHA1(957e98868559ecc22b3fa42c76692417b76bf132) ) -ROM_END - -ROM_START( rminitv ) - ROM_REGION( 0x2000000, "mainrom", 0 ) - ROM_LOAD( "29gl256.bin", 0x00000, 0x2000000, CRC(cb4048d4) SHA1(9877ce5716d13f8498abfc1cbfaefa9426205d3e) ) -ROM_END - -ROM_START( denv150 ) - ROM_REGION( 0x1000000, "mainrom", 0 ) - ROM_LOAD( "denver150in1.bin", 0x00000, 0x1000000, CRC(6b3819d7) SHA1(b0039945ce44a52ea224ab736d5f3c6980409b5d) ) // 2nd half is blank -ROM_END - - -ROM_START( ppgc200g ) - ROM_REGION( 0x800000, "mainrom", 0 ) - ROM_LOAD( "m29dw641.u2", 0x00000, 0x800000, CRC(b16dc677) SHA1(c1984fde4caf9345d41d127db946d1c21ec43ae0) ) -ROM_END - - - -ROM_START( mog_m320 ) - ROM_REGION( 0x800000, "mainrom", 0 ) - ROM_LOAD( "w25q64fv.bin", 0x00000, 0x800000, CRC(3c5e1b36) SHA1(4bcbf35ebf2b1714ccde5de758a89a6a39528f89) ) -ROM_END - -ROM_START( fcpocket ) - ROM_REGION( 0x8000000, "mainrom", 0 ) - ROM_LOAD( "s29gl01gp.bin", 0x00000, 0x8000000, CRC(8703b18a) SHA1(07943443294e80ca93f83181c8bdbf950b87c52f) ) // 2nd half = 0x00 (so 64MByte of content) -ROM_END - -ROM_START( fapocket ) - ROM_REGION( 0x4000000, "mainrom", 0 ) - ROM_LOAD( "s29gl512n.bin", 0x00000, 0x4000000, CRC(37d0fb06) SHA1(0146a2fae32e23b65d4032c508f0d12cedd399c3) ) -ROM_END - ROM_START( zdog ) ROM_REGION( 0x400000, "mainrom", 0 ) ROM_LOAD( "zdog.bin", 0x00000, 0x400000, CRC(5ed3485b) SHA1(5ab0e9370d4ed1535205deb0456878c4e400dd81) ) ROM_END -ROM_START( otrail ) - ROM_REGION( 0x100000, "mainrom", 0 ) - ROM_LOAD( "g25q80cw.bin", 0x00000, 0x100000, CRC(b20a03ba) SHA1(c4ca8e590b07baaebed747537bc8f92e44bdd219) ) // dumped as QD25Q80C - - ROM_REGION( 0x200, "seeprom", 0 ) - ROM_LOAD( "t24c04a.bin", 0x000, 0x200, CRC(ce1fad6f) SHA1(82878996765739edba42042b6336460d5c8f8096) ) -ROM_END - -ROM_START( zonefusn ) +ROM_START( dgun2500 ) ROM_REGION( 0x1000000, "mainrom", 0 ) - ROM_LOAD( "fusion.bin", 0x00000, 0x1000000, CRC(240bf970) SHA1(1b82d95a252c08e52fb8da6320276574a30b60db) ) + ROM_LOAD( "dgun2500.bin", 0x00000, 0x1000000, CRC(a2f963f3) SHA1(e29ed20ccdcf25b5640a607b3d2c9e6a4944e172) ) // 1ST AND 2ND HALF IDENTICAL + ROM_IGNORE(0x1000000) ROM_END -void nes_vt_cy_lexibook_state::init_lxcmcypp() -{ - int size = memregion("mainrom")->bytes()/2; - uint16_t* ROM = (uint16_t*)memregion("mainrom")->base(); +ROM_START( ppgc200g ) + ROM_REGION( 0x800000, "mainrom", 0 ) + ROM_LOAD( "m29dw641.u2", 0x00000, 0x800000, CRC(b16dc677) SHA1(c1984fde4caf9345d41d127db946d1c21ec43ae0) ) +ROM_END - for (int i = 0; i < size; i++) - { - ROM[i] = bitswap<16>(ROM[i], 4, 5, 6, 7, 0, 1, 2, 3, 12, 13, 14, 15, 8, 9, 10, 11); - } -} void nes_vt_state::init_protpp() { @@ -2224,27 +1295,6 @@ CONS( 200?, vtsndtest, 0, 0, nes_vt_512kb, nes_vt, nes_vt_state, empty_init // Bundled as "Demo for VT03 Pic32" on the V.R. Technology VT SDK CONS( 200?, vtboxing, 0, 0, nes_vt_512kb, nes_vt, nes_vt_state, empty_init, "VRT", "VRT VT SDK 'Boxing' (Demo for VT03 Pic32)", MACHINE_NOT_WORKING ) -// MSI Entertainment games (MSI previously operated as Majesco Entertainment) - -// There are meant to be multiple revisions of this software, some with theme tunes for the new wrestlers, some without. This one appears to lack them. -// 2 box variations exist, one with Randy Savage in purple attire and another with green, this was dumped from a unit with purple on the box. -CONS( 2017, msiwwe, 0, 0, nes_vt_2mb_baddma, nes_vt_msi, nes_vt_state, empty_init, "MSI", "WWE Wrestlemania Steel Cage Challenge (Plug & Play) (set 1)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -// this one was dumped from the version with Randy Savage in green, the box was much larger than the other one. This one also has new theme music for the adjusted roster. -CONS( 2017, msiwwea, msiwwe, 0, nes_vt_1mb_baddma, nes_vt_msi, nes_vt_state, empty_init, "MSI", "WWE Wrestlemania Steel Cage Challenge (Plug & Play) (set 2)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) - -CONS( 2017, msidd, 0, 0, nes_vt_2mb_baddma, nes_vt_msi, nes_vt_state, empty_init, "MSI / Arc System Works", "Double Dragon - 30 Years Anniversary (Plug & Play)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) - -CONS( 2016, msimpac, 0, 0, nes_vt_1mb_baddma, nes_vt_msi, nes_vt_state, empty_init, "MSI / Bandai Namco", "Ms. Pac-Man (MSI Plug & Play)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) - -CONS( 2017, msimm2, 0, 0, nes_vt_4mb_baddma, nes_vt_msi_mm2, nes_vt_state, empty_init, "MSI / Capcom", "Mega Man 2 (MSI Plug & Play)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // various issues (glitched Metal Man stage boss, missing 'ready' text) happen on real unit - -CONS( 2016, msisinv, 0, 0, nes_vt_1mb_baddma, nes_vt_msi, nes_vt_state, empty_init, "MSI / Taito", "Space Invaders (MSI Plug & Play)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) - -// This is from the version with the same case type as the above MSI units. -// MSI also issued a version in the original Majesco shell but with the updated case logos and boot logos in the software, the software on that revision might match this one. -CONS( 2016, msifrog, 0, 0, nes_vt_4mb_baddma_rasterhack, nes_vt_msi, nes_vt_state, empty_init, "MSI / Konami", "Frogger (MSI Plug & Play, white joystick)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // raster timing for need a hack - -// MSI Midway (Joust+Gauntlet 2 + Defender 2) has 2x Globs, rather than Glob + Flash ROM // Menu system clearly started off as 'vtpinball' Many elements seem similar to Family Pinball for the Famicom. // 050329 (29th March 2005) date on PCB @@ -2283,31 +1333,10 @@ CONS( 200?, timetp36, 0, 0, nes_vt_pal_4mb, timetp36, nes_vt_timetp36_state, CONS( 200?, timetp7, 0, 0, nes_vt_pal_2mb, timetp36, nes_vt_timetp36_state, empty_init, "TimeTop", "Super Game 7-in-1 (TimeTop SuperGame) (PAL)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -// Runs fine, non-sport 121 in 1 games perfect, but minor graphical issues in -// sport games, also no sound in menu or sport games due to missing PCM -// emulation -CONS( 200?, dgun2500, 0, 0, nes_vt_dg_baddma_16mb, nes_vt, nes_vt_dg_state, empty_init, "dreamGEAR", "dreamGEAR Wireless Motion Control with 130 games (DGUN-2500)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND) - -// all software in this runs in the VT03 enhanced mode, it also includes an actual licensed VT03 port of Frogger. -// all games work OK except Frogger which has serious graphical issues -CONS( 2006, vgtablet, 0, 0, nes_vt_vg_4mb_rasterhack, nes_vt, nes_vt_hh_state, empty_init, "Performance Designed Products (licensed by Konami) / JungleTac", "VG Pocket Tablet (VG-4000)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // raster timing for Frogger needs a hack -// There is a 2004 Majesco Frogger "TV game" that appears to contain the same version of Frogger as above but with no other games, so probably fits here. CONS( 2004, majkon, 0, 0, nes_vt_1mb_majkon, nes_vt, nes_vt_state, empty_init, "Majesco (licensed from Konami) / JungleTac", "Konami Collector's Series Arcade Advanced", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // raster timing for Frogger needs a hack, Rush'n Attack also has raster timing issues on the status bar split -CONS( 200?, majgnc, 0, 0, nes_vt_vg_1mb_majgnc, majgnc, nes_vt_vg_1mb_majgnc_state, empty_init, "Majesco / JungleTac", "Golden Nugget Casino", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +CONS( 200?, majgnc, 0, 0, nes_vt_1mb, majgnc, nes_vt_state, empty_init, "Majesco / JungleTac", "Golden Nugget Casino", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -// this is VT09 based -CONS( 2009, cybar120, 0, 0, nes_vt_vg_16mb,nes_vt, nes_vt_hh_state, empty_init, "Defender / JungleTac", "Defender M2500P 120-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -CONS( 200?, vsmaxtx2, 0, 0, nes_vt_vg_4mb, nes_vt, nes_vt_hh_state, empty_init, "Senario / JungleTac", "Vs Maxx TX-2 50-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -CONS( 200?, senario25, 0, 0, nes_vt_vg_2mb, nes_vt, nes_vt_hh_state, empty_init, "Senario / JungleTac", "25 Video Games - All in 1 Video System (Senario)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // no Vs Maxx branding, newer style packaging -CONS( 200?, rcapnp, 0, 0, nes_vt_vg_2mb, nes_vt, nes_vt_hh_state, empty_init, "RCA / JungleTac", "RCA NS-500 30-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -CONS( 200?, dturbogt, 0, 0, nes_vt_vg_8mb, nes_vt, nes_vt_hh_state, empty_init, "dreamGEAR / JungleTac", "Turbo GT 50-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -CONS( 200?, ventur25, 0, 0, nes_vt_vg_4mb, nes_vt, nes_vt_hh_state, empty_init, " / JungleTac", "Venturer '25 Games' 25-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -CONS( 2005, vgpocket, 0, 0, nes_vt_vg_4mb, nes_vt, nes_vt_hh_state, empty_init, "Performance Designed Products / JungleTac", "VG Pocket (VG-2000)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -CONS( 200?, vgpmini, 0, 0, nes_vt_vg_4mb, nes_vt, nes_vt_hh_state, empty_init, "Performance Designed Products / JungleTac", "VG Pocket Mini (VG-1500)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -// VG Pocket Max (VG-2500) (blue case, 75 games) -// VG Pocket Max (VG-3000) (white case, 75 games) (does the game selection differ, or only the case?) -// VG Pocket Caplet is SunPlus hardware instead, see spg2xx_lexibook.cpp // CPU die is marked 'VH2009' There's also a 62256 RAM chip on the PCB, some scrambled opcodes CONS( 2004, vsmaxx17, 0, 0, nes_vt_vh2009_2mb, nes_vt, nes_vt_swap_op_d5_d6_state, empty_init, "Senario / JungleTac", "Vs Maxx 17-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // from a Green unit, '17 Classic & Racing Game' @@ -2319,6 +1348,7 @@ CONS( 200?, vsmaxx77, 0, 0, nes_vt_vh2009_8mb, nes_vt, nes_vt_swap_op_ // die is marked as VH2009, as above, but no scrambled opcodes here CONS( 201?, techni4, 0, 0, nes_vt_pal_2mb, nes_vt, nes_vt_state, empty_init, "Technigame", "Technigame Super 4-in-1 Sports (PAL)", MACHINE_IMPERFECT_GRAPHICS ) +CONS( 2005, senwld, 0, 0, nes_vt_senwld_512kb, nes_vt, nes_vt_swap_op_d5_d6_state, empty_init, "Senario", "Win, Lose or Draw (Senario)", MACHINE_NOT_WORKING | MACHINE_IMPERFECT_GRAPHICS ) // needs RAM in banked space, Alpha display emulating, Touchpad emulating etc. // seems to use PCM for all sound, some garbage at bottom of screen, needs correct inputs (seems to respond to start, and any direction input for 'hit' - check if they're power related) CONS( 200?, protpp, 0, 0, nes_vt_vh2009_1mb, nes_vt, nes_vt_swap_op_d5_d6_state, init_protpp, "Protocol", "Virtual Ping Pong (Protocol)", MACHINE_NOT_WORKING | MACHINE_NO_SOUND ) @@ -2381,122 +1411,20 @@ CONS( 200?, mc_8x6ss, 0, 0, nes_vt_1mb, nes_vt, nes_vt_state, empty CONS( 2004, mc_dcat8, 0, 0, nes_vt_8mb, nes_vt, nes_vt_state, empty_init, "", "100 in 1 (D-CAT8 8bit Console, set 1) (v5.01.11-frd, BL 20041217)", MACHINE_IMPERFECT_GRAPHICS ) CONS( 2004, mc_dcat8a, mc_dcat8, 0, nes_vt_8mb, nes_vt, nes_vt_state, empty_init, "", "100 in 1 (D-CAT8 8bit Console, set 2)", MACHINE_IMPERFECT_GRAPHICS ) -// Runs well, only issues in SMB3 which crashes -CONS( 2017, bittboy, 0, 0, nes_vt_bt_2x16mb, nes_vt, nes_vt_cy_state, empty_init, "BittBoy", "BittBoy Mini FC 300 in 1", MACHINE_IMPERFECT_GRAPHICS ) // has external banking (2x 16mbyte banks) // Runs well, all games seem to work CONS( 201?, mc_89in1, 0, 0, nes_vt_4mb, nes_vt, nes_vt_state, empty_init, "", "89 in 1 Mini Game Console (060-92023011V1.0)", MACHINE_IMPERFECT_GRAPHICS ) -// Broken GFX, investigate -CONS( 201?, mc_pg150, 0, 0, nes_vt_bt_2x16mb, nes_vt, nes_vt_cy_state, empty_init, "", "Pocket Games 150 in 1", MACHINE_NOT_WORKING ) // has external banking -// No title screen, but press start and menu and games run fine. Makes odd -// memory accesses which probably explain broken title screen -CONS( 201?, mc_hh210, 0, 0, nes_vt_4k_ram_16mb, nes_vt, nes_vt_state, empty_init, "", "Handheld 210 in 1", MACHINE_NOT_WORKING ) -// First half of games don't work, probably bad dump -CONS( 201?, dvnimbus, 0, 0, nes_vt_vg_16mb, nes_vt, nes_vt_hh_state, empty_init, "", "DVTech Nimbus 176 in 1", MACHINE_NOT_WORKING ) -// Works fine, VT02 based + +// Works fine, uses ony VT02 features CONS( 201?, mc_tv200, 0, 0, nes_vt_8mb, nes_vt, nes_vt_state, empty_init, "Thumbs Up", "200 in 1 Retro TV Game", MACHINE_IMPERFECT_GRAPHICS ) - // probably another Thumbs Up product? cursor doesn't work unless nes_vt_hh machine is used? possibly newer than VT02 as it runs from an SPI ROM, might just not use enhanced features. Some minor game name changes to above (eg Smackdown just becomes Wrestling) -CONS( 201?, unkra200, mc_tv200, 0, nes_vt_hh_8mb, nes_vt, nes_vt_hh_state, empty_init, "", "200 in 1 Retro Arcade", MACHINE_IMPERFECT_GRAPHICS ) + + +// Runs fine, non-sport 121 in 1 games perfect, but minor graphical issues in +// sport games, also no sound in menu or sport games due to missing PCM +// emulation +CONS( 200?, dgun2500, 0, 0, nes_vt_16mb, nes_vt, nes_vt_state, empty_init, "dreamGEAR", "dreamGEAR Wireless Motion Control with 130 games (DGUN-2500)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND) // available in a number of colours, with various brands, but likely all the same. // This was a red coloured pad, contains various unlicensed bootleg reskinned NES game eg Blob Buster is a hack of Dig Dug 2 and there are also hacks of Xevious, Donkey Kong Jr, Donkey Kong 3 and many others. -CONS( 201?, ppgc200g, 0, 0, nes_vt_8mb, nes_vt, nes_vt_state, empty_init, "", "Plug & Play Game Controller with 200 Games (Supreme 200)", MACHINE_IMPERFECT_GRAPHICS ) - -// Probably VT09 or similar -// Use DIP switch to select console or cartridge, as cartridge is fake and just toggles a ROM high address bit -// (which can also be overriden by GPIO) -CONS( 2017, fapocket, 0, 0, nes_vt_fa_4x16mb, nes_vt_fa, nes_vt_dg_fapocket_state, empty_init, "", "Family Pocket 638 in 1", MACHINE_IMPERFECT_GRAPHICS ) // has external banking (4x 16mbyte banks) - -CONS( 2005, senwld, 0, 0, nes_vt_senwld_512kb, nes_vt, nes_vt_swap_op_d5_d6_state, empty_init, "Senario", "Win, Lose or Draw (Senario)", MACHINE_NOT_WORKING | MACHINE_IMPERFECT_GRAPHICS ) // needs RAM in banked space, Alpha display emulating, Touchpad emulating etc. - -// Runs well, minor GFX issues in intro -CONS( 2017, sy889, 0, 0, nes_vt_hh_8mb, nes_vt, nes_vt_hh_state, empty_init, "SY Corp", "SY-889 300 in 1 Handheld", MACHINE_IMPERFECT_GRAPHICS ) -CONS( 2016, sy888b, 0, 0, nes_vt_hh_4mb, nes_vt, nes_vt_hh_state, empty_init, "SY Corp", "SY-888B 288 in 1 Handheld", MACHINE_IMPERFECT_GRAPHICS ) - -// Same hardware as SY-889 -CONS( 201?, mc_cb280, 0, 0, nes_vt_hh_4mb, nes_vt, nes_vt_hh_state, empty_init, "CoolBoy", "Coolboy RS-18 (280 in 1)", MACHINE_IMPERFECT_GRAPHICS ) - -// Plays intro music but then crashes. same hardware as SY-88x but uses more features -CONS( 2016, mog_m320, 0, 0, nes_vt_hh_8mb, nes_vt, nes_vt_hh_state, empty_init, "MOGIS", "MOGIS M320 246 in 1 Handheld", MACHINE_NOT_WORKING ) - - -// similar menus to above, but with opcode scrambling -CONS( 2015, dgun2573, 0, 0, nes_vt_fp_32mb, nes_vt, nes_vt_hh_state, empty_init, "dreamGEAR", "My Arcade Gamer V Portable Gaming System (DGUN-2573) (set 1, newer)", MACHINE_WRONG_COLORS | MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) -CONS( 2015, dgun2573a, dgun2573, 0, nes_vt_fp_32mb, nes_vt, nes_vt_hh_state, empty_init, "dreamGEAR", "My Arcade Gamer V Portable Gaming System (DGUN-2573) (set 2, older)", MACHINE_WRONG_COLORS | MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // some menu graphics haven't been updated to reflect 'Panda' theme to the sports games - -CONS( 2015, rminitv, 0, 0, nes_vt_fp_pal_32mb, nes_vt, nes_vt_hh_state, empty_init, "Orb Gaming", "Retro 'Mini TV' Console 300-in-1", MACHINE_IMPERFECT_GRAPHICS ) // single 32Mbyte bank! -// New platform with scrambled opcodes, same as DGUN-2561. Runs fine with minor GFX and sound issues in menu -// Use DIP switch to select console or cartridge, as cartridge is fake and just toggles a GPIO -CONS( 2016, fcpocket, 0, 0, nes_vt_fp_4x16mb, nes_vt_fp, nes_vt_hh_state, empty_init, "", "FC Pocket 600 in 1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // has external banking (2x 32mbyte banks) - - -/**************************************************************************************************************** - - Things below seem on heavily enhanced hardware of unknown VT type - - It's possible some of these are the same as some of the ones above (sy889, rminitv, dgun2573 etc.) but with - more features used. - - In some cases these might be almost entirely different, and it is likely a number don't belong in this - driver at all. - -****************************************************************************************************************/ - -// don't even get to menu. very enhanced chipset, VT368/9? -CONS( 2012, dgun2561, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "dreamGEAR", "My Arcade Portable Gaming System with 140 Games (DGUN-2561)", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme -CONS( 2016, dgun2593, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "dreamGEAR", "My Arcade Retro Arcade Machine - 300 Handheld Video Games (DGUN-2593)", MACHINE_NOT_WORKING ) // 128Mbyte ROM, must be externally banked or different addressing scheme - -CONS( 200?, lxcmcy, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme -CONS( 200?, lxcmc250, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - 250-in-1 (JL2375)", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme -CONS( 200?, lxcmcysw, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Star Wars Rebels", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme -CONS( 200?, lxcmcyfz, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Frozen", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme -CONS( 200?, lxcmcydp, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Disney Princess", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme -CONS( 200?, lxcmcysp, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Marvel Ultimate Spider-Man", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme -CONS( 200?, lxcmcycr, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Cars", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme -// the data order is swapped for this one, maybe other internal differences? -CONS( 200?, lxcmcypp, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, init_lxcmcypp, "Lexibook", "Lexibook Compact Cyber Arcade - Paw Patrol", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme - - -CONS( 200?, lxccminn, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Console Colour - Minnie Mouse", MACHINE_NOT_WORKING ) // 64Mbyte (used) ROM, must be externally banked, or different addressing scheme -CONS( 200?, lxccplan, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Console Colour - Disney's Planes", MACHINE_NOT_WORKING ) // 64Mbyte (used) ROM, must be externally banked, or different addressing scheme - - -// GB-NO13-Main-VT389-2 on PCBs -CONS( 2016, rtvgc300, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Retro TV Game Console - 300 Games", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme -CONS( 2017, rtvgc300fz,0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Lexibook", "Lexibook Retro TV Game Console - Frozen - 300 Games", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme - - -/* The following are also confirmed to be NES/VT derived units, most having a standard set of games with a handful of lazy graphic mods thrown in to fit the unit theme - - (handheld units, use standard AAA batteries) - Lexibook Compact Cyber Arcade - Barbie - Lexibook Compact Cyber Arcade - Finding Dory - Lexibook Compact Cyber Arcade - PJ Masks - - (Handheld units, but different form factor to Compact Cyber Arcade, charged via USB) - Lexibook Console Colour - Barbie - - (units for use with TV) - Lexibook Retro TV Game Console (300 Games) - Cars - Lexibook Retro TV Game Console (300 Games) - PJ Masks - - (more?) - - There are also updated 'Compact Cyber Arcade' branded units with a large + D-pad and internal battery / USB charger for - Spiderman - Frozen - (generic) - it isn't verified if these use the same ROMs as the original Compact Cyber Arcade releases, or if the software has been updated - -*/ - -// intial code isn't valid? scrambled? -CONS( 201?, red5mam, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Red5", "Mini Arcade Machine (Red5)", MACHINE_NOT_WORKING ) // 128Mbyte ROM, must be externally banked or different addressing scheme - -CONS( 201?, denv150, 0, 0, nes_vt_cy_bigger, nes_vt, nes_vt_cy_lexibook_state, empty_init, "Denver", "Denver Game Console GMP-240C 150-in-1", MACHINE_NOT_WORKING | MACHINE_IMPERFECT_GRAPHICS ) - -// same encryption as above, but seems like newer hardware (or the above aren't using most of the features) -CONS( 200?, lpgm240, 0, 0, nes_vt_vh2009_8mb, nes_vt, nes_vt_swap_op_d5_d6_state, empty_init, "", "Let's Play! Game Machine 240 in 1", MACHINE_NOT_WORKING ) // mini 'retro-arcade' style cabinet - -CONS( 2017, otrail, 0, 0, nes_vt_dg_1mb, nes_vt, nes_vt_dg_state, empty_init, "Basic Fun", "The Oregon Trail", MACHINE_NOT_WORKING | MACHINE_IMPERFECT_GRAPHICS ) - -CONS( 200?, zonefusn, 0, 0, nes_vt_fp_16mb, nes_vt, nes_vt_hh_state, empty_init, "Ultimate Products / Jungle's Soft", "Zone Fusion", MACHINE_NOT_WORKING ) +// Also available in handheld form where Supreme 200 is also shown on the main menu background +// unclear if this is VT03 or VT09, the boot logo needs either VT09 or PAL mode for the DMA to be correct, dump is from a PAL unit +CONS( 201?, ppgc200g, 0, 0, nes_vt_pal_8mb, nes_vt, nes_vt_state, empty_init, "Fizz Creations", "Plug & Play Game Controller with 200 Games (Supreme 200)", MACHINE_IMPERFECT_GRAPHICS ) diff --git a/src/mame/drivers/nes_vt09.cpp b/src/mame/drivers/nes_vt09.cpp new file mode 100644 index 00000000000..4efafdb6a60 --- /dev/null +++ b/src/mame/drivers/nes_vt09.cpp @@ -0,0 +1,470 @@ +// license:BSD-3-Clause +// copyright-holders:David Haywood +/*************************************************************************** + + nes_vt09.cpp + + VT09 and higher go in here + + - 4KB RAM + - Optional alt 4bpp tile mode + - DMA acts the same in both NTSC and PAL modes + + NON-bugs (same happens on real hardware) + + msisinv: Taito screen has bad palette, it's encoded as VT03 but hardware is VT09 + msimm2: Corruption on Metal Man boss + +***************************************************************************/ + +#include "emu.h" +#include "machine/nes_vt_soc.h" + +class nes_vt09_common_base_state : public driver_device +{ +public: + nes_vt09_common_base_state(const machine_config& mconfig, device_type type, const char* tag) : + driver_device(mconfig, type, tag), + m_io0(*this, "IO0"), + m_io1(*this, "IO1"), + m_exin(*this, "EXTRAIN%u", 0U), + m_prgrom(*this, "mainrom") + { } + +protected: + virtual void machine_start() override; + virtual void machine_reset() override; + + virtual uint8_t in0_r(); + virtual uint8_t in1_r(); + virtual void in0_w(uint8_t data); + + void nes_vt09_map(address_map& map); + + optional_ioport m_io0; + optional_ioport m_io1; + + uint8_t m_latch0; + uint8_t m_latch1; + uint8_t m_previous_port0; + + optional_ioport_array<4> m_exin; + + required_region_ptr m_prgrom; + + uint8_t vt_rom_r(offs_t offset); + void vtspace_w(offs_t offset, uint8_t data); + + void configure_soc(nes_vt02_vt03_soc_device* soc); + + uint8_t upper_412c_r(); + uint8_t upper_412d_r(); + void upper_412c_w(uint8_t data); + +private: + /* Extra IO */ + template uint8_t extrain_r(); +}; + +class nes_vt09_common_state : public nes_vt09_common_base_state +{ +public: + nes_vt09_common_state(const machine_config& mconfig, device_type type, const char* tag) : + nes_vt09_common_base_state(mconfig, type, tag), + m_soc(*this, "soc") + { } + + void vt_external_space_map_32mbyte(address_map& map); + void vt_external_space_map_16mbyte(address_map& map); + void vt_external_space_map_8mbyte(address_map& map); + void vt_external_space_map_4mbyte(address_map& map); + void vt_external_space_map_2mbyte(address_map& map); + void vt_external_space_map_1mbyte(address_map& map); + void vt_external_space_map_512kbyte(address_map& map); + + +protected: + required_device m_soc; +}; + +class nes_vt09_state : public nes_vt09_common_state +{ +public: + nes_vt09_state(const machine_config& mconfig, device_type type, const char* tag) : + nes_vt09_common_state(mconfig, type, tag) + { } + + void nes_vt09(machine_config& config); + void nes_vt09_1mb(machine_config& config); + void nes_vt09_2mb(machine_config& config); + void nes_vt09_4mb(machine_config& config); + void nes_vt09_4mb_rasterhack(machine_config& config); + void nes_vt09_8mb(machine_config& config); + void nes_vt09_16mb(machine_config& config); + +private: +}; + +uint8_t nes_vt09_common_base_state::vt_rom_r(offs_t offset) +{ + return m_prgrom[offset]; +} + +void nes_vt09_common_base_state::vtspace_w(offs_t offset, uint8_t data) +{ + logerror("%s: vtspace_w %08x : %02x", machine().describe_context(), offset, data); +} + +// VTxx can address 25-bit address space (32MB of ROM) so use maps with mirroring in depending on ROM size +void nes_vt09_common_state::vt_external_space_map_32mbyte(address_map &map) +{ + map(0x0000000, 0x1ffffff).r(FUNC(nes_vt09_common_state::vt_rom_r)); +} + +void nes_vt09_common_state::vt_external_space_map_16mbyte(address_map &map) +{ + map(0x0000000, 0x0ffffff).mirror(0x1000000).r(FUNC(nes_vt09_common_state::vt_rom_r)); +} + +void nes_vt09_common_state::vt_external_space_map_8mbyte(address_map &map) +{ + map(0x0000000, 0x07fffff).mirror(0x1800000).r(FUNC(nes_vt09_common_state::vt_rom_r)); +} + +void nes_vt09_common_state::vt_external_space_map_4mbyte(address_map &map) +{ + map(0x0000000, 0x03fffff).mirror(0x1c00000).r(FUNC(nes_vt09_common_state::vt_rom_r)); +} + +void nes_vt09_common_state::vt_external_space_map_2mbyte(address_map &map) +{ + map(0x0000000, 0x01fffff).mirror(0x1e00000).r(FUNC(nes_vt09_common_state::vt_rom_r)); +} + +void nes_vt09_common_state::vt_external_space_map_1mbyte(address_map &map) +{ + map(0x0000000, 0x00fffff).mirror(0x1f00000).r(FUNC(nes_vt09_common_state::vt_rom_r)); +} + +void nes_vt09_common_state::vt_external_space_map_512kbyte(address_map &map) +{ + map(0x0000000, 0x007ffff).mirror(0x1f80000).r(FUNC(nes_vt09_common_state::vt_rom_r)); +} + +template uint8_t nes_vt09_common_base_state::extrain_r() +{ + if (m_exin[NUM]) + return m_exin[NUM]->read(); + else + { + logerror("%s: extrain_r (port %d) (not hooked up)\n", NUM, machine().describe_context()); + } + return 0x00; +} + + +/* Standard I/O handlers (NES Controller clone) */ + +uint8_t nes_vt09_common_base_state::in0_r() +{ + //logerror("%s: in0_r\n", machine().describe_context()); + uint8_t ret = 0x40; + ret |= m_latch0 & 1; + m_latch0 >>= 1; + return ret; +} + +uint8_t nes_vt09_common_base_state::in1_r() +{ + //logerror("%s: in1_r\n", machine().describe_context()); + uint8_t ret = 0x40; + ret |= m_latch1 & 1; + m_latch1 >>= 1; + return ret; +} + +void nes_vt09_common_base_state::in0_w(uint8_t data) +{ + //logerror("%s: in0_w %02x\n", machine().describe_context(), data); + if ((data & 0x01) != (m_previous_port0 & 0x01)) + { + if (data & 0x01) + { + m_latch0 = m_io0->read(); + m_latch1 = m_io1->read(); + } + } + + m_previous_port0 = data; +} + + +void nes_vt09_common_base_state::machine_start() +{ + m_latch0 = 0; + m_latch1 = 0; + m_previous_port0 = 0; + + save_item(NAME(m_latch0)); + save_item(NAME(m_latch1)); + save_item(NAME(m_previous_port0)); +} + +void nes_vt09_common_base_state::machine_reset() +{ +} + +void nes_vt09_common_base_state::configure_soc(nes_vt02_vt03_soc_device* soc) +{ + soc->set_addrmap(AS_PROGRAM, &nes_vt09_common_state::vt_external_space_map_32mbyte); + soc->read_0_callback().set(FUNC(nes_vt09_common_base_state::in0_r)); + soc->read_1_callback().set(FUNC(nes_vt09_common_base_state::in1_r)); + soc->write_0_callback().set(FUNC(nes_vt09_common_base_state::in0_w)); + + soc->extra_read_0_callback().set(FUNC(nes_vt09_common_base_state::extrain_r<0>)); + soc->extra_read_1_callback().set(FUNC(nes_vt09_common_base_state::extrain_r<1>)); + soc->extra_read_2_callback().set(FUNC(nes_vt09_common_base_state::extrain_r<2>)); + soc->extra_read_3_callback().set(FUNC(nes_vt09_common_base_state::extrain_r<3>)); +} + + +uint8_t nes_vt09_common_base_state::upper_412c_r() +{ + logerror("%s: upper_412c_r\n", machine().describe_context()); + return 0x00; +} + +uint8_t nes_vt09_common_base_state::upper_412d_r() +{ + logerror("%s: upper_412d_r\n", machine().describe_context()); + return 0x00; +} + +void nes_vt09_common_base_state::upper_412c_w(uint8_t data) +{ + logerror("%s: upper_412c_w %02x\n", machine().describe_context(), data); +} + + + +void nes_vt09_state::nes_vt09(machine_config &config) +{ + /* basic machine hardware */ + NES_VT09_SOC(config, m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); + + dynamic_cast(*m_soc).upper_read_412c_callback().set(FUNC(nes_vt09_state::upper_412c_r)); + dynamic_cast(*m_soc).upper_read_412d_callback().set(FUNC(nes_vt09_state::upper_412d_r)); + dynamic_cast(*m_soc).upper_write_412c_callback().set(FUNC(nes_vt09_state::upper_412c_w)); + + m_soc->force_bad_dma(); +} + +void nes_vt09_state::nes_vt09_16mb(machine_config& config) +{ + nes_vt09(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt09_state::vt_external_space_map_16mbyte); +} + +void nes_vt09_state::nes_vt09_8mb(machine_config& config) +{ + nes_vt09(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt09_state::vt_external_space_map_8mbyte); +} + +void nes_vt09_state::nes_vt09_1mb(machine_config& config) +{ + nes_vt09(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt09_state::vt_external_space_map_1mbyte); +} + +void nes_vt09_state::nes_vt09_2mb(machine_config& config) +{ + nes_vt09(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt09_state::vt_external_space_map_2mbyte); +} + +void nes_vt09_state::nes_vt09_4mb(machine_config& config) +{ + nes_vt09(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt09_state::vt_external_space_map_4mbyte); +} + +void nes_vt09_state::nes_vt09_4mb_rasterhack(machine_config& config) +{ + nes_vt09_4mb(config); + m_soc->force_raster_timing_hack(); +} + + + +static INPUT_PORTS_START( nes_vt09 ) + PORT_START("IO0") + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(1) PORT_NAME("A") + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(1) PORT_NAME("B") + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(1) + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(1) + PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(1) PORT_8WAY + + PORT_START("IO1") + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(2) PORT_NAME("A") + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(2) PORT_NAME("B") + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(2) + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(2) + PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(2) PORT_8WAY + PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(2) PORT_8WAY + PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(2) PORT_8WAY + PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(2) PORT_8WAY +INPUT_PORTS_END + +static INPUT_PORTS_START( nes_vt09_msi ) + PORT_START("IO0") + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(1) PORT_NAME("A") + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(1) PORT_NAME("B") + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(1) // doesn't exist? + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(1) + PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(1) PORT_8WAY + + PORT_START("IO1") + PORT_BIT( 0xff, IP_ACTIVE_HIGH, IPT_UNUSED ) +INPUT_PORTS_END + +static INPUT_PORTS_START( nes_vt09_msi_mm2 ) + PORT_START("IO0") + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(1) PORT_NAME("A") + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(1) PORT_NAME("B") + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(1) // doesn't exist? + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(1) + PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(1) PORT_8WAY + + PORT_START("IO1") + PORT_BIT( 0xff, IP_ACTIVE_HIGH, IPT_UNUSED ) +INPUT_PORTS_END + + +ROM_START( msiwwe ) + ROM_REGION( 0x200000, "mainrom", 0 ) // the first half of this ROM is unused code from the Ms. Pac-Man game! + ROM_LOAD( "wrestlemania_es29lv160fb_004a2249.bin", 0x00000, 0x200000, CRC(f524382d) SHA1(0c8d1c29c76e3e3c58018354f1eca9445c9ab945) ) +ROM_END + +ROM_START( msiwwea ) + ROM_REGION( 0x100000, "mainrom", 0 ) + ROM_LOAD( "wrestlemania_en29lv800bb_007f225b.bin", 0x00000, 0x100000, CRC(52102de3) SHA1(f858ad18e05d3de24dfab4c98798efb4d30e2987) ) +ROM_END + +ROM_START( msidd ) + ROM_REGION( 0x200000, "mainrom", 0 ) + ROM_LOAD( "doubledragon_m29w160eb_00202249.bin", 0x00000, 0x200000, CRC(44df5bb6) SHA1(a984aa1644d2d313d4263afdfed1cd64009f1137) ) +ROM_END + +ROM_START( msimm2 ) + ROM_REGION( 0x400000, "mainrom", 0 ) + ROM_LOAD( "megaman2_s99jl032hbt1_001227e_readas_s29jl032h.bin", 0x00000, 0x400000, CRC(f537a053) SHA1(bd9353df34c0c0ee7d0e5e9808fc36f1a5eecc22) ) +ROM_END + +ROM_START( msimpac ) + ROM_REGION( 0x100000, "mainrom", 0 ) + ROM_LOAD( "mspacman_29dl800ba_000422cb.bin", 0x00000, 0x100000, CRC(c66300e3) SHA1(3fc0bdfbf449d884151f1b581e848243cd2df3a5) ) +ROM_END + +ROM_START( msisinv ) + ROM_REGION( 0x100000, "mainrom", 0 ) + ROM_LOAD( "spaceinvaders_en29lv800bb_007f225b.bin", 0x00000, 0x100000, CRC(e444d129) SHA1(33742bc3a6250337cc42b73812e797023818282a) ) +ROM_END + +ROM_START( msifrog ) + ROM_REGION( 0x400000, "mainrom", 0 ) + ROM_LOAD( "frogger_39vf3201_00bf235b.bin", 0x00000, 0x400000, CRC(c46c29c0) SHA1(b8f26445c2086b97db8ee98bf36dff9d63ca414b) ) +ROM_END + +ROM_START( cybar120 ) + ROM_REGION( 0x1000000, "mainrom", 0 ) + ROM_LOAD( "m2500p-vt09-epson,20091222ver05,_30r-sx1067-01_pcb,_12r0cob128m_12001-3d05_fw.bin", 0x00000, 0x1000000, CRC(f7138980) SHA1(de31264ee3a5a5c77a86733b2e2d6845fee91ea5) ) +ROM_END + +ROM_START( vsmaxtx2 ) + ROM_REGION( 0x400000, "mainrom", 0 ) + ROM_LOAD( "tx2.bin", 0x00000, 0x400000, CRC(eddf0ca8) SHA1(b87c5c3e945d1efdcb953325425d4ddb0fded00a) ) +ROM_END + +ROM_START( senario25 ) + ROM_REGION( 0x200000, "mainrom", 0 ) + ROM_LOAD( "senario25.bin", 0x00000, 0x200000, CRC(270c4517) SHA1(c099096d1c86f55f2b0826484cd3d3f68c90c794) ) +ROM_END + +ROM_START( dturbogt ) + ROM_REGION( 0x800000, "mainrom", 0 ) + ROM_LOAD( "dgturbogt.bin", 0x00000, 0x800000, CRC(9532fb78) SHA1(cd188672f9b8e9c12069612ad0d0b70d3dd6c1b1) ) +ROM_END + +ROM_START( rcapnp ) + ROM_REGION( 0x200000, "mainrom", 0 ) + ROM_LOAD( "rcapnp_mx29lv160ab_00c22249.bin", 0x00000, 0x200000, CRC(8cc30a47) SHA1(815bfc26360b01ed3fa077016222939d2184408c) ) +ROM_END + +ROM_START( ventur25 ) + ROM_REGION( 0x400000, "mainrom", 0 ) + ROM_LOAD( "25games_m5m29gt320vp_001c0020.bin", 0x00000, 0x400000, CRC(3f78a45a) SHA1(3e97333c13e09c580e66518dd2e1e031371d399c) ) +ROM_END + +ROM_START( vgtablet ) + ROM_REGION( 0x400000, "mainrom", 0 ) + ROM_LOAD( "vgtablet.bin", 0x00000, 0x400000, CRC(99ef3978) SHA1(0074445708d66a04ab02b4993069ce1ae0514c2f) ) +ROM_END + +ROM_START( vgpocket ) + ROM_REGION( 0x400000, "mainrom", 0 ) + ROM_LOAD( "vgpocket.bin", 0x00000, 0x400000, CRC(843634c6) SHA1(c59dab0e43d364f59eb3a138abb585bc54e5d674) ) + // there was a dump of a 'secure' area with this, but it was just the top 0x10000 bytes of the existing rom. +ROM_END + +ROM_START( vgpmini ) + ROM_REGION( 0x400000, "mainrom", 0 ) + ROM_LOAD( "vgpmini.bin", 0x00000, 0x400000, CRC(a1121843) SHA1(c96013ae6cf2f8173e65a167d45685cb61536d36) ) + // there was a dump of a 'secure' area with this, but it was just the bottom 0x10000 bytes of the existing rom. +ROM_END + +// MSI Entertainment games (MSI previously operated as Majesco Entertainment) + +// There are meant to be multiple revisions of this software, some with theme tunes for the new wrestlers, some without. This one appears to lack them. +// 2 box variations exist, one with Randy Savage in purple attire and another with green, this was dumped from a unit with purple on the box. +CONS( 2017, msiwwe, 0, 0, nes_vt09_2mb, nes_vt09_msi, nes_vt09_state, empty_init, "MSI", "WWE Wrestlemania Steel Cage Challenge (Plug & Play) (set 1)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +// this one was dumped from the version with Randy Savage in green, the box was much larger than the other one. This one also has new theme music for the adjusted roster. +CONS( 2017, msiwwea, msiwwe, 0, nes_vt09_1mb, nes_vt09_msi, nes_vt09_state, empty_init, "MSI", "WWE Wrestlemania Steel Cage Challenge (Plug & Play) (set 2)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) + +CONS( 2017, msidd, 0, 0, nes_vt09_2mb, nes_vt09_msi, nes_vt09_state, empty_init, "MSI / Arc System Works", "Double Dragon - 30 Years Anniversary (Plug & Play)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) + +CONS( 2016, msimpac, 0, 0, nes_vt09_1mb, nes_vt09_msi, nes_vt09_state, empty_init, "MSI / Bandai Namco", "Ms. Pac-Man (MSI Plug & Play)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) + +CONS( 2017, msimm2, 0, 0, nes_vt09_4mb, nes_vt09_msi_mm2, nes_vt09_state, empty_init, "MSI / Capcom", "Mega Man 2 (MSI Plug & Play)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // various issues (glitched Metal Man stage boss, missing 'ready' text) happen on real unit + +CONS( 2016, msisinv, 0, 0, nes_vt09_1mb, nes_vt09_msi, nes_vt09_state, empty_init, "MSI / Taito", "Space Invaders (MSI Plug & Play)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) + +// This is from the version with the same case type as the above MSI units. +// MSI also issued a version in the original Majesco shell but with the updated case logos and boot logos in the software, the software on that revision might match this one. +CONS( 2016, msifrog, 0, 0, nes_vt09_4mb_rasterhack, nes_vt09_msi, nes_vt09_state, empty_init, "MSI / Konami", "Frogger (MSI Plug & Play, white joystick)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // raster timing for need a hack + +// MSI Midway (Joust+Gauntlet 2 + Defender 2) has 2x Globs, rather than Glob + Flash ROM + +// this is VT09 based +CONS( 2009, cybar120, 0, 0, nes_vt09_16mb,nes_vt09, nes_vt09_state, empty_init, "Defender / JungleTac", "Defender M2500P 120-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +CONS( 200?, vsmaxtx2, 0, 0, nes_vt09_4mb, nes_vt09, nes_vt09_state, empty_init, "Senario / JungleTac", "Vs Maxx TX-2 50-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +CONS( 200?, senario25, 0, 0, nes_vt09_2mb, nes_vt09, nes_vt09_state, empty_init, "Senario / JungleTac", "25 Video Games - All in 1 Video System (Senario)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // no Vs Maxx branding, newer style packaging +CONS( 200?, rcapnp, 0, 0, nes_vt09_2mb, nes_vt09, nes_vt09_state, empty_init, "RCA / JungleTac", "RCA NS-500 30-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +CONS( 200?, dturbogt, 0, 0, nes_vt09_8mb, nes_vt09, nes_vt09_state, empty_init, "dreamGEAR / JungleTac", "Turbo GT 50-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +CONS( 200?, ventur25, 0, 0, nes_vt09_4mb, nes_vt09, nes_vt09_state, empty_init, " / JungleTac", "Venturer '25 Games' 25-in-1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +CONS( 2005, vgpocket, 0, 0, nes_vt09_4mb, nes_vt09, nes_vt09_state, empty_init, "Performance Designed Products / JungleTac", "VG Pocket (VG-2000)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +CONS( 200?, vgpmini, 0, 0, nes_vt09_4mb, nes_vt09, nes_vt09_state, empty_init, "Performance Designed Products / JungleTac", "VG Pocket Mini (VG-1500)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +// VG Pocket Max (VG-2500) (blue case, 75 games) +// VG Pocket Max (VG-3000) (white case, 75 games) (does the game selection differ, or only the case?) +CONS( 2006, vgtablet, 0, 0, nes_vt09_4mb_rasterhack, nes_vt09, nes_vt09_state, empty_init, "Performance Designed Products (licensed by Konami) / JungleTac", "VG Pocket Tablet (VG-4000)", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // raster timing for Frogger needs a hack +// VG Pocket Caplet is SunPlus hardware instead, see spg2xx_lexibook.cpp diff --git a/src/mame/drivers/nes_vt32_vt369.cpp b/src/mame/drivers/nes_vt32_vt369.cpp new file mode 100644 index 00000000000..38cfce4dcbc --- /dev/null +++ b/src/mame/drivers/nes_vt32_vt369.cpp @@ -0,0 +1,971 @@ +// license:BSD-3-Clause +// copyright-holders:David Haywood +/*************************************************************************** + + nes_vt32_vt369.cpp + + VT32, VT369 and higher + + - new screen modes + - new registers for controlling banking + - can run from SPI ROM + - backwards compatibility with mappers other than MMC3 + - additional audio cpu (like VT1682) and multiplier on VT369 models + + (not all features are used all games, but anything that has an SPI ROM + must at least be this tech level) + + TODO: + this still needs significant cleanups before work is started on individual + systems + + ***************************************************************************/ + +#include "emu.h" +#include "machine/nes_vt_soc.h" + +class nes_vt3x_base_state : public driver_device +{ +public: + nes_vt3x_base_state(const machine_config& mconfig, device_type type, const char* tag) : + driver_device(mconfig, type, tag), + m_io0(*this, "IO0"), + m_io1(*this, "IO1"), + m_cartsel(*this, "CARTSEL"), + m_exin(*this, "EXTRAIN%u", 0U), + m_prgrom(*this, "mainrom") + { } + +protected: + virtual void machine_start() override; + virtual void machine_reset() override; + + virtual uint8_t in0_r(); + virtual uint8_t in1_r(); + virtual void in0_w(uint8_t data); + + void nes_vt3x_map(address_map& map); + + optional_ioport m_io0; + optional_ioport m_io1; + + uint8_t m_latch0; + uint8_t m_latch1; + uint8_t m_previous_port0; + + optional_ioport m_cartsel; + optional_ioport_array<4> m_exin; + + /* Misc */ + uint32_t m_ahigh; // external banking bits + uint8_t m_4242; + uint8_t m_411c; + uint8_t m_411d; + + required_region_ptr m_prgrom; + + uint8_t vt_rom_r(offs_t offset); + void vtspace_w(offs_t offset, uint8_t data); + + void configure_soc(nes_vt02_vt03_soc_device* soc); + + uint8_t upper_412c_r(); + uint8_t upper_412d_r(); + void upper_412c_w(uint8_t data); + +private: + /* Extra IO */ + template uint8_t extrain_r(); +}; + +class nes_vt3x_state : public nes_vt3x_base_state +{ +public: + nes_vt3x_state(const machine_config& mconfig, device_type type, const char* tag) : + nes_vt3x_base_state(mconfig, type, tag), + m_soc(*this, "soc") + { } + + void nes_vt3x_4k_ram(machine_config& config); + void nes_vt3x_4k_ram_16mb(machine_config& config); + + void vt_external_space_map_32mbyte(address_map& map); + void vt_external_space_map_16mbyte(address_map& map); + void vt_external_space_map_8mbyte(address_map& map); + void vt_external_space_map_4mbyte(address_map& map); + void vt_external_space_map_2mbyte(address_map& map); + void vt_external_space_map_1mbyte(address_map& map); + void vt_external_space_map_512kbyte(address_map& map); + + void init_lxcmcypp(); + +protected: + required_device m_soc; +}; + + +class nes_vt3x_swap_op_d5_d6_state : public nes_vt3x_state +{ +public: + nes_vt3x_swap_op_d5_d6_state(const machine_config& mconfig, device_type type, const char* tag) : + nes_vt3x_state(mconfig, type, tag) + { } + + void nes_vt3x_vh2009_8mb(machine_config& config); +protected: +}; + + +class nes_vt3x_cy_state : public nes_vt3x_state +{ +public: + nes_vt3x_cy_state(const machine_config& mconfig, device_type type, const char* tag) : + nes_vt3x_state(mconfig, type, tag) + { } + + void nes_vt3x_cy(machine_config& config); + void nes_vt3x_cy_bigger(machine_config& config); + void nes_vt3x_bt(machine_config& config); + void nes_vt3x_bt_2x16mb(machine_config& config); + + void vt_external_space_map_bitboy_2x16mbyte(address_map& map); + +private: + void nes_vt3x_cy_map(address_map& map); + void nes_vt3x_bt_map(address_map& map); + + void bittboy_412c_w(uint8_t data); + + uint8_t vt_rom_banked_r(offs_t offset); +}; + +class nes_vt3x_dg_state : public nes_vt3x_state +{ +public: + nes_vt3x_dg_state(const machine_config& mconfig, device_type type, const char* tag) : + nes_vt3x_state(mconfig, type, tag) + { } + + void nes_vt3x_fa(machine_config& config); + void nes_vt3x_fa_4x16mb(machine_config& config); + +protected: + +private: + uint8_t vt_rom_banked_r(offs_t offset); + void vt_external_space_map_fapocket_4x16mbyte(address_map& map); + + uint8_t fapocket_412c_r(); + void fapocket_412c_w(uint8_t data); + +}; + +class nes_vt3x_dg_fapocket_state : public nes_vt3x_dg_state +{ +public: + nes_vt3x_dg_fapocket_state(const machine_config& mconfig, device_type type, const char* tag) : + nes_vt3x_dg_state(mconfig, type, tag) + { } + +protected: + virtual void machine_reset() override; +}; + + +class nes_vt3x_unk_state : public nes_vt3x_dg_state +{ +public: + nes_vt3x_unk_state(const machine_config& mconfig, device_type type, const char* tag) : + nes_vt3x_dg_state(mconfig, type, tag) + { } + + void nes_vt3x_hh(machine_config& config); + void nes_vt3x_hh_4mb(machine_config& config); + void nes_vt3x_hh_8mb(machine_config& config); + + void nes_vt3x_unk(machine_config& config); + void nes_vt3x_unk_1mb(machine_config& config); + void nes_vt3x_unk_16mb(machine_config& config); + + void nes_vt3x_fp(machine_config& config); + void nes_vt3x_fp_16mb(machine_config& config); + void nes_vt3x_fp_32mb(machine_config& config); + void nes_vt3x_fp_bigger(machine_config& config); + void nes_vt3x_fp_4x16mb(machine_config& config); + + void nes_vt3x_fp_pal(machine_config& config); + void nes_vt3x_fp_pal_32mb(machine_config& config); + +private: + uint8_t vt_rom_banked_r(offs_t offset); + void vt_external_space_map_fp_2x32mbyte(address_map& map); + + void nes_vt3x_fp_map(address_map& map); + + uint8_t fcpocket_412d_r(); + void fcpocket_412c_w(uint8_t data); +}; + +uint8_t nes_vt3x_base_state::vt_rom_r(offs_t offset) +{ + return m_prgrom[offset]; +} + +void nes_vt3x_base_state::vtspace_w(offs_t offset, uint8_t data) +{ + logerror("%s: vtspace_w %08x : %02x", machine().describe_context(), offset, data); +} + +// VTxx can address 25-bit address space (32MB of ROM) so use maps with mirroring in depending on ROM size +void nes_vt3x_state::vt_external_space_map_32mbyte(address_map &map) +{ + map(0x0000000, 0x1ffffff).r(FUNC(nes_vt3x_state::vt_rom_r)); +} + +void nes_vt3x_state::vt_external_space_map_16mbyte(address_map &map) +{ + map(0x0000000, 0x0ffffff).mirror(0x1000000).r(FUNC(nes_vt3x_state::vt_rom_r)); +} + +void nes_vt3x_state::vt_external_space_map_8mbyte(address_map &map) +{ + map(0x0000000, 0x07fffff).mirror(0x1800000).r(FUNC(nes_vt3x_state::vt_rom_r)); +} + +void nes_vt3x_state::vt_external_space_map_4mbyte(address_map &map) +{ + map(0x0000000, 0x03fffff).mirror(0x1c00000).r(FUNC(nes_vt3x_state::vt_rom_r)); +} + +void nes_vt3x_state::vt_external_space_map_2mbyte(address_map &map) +{ + map(0x0000000, 0x01fffff).mirror(0x1e00000).r(FUNC(nes_vt3x_state::vt_rom_r)); +} + +void nes_vt3x_state::vt_external_space_map_1mbyte(address_map &map) +{ + map(0x0000000, 0x00fffff).mirror(0x1f00000).r(FUNC(nes_vt3x_state::vt_rom_r)); +} + +void nes_vt3x_state::vt_external_space_map_512kbyte(address_map &map) +{ + map(0x0000000, 0x007ffff).mirror(0x1f80000).r(FUNC(nes_vt3x_state::vt_rom_r)); +} + +// bitboy is 2 16Mbyte banks +uint8_t nes_vt3x_cy_state::vt_rom_banked_r(offs_t offset) +{ + return m_prgrom[m_ahigh | offset]; +} + +void nes_vt3x_cy_state::vt_external_space_map_bitboy_2x16mbyte(address_map &map) +{ + map(0x0000000, 0x0ffffff).mirror(0x1000000).r(FUNC(nes_vt3x_cy_state::vt_rom_banked_r)); +} + +// fapocket is 4 16Mbyte banks +uint8_t nes_vt3x_dg_state::vt_rom_banked_r(offs_t offset) +{ + return m_prgrom[m_ahigh | offset]; +} + +void nes_vt3x_dg_state::vt_external_space_map_fapocket_4x16mbyte(address_map &map) +{ + map(0x0000000, 0x0ffffff).mirror(0x1000000).r(FUNC(nes_vt3x_dg_state::vt_rom_banked_r)); +} + +uint8_t nes_vt3x_unk_state::vt_rom_banked_r(offs_t offset) +{ + return m_prgrom[m_ahigh | offset]; +} + +void nes_vt3x_unk_state::vt_external_space_map_fp_2x32mbyte(address_map &map) +{ + map(0x0000000, 0x1ffffff).r(FUNC(nes_vt3x_unk_state::vt_rom_banked_r)); +} + + +template uint8_t nes_vt3x_base_state::extrain_r() +{ + if (m_exin[NUM]) + return m_exin[NUM]->read(); + else + { + logerror("%s: extrain_r (port %d) (not hooked up)\n", NUM, machine().describe_context()); + } + return 0x00; +} + + +/* Standard I/O handlers (NES Controller clone) */ + +uint8_t nes_vt3x_base_state::in0_r() +{ + //logerror("%s: in0_r\n", machine().describe_context()); + uint8_t ret = 0x40; + ret |= m_latch0 & 1; + m_latch0 >>= 1; + return ret; +} + +uint8_t nes_vt3x_base_state::in1_r() +{ + //logerror("%s: in1_r\n", machine().describe_context()); + uint8_t ret = 0x40; + ret |= m_latch1 & 1; + m_latch1 >>= 1; + return ret; +} + +void nes_vt3x_base_state::in0_w(uint8_t data) +{ + //logerror("%s: in0_w %02x\n", machine().describe_context(), data); + if ((data & 0x01) != (m_previous_port0 & 0x01)) + { + if (data & 0x01) + { + m_latch0 = m_io0->read(); + m_latch1 = m_io1->read(); + } + } + + m_previous_port0 = data; +} + + +void nes_vt3x_base_state::machine_start() +{ + m_latch0 = 0; + m_latch1 = 0; + m_previous_port0 = 0; + + m_ahigh = 0; + m_4242 = 0; + m_411c = 0; + m_411d = 0; + + save_item(NAME(m_latch0)); + save_item(NAME(m_latch1)); + save_item(NAME(m_previous_port0)); + + save_item(NAME(m_ahigh)); + save_item(NAME(m_4242)); + save_item(NAME(m_411c)); + save_item(NAME(m_411d)); +} + +void nes_vt3x_base_state::machine_reset() +{ + +} + +void nes_vt3x_dg_fapocket_state::machine_reset() +{ + nes_vt3x_base_state::machine_reset(); + + // fapocket needs this, fcpocket instead reads the switch in software? + if (m_cartsel) + m_ahigh = (m_cartsel->read() == 0x01) ? (1 << 25) : 0x0; + else + m_ahigh = 0; +} +void nes_vt3x_base_state::configure_soc(nes_vt02_vt03_soc_device* soc) +{ + soc->set_addrmap(AS_PROGRAM, &nes_vt3x_state::vt_external_space_map_32mbyte); + soc->read_0_callback().set(FUNC(nes_vt3x_base_state::in0_r)); + soc->read_1_callback().set(FUNC(nes_vt3x_base_state::in1_r)); + soc->write_0_callback().set(FUNC(nes_vt3x_base_state::in0_w)); + + soc->extra_read_0_callback().set(FUNC(nes_vt3x_base_state::extrain_r<0>)); + soc->extra_read_1_callback().set(FUNC(nes_vt3x_base_state::extrain_r<1>)); + soc->extra_read_2_callback().set(FUNC(nes_vt3x_base_state::extrain_r<2>)); + soc->extra_read_3_callback().set(FUNC(nes_vt3x_base_state::extrain_r<3>)); +} + +uint8_t nes_vt3x_base_state::upper_412c_r() +{ + logerror("%s: upper_412c_r\n", machine().describe_context()); + return 0x00; +} + +uint8_t nes_vt3x_base_state::upper_412d_r() +{ + logerror("%s: upper_412d_r\n", machine().describe_context()); + return 0x00; +} + +void nes_vt3x_base_state::upper_412c_w(uint8_t data) +{ + logerror("%s: upper_412c_w %02x\n", machine().describe_context(), data); +} + +void nes_vt3x_state::nes_vt3x_4k_ram(machine_config &config) +{ + /* basic machine hardware */ + NES_VT09_SOC(config, m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); + + dynamic_cast(*m_soc).upper_read_412c_callback().set(FUNC(nes_vt3x_state::upper_412c_r)); + dynamic_cast(*m_soc).upper_read_412d_callback().set(FUNC(nes_vt3x_state::upper_412d_r)); + dynamic_cast(*m_soc).upper_write_412c_callback().set(FUNC(nes_vt3x_state::upper_412c_w)); +} + +void nes_vt3x_state::nes_vt3x_4k_ram_16mb(machine_config &config) +{ + nes_vt3x_4k_ram(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_state::vt_external_space_map_16mbyte); +} + +void nes_vt3x_cy_state::nes_vt3x_cy(machine_config &config) +{ + nes_vt3x_4k_ram(config); + + NES_VT09_SOC_CY(config.replace(), m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); +} + +void nes_vt3x_cy_state::nes_vt3x_cy_bigger(machine_config &config) +{ + nes_vt3x_cy(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_cy_state::vt_external_space_map_32mbyte); // must be some banking of this kind of VT can address over 32mb +} + +void nes_vt3x_cy_state::nes_vt3x_bt(machine_config &config) +{ + nes_vt3x_4k_ram(config); + + NES_VT09_SOC_BT(config.replace(), m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); +} + +void nes_vt3x_cy_state::bittboy_412c_w(uint8_t data) +{ + //bittboy (ok), mc_pg150 (not working) + logerror("%s: vt03_412c_extbank_w %02x\n", machine().describe_context(), data); + m_ahigh = (data & 0x04) ? (1 << 24) : 0x0; +} + +void nes_vt3x_cy_state::nes_vt3x_bt_2x16mb(machine_config& config) +{ + nes_vt3x_bt(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_cy_state::vt_external_space_map_bitboy_2x16mbyte); + + dynamic_cast(*m_soc).upper_write_412c_callback().set(FUNC(nes_vt3x_cy_state::bittboy_412c_w)); +} + +void nes_vt3x_unk_state::nes_vt3x_unk(machine_config &config) +{ + nes_vt3x_4k_ram(config); + + NES_VT3X_SOC_DG(config.replace(), m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); + m_soc->force_bad_dma(); +} + +void nes_vt3x_unk_state::nes_vt3x_unk_16mb(machine_config& config) +{ + nes_vt3x_unk(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_unk_state::vt_external_space_map_16mbyte); +} + +void nes_vt3x_unk_state::nes_vt3x_unk_1mb(machine_config& config) +{ + nes_vt3x_unk(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_unk_state::vt_external_space_map_1mbyte); +} + + + + + +// New mystery handheld architecture, VTxx derived +void nes_vt3x_unk_state::nes_vt3x_hh(machine_config &config) +{ + nes_vt3x_4k_ram(config); + + NES_VT369_SOC(config.replace(), m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); + + m_soc->set_default_palette_mode(PAL_MODE_NEW_RGB); + m_soc->force_bad_dma(); +} + +void nes_vt3x_unk_state::nes_vt3x_hh_8mb(machine_config& config) +{ + nes_vt3x_hh(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_unk_state::vt_external_space_map_8mbyte); +} + +void nes_vt3x_unk_state::nes_vt3x_hh_4mb(machine_config& config) +{ + nes_vt3x_hh(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_unk_state::vt_external_space_map_4mbyte); +} + + +static INPUT_PORTS_START( nes_vt3x ) + PORT_START("IO0") + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(1) PORT_NAME("A") + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(1) PORT_NAME("B") + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(1) + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(1) + PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(1) PORT_8WAY + PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(1) PORT_8WAY + + PORT_START("IO1") + PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_PLAYER(2) PORT_NAME("A") + PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_PLAYER(2) PORT_NAME("B") + PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(2) + PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(2) + PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(2) PORT_8WAY + PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(2) PORT_8WAY + PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(2) PORT_8WAY + PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(2) PORT_8WAY +INPUT_PORTS_END + +uint8_t nes_vt3x_unk_state::fcpocket_412d_r() +{ + if (m_cartsel) + return m_cartsel->read(); + else + return 0; +} + +void nes_vt3x_unk_state::fcpocket_412c_w(uint8_t data) +{ + // fcpocket + logerror("%s: vtfp_412c_extbank_w %02x\n", machine().describe_context(), data); + m_ahigh = (data & 0x01) ? (1 << 25) : 0x0; +} + +void nes_vt3x_unk_state::nes_vt3x_fp(machine_config &config) +{ + nes_vt3x_4k_ram(config); + + NES_VT32_SOC(config.replace(), m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); + + m_soc->set_default_palette_mode(PAL_MODE_NEW_RGB12); + m_soc->force_bad_dma(); +} + +void nes_vt3x_unk_state::nes_vt3x_fp_pal_32mb(machine_config& config) +{ + nes_vt3x_4k_ram(config); + + NES_VT32_SOC_PAL(config.replace(), m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); + + m_soc->set_default_palette_mode(PAL_MODE_NEW_RGB12); + m_soc->force_bad_dma(); + + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_unk_state::vt_external_space_map_32mbyte); +} + +void nes_vt3x_unk_state::nes_vt3x_fp_4x16mb(machine_config& config) +{ + nes_vt3x_fp(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_unk_state::vt_external_space_map_fp_2x32mbyte); + + dynamic_cast(*m_soc).upper_write_412c_callback().set(FUNC(nes_vt3x_unk_state::fcpocket_412c_w)); + dynamic_cast(*m_soc).upper_read_412d_callback().set(FUNC(nes_vt3x_unk_state::fcpocket_412d_r)); +} + +void nes_vt3x_unk_state::nes_vt3x_fp_32mb(machine_config& config) +{ + nes_vt3x_fp(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_unk_state::vt_external_space_map_32mbyte); +} + +void nes_vt3x_unk_state::nes_vt3x_fp_bigger(machine_config& config) +{ + nes_vt3x_fp(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_unk_state::vt_external_space_map_32mbyte); // must be some kind of banking, or this VT can address > 32Mbyte +} + +void nes_vt3x_unk_state::nes_vt3x_fp_16mb(machine_config& config) +{ + nes_vt3x_fp(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_unk_state::vt_external_space_map_16mbyte); +} + +void nes_vt3x_unk_state::nes_vt3x_fp_pal(machine_config &config) +{ + nes_vt3x_fp(config); + + // set to PAL +} + + + +void nes_vt3x_dg_state::nes_vt3x_fa(machine_config& config) +{ + nes_vt3x_4k_ram(config); + + NES_VT3X_SOC_FA(config.replace(), m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); +} + + +uint8_t nes_vt3x_dg_state::fapocket_412c_r() +{ + if (m_cartsel) + return m_cartsel->read(); + else + return 0; +} + +void nes_vt3x_dg_state::fapocket_412c_w(uint8_t data) +{ + // fapocket (ok?) (also uses bank from config switch for fake cartridge slot) + logerror("%s: vtfa_412c_extbank_w %02x\n", machine().describe_context(), data); + m_ahigh = 0; + m_ahigh |= (data & 0x01) ? (1 << 25) : 0x0; + m_ahigh |= (data & 0x02) ? (1 << 24) : 0x0; +} + +void nes_vt3x_dg_state::nes_vt3x_fa_4x16mb(machine_config& config) // fapocket +{ + nes_vt3x_fa(config); + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_dg_state::vt_external_space_map_fapocket_4x16mbyte); + + dynamic_cast(*m_soc).upper_read_412c_callback().set(FUNC(nes_vt3x_dg_state::fapocket_412c_r)); + dynamic_cast(*m_soc).upper_write_412c_callback().set(FUNC(nes_vt3x_dg_state::fapocket_412c_w)); +} + + +void nes_vt3x_swap_op_d5_d6_state::nes_vt3x_vh2009_8mb(machine_config& config) +{ + NES_VT02_VT03_SOC(config, m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); + + NES_VT02_VT03_SOC_SCRAMBLE(config.replace(), m_soc, NTSC_APU_CLOCK); + configure_soc(m_soc); + + m_soc->set_addrmap(AS_PROGRAM, &nes_vt3x_swap_op_d5_d6_state::vt_external_space_map_8mbyte); +} + + +static INPUT_PORTS_START( nes_vt3x_fp ) + PORT_INCLUDE(nes_vt3x) + + PORT_START("CARTSEL") + PORT_DIPNAME( 0x06, 0x00, "Cartridge Select" ) PORT_CODE(KEYCODE_3) PORT_TOGGLE + PORT_DIPSETTING( 0x00, "472-in-1" ) + PORT_DIPSETTING( 0x06, "128-in-1" ) +INPUT_PORTS_END + +static INPUT_PORTS_START( nes_vt3x_fa ) + PORT_INCLUDE(nes_vt3x) + + PORT_START("CARTSEL") + PORT_DIPNAME( 0x01, 0x00, "Cartridge Select" ) PORT_CODE(KEYCODE_3) PORT_TOGGLE + PORT_DIPSETTING( 0x00, "508-in-1" ) + PORT_DIPSETTING( 0x01, "130-in-1" ) +INPUT_PORTS_END + + + + +ROM_START( dgun2561 ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + ROM_LOAD( "dgun2561.bin", 0x00000, 0x4000000, CRC(a6e627b4) SHA1(2667d2feb02de349387f9dcfa5418e7ed3afeef6) ) +ROM_END + +ROM_START( dgun2593 ) + ROM_REGION( 0x8000000, "mainrom", 0 ) + ROM_LOAD( "dreamgear300.bin", 0x00000, 0x8000000, CRC(4fe0ed02) SHA1(a55590557bacca65ed9a17c5bcf0a4e5cb223126) ) +ROM_END + +ROM_START( rtvgc300 ) + ROM_REGION( 0x8000000, "mainrom", 0 ) + // some of the higher address lines might be swapped + ROM_LOAD( "lexibook300.bin", 0x00000, 0x4000000, CRC(015c4067) SHA1(a12986c4a366a23c4c7ca7b3d33e421a8dfdffc0) ) +ROM_END + +ROM_START( rtvgc300fz ) + ROM_REGION( 0x8000000, "mainrom", 0 ) + // some of the higher address lines might be swapped + ROM_LOAD( "jg7800fz.bin", 0x00000, 0x4000000, CRC(c9d319d2) SHA1(9d0d1435b802f63ce11b94ce54d11f4065b324cc) ) +ROM_END + +// The maximum address space a VT chip can see is 32MB, so these 64MB roms are actually 2 programs (there are vectors in the first half and the 2nd half) +// there must be a bankswitch bit that switches the whole 32MB space. Loading the 2nd half in Star Wars does actually boot straight to a game. +ROM_START( lxcmcy ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + ROM_LOAD( "lxcmcy.bin", 0x00000, 0x4000000, CRC(3f3af72c) SHA1(76127054291568fcce1431d21af71f775cfb05a6) ) +ROM_END + +ROM_START( lxcmcysw ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + ROM_LOAD( "jl2365swr-1.u2", 0x2000000, 0x2000000, CRC(60ece391) SHA1(655de6b36ba596d873de2839522b948ccf45e006) ) + ROM_CONTINUE(0x0000000, 0x2000000) +ROM_END + +ROM_START( lxcmcyfz ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + // sub-board was marked for 2GB capacity (A0-A26 address lines), but only address lines A0-A24 are connected to the chip + ROM_LOAD( "jl2365_frozen.u1", 0x00000, 0x4000000, CRC(64d4c708) SHA1(1bc2d161326ce3039ab9ba46ad62695060cfb2e1) ) +ROM_END + +ROM_START( lxcmcydp ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + // sub-board was marked for 2GB capacity (A0-A26 address lines), but only address lines A0-A24 are connected to the chip + ROM_LOAD( "cyberarcade-disneyprincess.bin", 0x00000, 0x4000000, CRC(05946f81) SHA1(33eea2b70f5427e7613c836b8a08148731fac231) ) +ROM_END + +ROM_START( lxcmcysp ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + // sub-board was marked for 2GB capacity (A0-A26 address lines), but only address lines A0-A24 are connected to the chip + ROM_LOAD( "lexibookspiderman.bin", 0x00000, 0x4000000, CRC(ef6e8847) SHA1(0012df193c52fd48595d85886fd431619c5d5e3e) ) +ROM_END + +ROM_START( lxcmcycr ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + ROM_LOAD( "lexibook cars.bin", 0x00000, 0x4000000, CRC(198fe11b) SHA1(5e35caa3fc319ec69812c187a3ec89f01749f749) ) +ROM_END + +ROM_START( lxcmcypp ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + // marked 512mbit, possible A22 / A23 are swapped as they were marked on the board in a different way. + ROM_LOAD( "pawpatrol_compact.bin", 0x00000, 0x4000000, CRC(bf536762) SHA1(80dde8426a636bae33a82d779e564fa743eb3776) ) +ROM_END + +ROM_START( lxcmc250 ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + // sub-board was marked for 2GB capacity (A0-A26 address lines), but only address lines A0-A24 are connected to the chip + ROM_LOAD( "cca250in1.u1", 0x00000, 0x4000000, CRC(6ccd6ad6) SHA1(fafed339097c3d1538faa306021a8373c1b799b3) ) +ROM_END + +ROM_START( lxccminn ) + ROM_REGION( 0x4000000, "mainrom", 0 ) // sub-board was hardwired to only be able to address the lower 64MByte, was rewired to also dump upper half when dumping, upper half contains only garbage, hence ROM_IGNORE + ROM_LOAD( "minnie_lexibook.bin", 0x00000, 0x4000000, CRC(3f8e5a69) SHA1(c9f11f3e5f9b73832a191f4d1620a85c1b70f79e) ) + ROM_IGNORE(0x4000000) +ROM_END + +ROM_START( lxccplan ) + ROM_REGION( 0x4000000, "mainrom", 0 ) // sub-board was hardwired to only be able to address the lower 64MByte, was rewired to also dump upper half when dumping, upper half contains only garbage, hence ROM_IGNORE + ROM_LOAD( "planes_lexibook.bin", 0x00000, 0x4000000, CRC(76e1a962) SHA1(83b801c0e0e941ceb1c93e565e833b07c09412c3)) + ROM_IGNORE(0x4000000) +ROM_END + +ROM_START( red5mam ) + ROM_REGION( 0x8000000, "mainrom", 0 ) + ROM_LOAD( "mam.u3", 0x00000, 0x8000000, CRC(0c0a0ecd) SHA1(2dfd8437de17fc9975698f1933dd81fbac78466d) ) +ROM_END + +ROM_START( lpgm240 ) + ROM_REGION( 0x800000, "mainrom", 0 ) + ROM_LOAD( "w25q64jv.u1", 0x00000, 0x800000, CRC(b973e65b) SHA1(36ff137068ea56b4679c2db386ac0067de0a9eaf) ) +ROM_END + +ROM_START( sy889 ) + ROM_REGION( 0x800000, "mainrom", 0 ) + ROM_LOAD( "sy889_w25q64.bin", 0x00000, 0x800000, CRC(fcdaa6fc) SHA1(0493747facf2172b8af22010851668bb18cbb3e4) ) +ROM_END + +ROM_START( sy888b ) + ROM_REGION( 0x400000, "mainrom", 0 ) + ROM_LOAD( "sy888b_f25q32.bin", 0x00000, 0x400000, CRC(a8298c33) SHA1(7112dd13d5fb5f9f9d496816758defd22773ec6e) ) +ROM_END + +ROM_START( dgun2573 ) // this one lacked a DreamGear logo but was otherwise physically identical, is it a clone product or did DreamGear drop the logo in favor of just using the 'My Arcade' brand? + ROM_REGION( 0x2000000, "mainrom", 0 ) + ROM_LOAD( "myarcadegamerportable_s29gl256p10tfi01_0001227e.bin", 0x00000, 0x2000000, CRC(8f8c8da7) SHA1(76a18458922e39abe1982f05f184babb5e65acf2) ) +ROM_END + +ROM_START( dgun2573a ) + ROM_REGION( 0x2000000, "mainrom", 0 ) + ROM_LOAD( "myarcadegamerportabledreamgear_s29gl256p10tfi01_0001227e.bin", 0x00000, 0x2000000, CRC(928c41ad) SHA1(c0119a13a47a5b784d0b834d1451973ff0b4a84f) ) +ROM_END + +ROM_START( bittboy ) + ROM_REGION( 0x2000000, "mainrom", 0 ) + ROM_LOAD( "bittboy_flash_read_s29gl256n-tf-v2.bin", 0x00000, 0x2000000, CRC(24c802d7) SHA1(c1300ff799b93b9b53060b94d3985db4389c5d3a) ) +ROM_END + +ROM_START( mc_cb280 ) + ROM_REGION( 0x400000, "mainrom", 0 ) + ROM_LOAD( "w25q32.u5", 0x00000, 0x400000, CRC(c9541bdf) SHA1(f0ce46f18658ca5dbed881e5a80460e59820bbd0) ) +ROM_END + +ROM_START( mc_pg150 ) + ROM_REGION( 0x2000000, "mainrom", 0 ) + ROM_LOAD( "pocketgames150-in1.bin", 0x00000, 0x2000000, CRC(32f1176b) SHA1(2cfd9b61ebdfc328f020ae9bd5e5e2219321e828) ) +ROM_END + +ROM_START( mc_hh210 ) + ROM_REGION( 0x1000000, "mainrom", 0 ) + ROM_LOAD( "msp55lv128t.u4", 0x00000, 0x1000000, CRC(9ba520d4) SHA1(627f811b24314197e289a2ade668ff4115421bed) ) +ROM_END + +ROM_START( dvnimbus ) + ROM_REGION( 0x1000000, "mainrom", 0 ) + ROM_LOAD( "2012-7-4-v1.bin", 0x00000, 0x1000000, CRC(a91d7aa6) SHA1(9421b70b281bb630752bc352c3715258044c0bbe) ) +ROM_END + +ROM_START( unkra200 ) // "Winbond 25Q64FVSIG 1324" SPI ROM + ROM_REGION( 0x800000, "mainrom", 0 ) + ROM_LOAD( "retro_machine_rom", 0x00000, 0x800000, CRC(0e824aa7) SHA1(957e98868559ecc22b3fa42c76692417b76bf132) ) +ROM_END + +ROM_START( rminitv ) + ROM_REGION( 0x2000000, "mainrom", 0 ) + ROM_LOAD( "29gl256.bin", 0x00000, 0x2000000, CRC(cb4048d4) SHA1(9877ce5716d13f8498abfc1cbfaefa9426205d3e) ) +ROM_END + +ROM_START( denv150 ) + ROM_REGION( 0x1000000, "mainrom", 0 ) + ROM_LOAD( "denver150in1.bin", 0x00000, 0x1000000, CRC(6b3819d7) SHA1(b0039945ce44a52ea224ab736d5f3c6980409b5d) ) // 2nd half is blank +ROM_END + +ROM_START( mog_m320 ) + ROM_REGION( 0x800000, "mainrom", 0 ) + ROM_LOAD( "w25q64fv.bin", 0x00000, 0x800000, CRC(3c5e1b36) SHA1(4bcbf35ebf2b1714ccde5de758a89a6a39528f89) ) +ROM_END + +ROM_START( fcpocket ) + ROM_REGION( 0x8000000, "mainrom", 0 ) + ROM_LOAD( "s29gl01gp.bin", 0x00000, 0x8000000, CRC(8703b18a) SHA1(07943443294e80ca93f83181c8bdbf950b87c52f) ) // 2nd half = 0x00 (so 64MByte of content) +ROM_END + +ROM_START( fapocket ) + ROM_REGION( 0x4000000, "mainrom", 0 ) + ROM_LOAD( "s29gl512n.bin", 0x00000, 0x4000000, CRC(37d0fb06) SHA1(0146a2fae32e23b65d4032c508f0d12cedd399c3) ) +ROM_END + +ROM_START( otrail ) + ROM_REGION( 0x100000, "mainrom", 0 ) + ROM_LOAD( "g25q80cw.bin", 0x00000, 0x100000, CRC(b20a03ba) SHA1(c4ca8e590b07baaebed747537bc8f92e44bdd219) ) // dumped as QD25Q80C + + ROM_REGION( 0x200, "seeprom", 0 ) + ROM_LOAD( "t24c04a.bin", 0x000, 0x200, CRC(ce1fad6f) SHA1(82878996765739edba42042b6336460d5c8f8096) ) +ROM_END + +ROM_START( zonefusn ) + ROM_REGION( 0x1000000, "mainrom", 0 ) + ROM_LOAD( "fusion.bin", 0x00000, 0x1000000, CRC(240bf970) SHA1(1b82d95a252c08e52fb8da6320276574a30b60db) ) +ROM_END + +void nes_vt3x_state::init_lxcmcypp() +{ + int size = memregion("mainrom")->bytes()/2; + uint16_t* ROM = (uint16_t*)memregion("mainrom")->base(); + + for (int i = 0; i < size; i++) + { + ROM[i] = bitswap<16>(ROM[i], 4, 5, 6, 7, 0, 1, 2, 3, 12, 13, 14, 15, 8, 9, 10, 11); + } +} + +// Runs well, only issues in SMB3 which crashes +CONS( 2017, bittboy, 0, 0, nes_vt3x_bt_2x16mb, nes_vt3x, nes_vt3x_cy_state, empty_init, "BittBoy", "BittBoy Mini FC 300 in 1", MACHINE_IMPERFECT_GRAPHICS ) // has external banking (2x 16mbyte banks) +// Broken GFX, investigate, is this really a system? research indicates it's a multicart for a regular NES? +CONS( 201?, mc_pg150, 0, 0, nes_vt3x_bt_2x16mb, nes_vt3x, nes_vt3x_cy_state, empty_init, "", "Pocket Games 150 in 1", MACHINE_NOT_WORKING ) // has external banking +// No title screen, but press start and menu and games run fine. Makes odd +// memory accesses which probably explain broken title screen +CONS( 201?, mc_hh210, 0, 0, nes_vt3x_4k_ram_16mb, nes_vt3x, nes_vt3x_state, empty_init, "", "Handheld 210 in 1", MACHINE_NOT_WORKING ) +// First half of games don't work, probably bad dump +CONS( 201?, dvnimbus, 0, 0, nes_vt3x_unk_16mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "", "DVTech Nimbus 176 in 1", MACHINE_NOT_WORKING ) + // probably another Thumbs Up product? cursor doesn't work unless nes_vt3x_hh machine is used? possibly newer than VT02 as it runs from an SPI ROM, might just not use enhanced features. Some minor game name changes to above (eg Smackdown just becomes Wrestling) +CONS( 201?, unkra200, mc_tv200, 0, nes_vt3x_hh_8mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "", "200 in 1 Retro Arcade", MACHINE_IMPERFECT_GRAPHICS ) + +// is this vt09 or vt32? +// Use DIP switch to select console or cartridge, as cartridge is fake and just toggles a ROM high address bit +// (which can also be overriden by GPIO) +CONS( 2017, fapocket, 0, 0, nes_vt3x_fa_4x16mb, nes_vt3x_fa, nes_vt3x_dg_fapocket_state, empty_init, "", "Family Pocket 638 in 1", MACHINE_IMPERFECT_GRAPHICS ) // has external banking (4x 16mbyte banks) + + +// Runs well, minor GFX issues in intro +CONS( 2017, sy889, 0, 0, nes_vt3x_hh_8mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "SY Corp", "SY-889 300 in 1 Handheld", MACHINE_IMPERFECT_GRAPHICS ) +CONS( 2016, sy888b, 0, 0, nes_vt3x_hh_4mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "SY Corp", "SY-888B 288 in 1 Handheld", MACHINE_IMPERFECT_GRAPHICS ) + +// Same hardware as SY-889 +CONS( 201?, mc_cb280, 0, 0, nes_vt3x_hh_4mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "CoolBoy", "Coolboy RS-18 (280 in 1)", MACHINE_IMPERFECT_GRAPHICS ) + +// Plays intro music but then crashes. same hardware as SY-88x but uses more features +CONS( 2016, mog_m320, 0, 0, nes_vt3x_hh_8mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "MOGIS", "MOGIS M320 246 in 1 Handheld", MACHINE_NOT_WORKING ) + +// similar menus to above, but with opcode scrambling +CONS( 2015, dgun2573, 0, 0, nes_vt3x_fp_32mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "dreamGEAR", "My Arcade Gamer V Portable Gaming System (DGUN-2573) (set 1, newer)", MACHINE_WRONG_COLORS | MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) +CONS( 2015, dgun2573a, dgun2573, 0, nes_vt3x_fp_32mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "dreamGEAR", "My Arcade Gamer V Portable Gaming System (DGUN-2573) (set 2, older)", MACHINE_WRONG_COLORS | MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // some menu graphics haven't been updated to reflect 'Panda' theme to the sports games + +CONS( 2015, rminitv, 0, 0, nes_vt3x_fp_pal_32mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "Orb Gaming", "Retro 'Mini TV' Console 300-in-1", MACHINE_IMPERFECT_GRAPHICS ) // single 32Mbyte bank! +// New platform with scrambled opcodes, same as DGUN-2561. Runs fine with minor GFX and sound issues in menu +// Use DIP switch to select console or cartridge, as cartridge is fake and just toggles a GPIO +CONS( 2016, fcpocket, 0, 0, nes_vt3x_fp_4x16mb, nes_vt3x_fp, nes_vt3x_unk_state, empty_init, "", "FC Pocket 600 in 1", MACHINE_IMPERFECT_GRAPHICS | MACHINE_IMPERFECT_SOUND ) // has external banking (2x 32mbyte banks) + + +/**************************************************************************************************************** + + Things below seem on heavily enhanced hardware of unknown VT type + + It's possible some of these are the same as some of the ones above (sy889, rminitv, dgun2573 etc.) but with + more features used. + + In some cases these might be almost entirely different, and it is likely a number don't belong in this + driver at all. + +****************************************************************************************************************/ + +// don't even get to menu. very enhanced chipset, VT368/9? +CONS( 2012, dgun2561, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "dreamGEAR", "My Arcade Portable Gaming System with 140 Games (DGUN-2561)", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme +CONS( 2016, dgun2593, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "dreamGEAR", "My Arcade Retro Arcade Machine - 300 Handheld Video Games (DGUN-2593)", MACHINE_NOT_WORKING ) // 128Mbyte ROM, must be externally banked or different addressing scheme + +CONS( 200?, lxcmcy, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme +CONS( 200?, lxcmc250, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - 250-in-1 (JL2375)", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme +CONS( 200?, lxcmcysw, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Star Wars Rebels", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme +CONS( 200?, lxcmcyfz, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Frozen", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme +CONS( 200?, lxcmcydp, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Disney Princess", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme +CONS( 200?, lxcmcysp, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Marvel Ultimate Spider-Man", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme +CONS( 200?, lxcmcycr, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Compact Cyber Arcade - Cars", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme +// the data order is swapped for this one, maybe other internal differences? +CONS( 200?, lxcmcypp, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, init_lxcmcypp, "Lexibook", "Lexibook Compact Cyber Arcade - Paw Patrol", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme + + +CONS( 200?, lxccminn, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Console Colour - Minnie Mouse", MACHINE_NOT_WORKING ) // 64Mbyte (used) ROM, must be externally banked, or different addressing scheme +CONS( 200?, lxccplan, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Console Colour - Disney's Planes", MACHINE_NOT_WORKING ) // 64Mbyte (used) ROM, must be externally banked, or different addressing scheme + + +// GB-NO13-Main-VT389-2 on PCBs +CONS( 2016, rtvgc300, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Retro TV Game Console - 300 Games", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme +CONS( 2017, rtvgc300fz,0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Lexibook", "Lexibook Retro TV Game Console - Frozen - 300 Games", MACHINE_NOT_WORKING ) // 64Mbyte ROM, must be externally banked, or different addressing scheme + + +/* The following are also confirmed to be NES/VT derived units, most having a standard set of games with a handful of lazy graphic mods thrown in to fit the unit theme + + (handheld units, use standard AAA batteries) + Lexibook Compact Cyber Arcade - Barbie + Lexibook Compact Cyber Arcade - Finding Dory + Lexibook Compact Cyber Arcade - PJ Masks + + (Handheld units, but different form factor to Compact Cyber Arcade, charged via USB) + Lexibook Console Colour - Barbie + + (units for use with TV) + Lexibook Retro TV Game Console (300 Games) - Cars + Lexibook Retro TV Game Console (300 Games) - PJ Masks + + (more?) + + There are also updated 'Compact Cyber Arcade' branded units with a large + D-pad and internal battery / USB charger for + Spiderman + Frozen + (generic) + it isn't verified if these use the same ROMs as the original Compact Cyber Arcade releases, or if the software has been updated + +*/ + +// intial code isn't valid? scrambled? +CONS( 201?, red5mam, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Red5", "Mini Arcade Machine (Red5)", MACHINE_NOT_WORKING ) // 128Mbyte ROM, must be externally banked or different addressing scheme + +CONS( 201?, denv150, 0, 0, nes_vt3x_cy_bigger, nes_vt3x, nes_vt3x_cy_state, empty_init, "Denver", "Denver Game Console GMP-240C 150-in-1", MACHINE_NOT_WORKING | MACHINE_IMPERFECT_GRAPHICS ) + +// same encryption as above, but seems like newer hardware (or the above aren't using most of the features) +CONS( 200?, lpgm240, 0, 0, nes_vt3x_vh2009_8mb, nes_vt3x, nes_vt3x_swap_op_d5_d6_state, empty_init, "", "Let's Play! Game Machine 240 in 1", MACHINE_NOT_WORKING ) // mini 'retro-arcade' style cabinet + +CONS( 2017, otrail, 0, 0, nes_vt3x_unk_1mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "Basic Fun", "The Oregon Trail", MACHINE_NOT_WORKING | MACHINE_IMPERFECT_GRAPHICS ) + +CONS( 200?, zonefusn, 0, 0, nes_vt3x_fp_16mb, nes_vt3x, nes_vt3x_unk_state, empty_init, "Ultimate Products / Jungle's Soft", "Zone Fusion", MACHINE_NOT_WORKING ) diff --git a/src/mame/machine/nes_vt_soc.cpp b/src/mame/machine/nes_vt_soc.cpp index 6467c9b4ba3..420290396d6 100644 --- a/src/mame/machine/nes_vt_soc.cpp +++ b/src/mame/machine/nes_vt_soc.cpp @@ -9,13 +9,13 @@ This list is incomplete - VT01 - plain famiclone? + VT01 - only enhancement over plain Famiclone is ability to drive STN displays directly VT02 - banking scheme to access 32MB, Dual APU with PCM support VT03 - above + 4bpp sprite / bg modes, enhanced palette VT08 - ? - VT09 - alt 4bpp mode, 4KB system RAM + VT09 - alt 4bpp mode, 4KB system RAM, DMA isn't bugged in NTSC mode? VT16 - ? VT18 - ? @@ -44,12 +44,16 @@ APU refactoring to allow for mostly doubled up functionality + PCM channel *more* - todo (newer VTxx): + TODO: + (newer VTxx) new PCM audio in FC Pocket and DGUN-2573 add support for VT368 (?) in DGUN-2561 and lxcmcy add support for the VT369 (?) featurs used by the MOGIS M320 + (general) + split into multipe files once feature boundaries are properly established + **************************************************************************/ #include "emu.h" @@ -58,27 +62,34 @@ // TODO: identify what kind of SoCs each of these are (some are probably meant to be the same chip, just with subsets of the features added at the moment, especially the CY/BT/HH ones) // also work out if some of these features (eg. opcode scrambling) should be done with external callbacks, sometimes the die was the same (VH2009) but encryption not always present (pin control or external feature?) -DEFINE_DEVICE_TYPE(NES_VT_SOC, nes_vt_soc_device, "nes_vt_soc", "VTxx series System on a Chip (NTSC)") -DEFINE_DEVICE_TYPE(NES_VT_SOC_PAL, nes_vt_soc_pal_device, "nes_vt_soc_pal", "VTxx series System on a Chip (PAL)") +DEFINE_DEVICE_TYPE(NES_VT02_VT03_SOC, nes_vt02_vt03_soc_device, "nes_vt02_vt03_soc", "VT02/03 series System on a Chip (NTSC)") +DEFINE_DEVICE_TYPE(NES_VT02_VT03_SOC_PAL, nes_vt02_vt03_soc_pal_device, "nes_vt02_vt03_soc_pal", "VT02/03 series System on a Chip (PAL)") +DEFINE_DEVICE_TYPE(NES_VT02_VT03_SOC_SCRAMBLE, nes_vt02_vt03_soc_scramble_device, "nes_vt02_vt03_soc_scram", "VT02/03 series System on a Chip (NTSC, with simple Opcode scrambling)") -DEFINE_DEVICE_TYPE(NES_VT_SOC_SCRAMBLE, nes_vt_soc_scramble_device, "nes_vt_soc_scram", "VTxx series System on a Chip (with simple Opcode scrambling)") +DEFINE_DEVICE_TYPE(NES_VT09_SOC, nes_vt09_soc_device, "nes_vt09_soc", "VT09 series System on a Chip (NTSC)") -DEFINE_DEVICE_TYPE(NES_VT_SOC_4KRAM, nes_vt_soc_4kram_device, "nes_vt_soc_4k", "VTxx series System on a Chip (with 4KByte RAM)") -DEFINE_DEVICE_TYPE(NES_VT_SOC_4KRAM_CY, nes_vt_soc_4kram_cy_device, "nes_vt_soc_4k_cy", "VTxx series System on a Chip (with 4KByte RAM) (CY)") -DEFINE_DEVICE_TYPE(NES_VT_SOC_4KRAM_BT, nes_vt_soc_4kram_bt_device, "nes_vt_soc_4k_bt", "VTxx series System on a Chip (with 4KByte RAM) (BT)") -DEFINE_DEVICE_TYPE(NES_VT_SOC_4KRAM_HH, nes_vt_soc_4kram_hh_device, "nes_vt_soc_4k_hh", "VTxx series System on a Chip (with 4KByte RAM) (HH)") +// everything below is still uncertain -DEFINE_DEVICE_TYPE(NES_VT_SOC_4KRAM_FP, nes_vt_soc_4kram_fp_device, "nes_vt_soc_4k_fp", "VTxx series System on a Chip (with 4KByte RAM) (FP) (NTSC)") -DEFINE_DEVICE_TYPE(NES_VT_SOC_4KRAM_FP_PAL, nes_vt_soc_4kram_fp_pal_device, "nes_vt_soc_4k_fp_pal", "VTxx series System on a Chip (with 4KByte RAM) (FP) (PAL)") +// these might not be VT09, but VT32 +DEFINE_DEVICE_TYPE(NES_VT09_SOC_CY, nes_vt09_soc_cy_device, "nes_vt09_soc_cy", "VT09/32 series System on a Chip (CY)") +DEFINE_DEVICE_TYPE(NES_VT09_SOC_BT, nes_vt09_soc_bt_device, "nes_vt09_soc_bt", "VT09/32 series System on a Chip (BT)") -DEFINE_DEVICE_TYPE(NES_VT_SOC_8KRAM_DG, nes_vt_soc_8kram_dg_device, "nes_vt_soc_8k_dg", "VTxx series System on a Chip (with 8KByte RAM) (DG)") -DEFINE_DEVICE_TYPE(NES_VT_SOC_8KRAM_FA, nes_vt_soc_8kram_fa_device, "nes_vt_soc_8k_fa", "VTxx series System on a Chip (with 8KByte RAM) (FA)") +// these have RGB12 output mode +DEFINE_DEVICE_TYPE(NES_VT32_SOC, nes_vt32_soc_device, "nes_vt32_soc", "VT32 series System on a Chip (FP) (NTSC)") +DEFINE_DEVICE_TYPE(NES_VT32_SOC_PAL, nes_vt32_soc_pal_device, "nes_vt32_soc_pal", "VT32 series System on a Chip (FP) (PAL)") -void nes_vt_soc_device::program_map(address_map &map) +// this has a new RGB555 mode +DEFINE_DEVICE_TYPE(NES_VT369_SOC, nes_vt369_soc_device, "nes_vt369_soc_hh", "VT369 series System on a Chip") + +// unknown +DEFINE_DEVICE_TYPE(NES_VT3X_SOC_DG, nes_vt3x_soc_dg_device, "nes_vt3x_soc_dg", "VT3x series System on a Chip (DG)") +DEFINE_DEVICE_TYPE(NES_VT3X_SOC_FA, nes_vt3x_soc_fa_device, "nes_vt3x_soc_fa", "VT3x series System on a Chip (Family Pocket)") + +void nes_vt02_vt03_soc_device::program_map(address_map &map) { } -nes_vt_soc_device::nes_vt_soc_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : +nes_vt02_vt03_soc_device::nes_vt02_vt03_soc_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : device_t(mconfig, type, tag, owner, clock), device_memory_interface(mconfig, *this), m_maincpu(*this, "maincpu"), @@ -88,7 +99,7 @@ nes_vt_soc_device::nes_vt_soc_device(const machine_config& mconfig, device_type m_initial_e000_bank(0xff), m_ntram(nullptr), m_chrram(nullptr), - m_space_config("program", ENDIANNESS_LITTLE, 8, 25, 0, address_map_constructor(FUNC(nes_vt_soc_device::program_map), this)), + m_space_config("program", ENDIANNESS_LITTLE, 8, 25, 0, address_map_constructor(FUNC(nes_vt02_vt03_soc_device::program_map), this)), m_write_0_callback(*this), m_read_0_callback(*this), m_read_1_callback(*this), @@ -124,88 +135,88 @@ nes_vt_soc_device::nes_vt_soc_device(const machine_config& mconfig, device_type m_use_raster_timing_hack = false; } -nes_vt_soc_device::nes_vt_soc_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_device(mconfig, NES_VT_SOC, tag, owner, clock) +nes_vt02_vt03_soc_device::nes_vt02_vt03_soc_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt02_vt03_soc_device(mconfig, NES_VT02_VT03_SOC, tag, owner, clock) { } -nes_vt_soc_pal_device::nes_vt_soc_pal_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_device(mconfig, NES_VT_SOC_PAL, tag, owner, clock) +nes_vt02_vt03_soc_pal_device::nes_vt02_vt03_soc_pal_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt02_vt03_soc_device(mconfig, NES_VT02_VT03_SOC_PAL, tag, owner, clock) { } -nes_vt_soc_scramble_device::nes_vt_soc_scramble_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_device(mconfig, NES_VT_SOC_SCRAMBLE, tag, owner, clock) +nes_vt02_vt03_soc_scramble_device::nes_vt02_vt03_soc_scramble_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt02_vt03_soc_device(mconfig, NES_VT02_VT03_SOC_SCRAMBLE, tag, owner, clock) { } -nes_vt_soc_4kram_device::nes_vt_soc_4kram_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_4kram_device(mconfig, NES_VT_SOC_4KRAM, tag, owner, clock) +nes_vt09_soc_device::nes_vt09_soc_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt09_soc_device(mconfig, NES_VT09_SOC, tag, owner, clock) { } -nes_vt_soc_4kram_device::nes_vt_soc_4kram_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_device(mconfig, type, tag, owner, clock), +nes_vt09_soc_device::nes_vt09_soc_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : + nes_vt02_vt03_soc_device(mconfig, type, tag, owner, clock), m_upper_write_412c_callback(*this), m_upper_read_412c_callback(*this), m_upper_read_412d_callback(*this) { } -nes_vt_soc_4kram_cy_device::nes_vt_soc_4kram_cy_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_4kram_device(mconfig, NES_VT_SOC_4KRAM_CY, tag, owner, clock) +nes_vt09_soc_cy_device::nes_vt09_soc_cy_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt09_soc_device(mconfig, NES_VT09_SOC_CY, tag, owner, clock) { } -nes_vt_soc_4kram_bt_device::nes_vt_soc_4kram_bt_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_4kram_device(mconfig, NES_VT_SOC_4KRAM_BT, tag, owner, clock) +nes_vt09_soc_bt_device::nes_vt09_soc_bt_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt09_soc_device(mconfig, NES_VT09_SOC_BT, tag, owner, clock) { } -nes_vt_soc_4kram_hh_device::nes_vt_soc_4kram_hh_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_4kram_device(mconfig, type, tag, owner, clock) +nes_vt369_soc_device::nes_vt369_soc_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : + nes_vt09_soc_device(mconfig, type, tag, owner, clock) { } -nes_vt_soc_4kram_hh_device::nes_vt_soc_4kram_hh_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_4kram_hh_device(mconfig, NES_VT_SOC_4KRAM_HH, tag, owner, clock) +nes_vt369_soc_device::nes_vt369_soc_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt369_soc_device(mconfig, NES_VT369_SOC, tag, owner, clock) { } -nes_vt_soc_4kram_fp_device::nes_vt_soc_4kram_fp_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_4kram_fp_device(mconfig, NES_VT_SOC_4KRAM_FP, tag, owner, clock) +nes_vt32_soc_device::nes_vt32_soc_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt32_soc_device(mconfig, NES_VT32_SOC, tag, owner, clock) { } -nes_vt_soc_4kram_fp_device::nes_vt_soc_4kram_fp_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_4kram_hh_device(mconfig, type, tag, owner, clock) +nes_vt32_soc_device::nes_vt32_soc_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : + nes_vt369_soc_device(mconfig, type, tag, owner, clock) { } -nes_vt_soc_4kram_fp_pal_device::nes_vt_soc_4kram_fp_pal_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_4kram_fp_device(mconfig, NES_VT_SOC_4KRAM_FP_PAL, tag, owner, clock) +nes_vt32_soc_pal_device::nes_vt32_soc_pal_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt32_soc_device(mconfig, NES_VT32_SOC_PAL, tag, owner, clock) { } -nes_vt_soc_8kram_dg_device::nes_vt_soc_8kram_dg_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_4kram_device(mconfig, type, tag, owner, clock) +nes_vt3x_soc_dg_device::nes_vt3x_soc_dg_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock) : + nes_vt09_soc_device(mconfig, type, tag, owner, clock) { } -nes_vt_soc_8kram_dg_device::nes_vt_soc_8kram_dg_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_8kram_dg_device(mconfig, NES_VT_SOC_8KRAM_DG, tag, owner, clock) +nes_vt3x_soc_dg_device::nes_vt3x_soc_dg_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt3x_soc_dg_device(mconfig, NES_VT3X_SOC_DG, tag, owner, clock) { } -nes_vt_soc_8kram_fa_device::nes_vt_soc_8kram_fa_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : - nes_vt_soc_8kram_dg_device(mconfig, NES_VT_SOC_8KRAM_FA, tag, owner, clock) +nes_vt3x_soc_fa_device::nes_vt3x_soc_fa_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock) : + nes_vt3x_soc_dg_device(mconfig, NES_VT3X_SOC_FA, tag, owner, clock) { } -void nes_vt_soc_device::device_start() +void nes_vt02_vt03_soc_device::device_start() { save_item(NAME(m_410x)); @@ -226,13 +237,13 @@ void nes_vt_soc_device::device_start() m_chrram = std::make_unique(0x2000); save_pointer(NAME(m_chrram), 0x2000); - m_ppu->set_scanline_callback(*this, FUNC(nes_vt_soc_device::scanline_irq)); - m_ppu->set_hblank_callback(*this, FUNC(nes_vt_soc_device::hblank_irq)); + m_ppu->set_scanline_callback(*this, FUNC(nes_vt02_vt03_soc_device::scanline_irq)); + m_ppu->set_hblank_callback(*this, FUNC(nes_vt02_vt03_soc_device::hblank_irq)); //m_ppu->set_hblank_callback(*m_cartslot->m_cart, FUNC(device_nes_cart_interface::hblank_irq))); //m_ppu->space(AS_PROGRAM).install_readwrite_handler(0, 0x1fff, read8sm_delegate(*m_cartslot->m_cart, FUNC(device_nes_cart_interface::chr_r)), write8sm_delegate(*m_cartslot->m_cart, FUNC(device_nes_cart_interface::chr_w))); - m_ppu->space(AS_PROGRAM).install_readwrite_handler(0x2000, 0x3eff, read8sm_delegate(*this, FUNC(nes_vt_soc_device::nt_r)), write8sm_delegate(*this, FUNC(nes_vt_soc_device::nt_w))); - m_ppu->space(AS_PROGRAM).install_readwrite_handler(0, 0x1fff, read8sm_delegate(*this, FUNC(nes_vt_soc_device::chr_r)), write8sm_delegate(*this, FUNC(nes_vt_soc_device::chr_w))); + m_ppu->space(AS_PROGRAM).install_readwrite_handler(0x2000, 0x3eff, read8sm_delegate(*this, FUNC(nes_vt02_vt03_soc_device::nt_r)), write8sm_delegate(*this, FUNC(nes_vt02_vt03_soc_device::nt_w))); + m_ppu->space(AS_PROGRAM).install_readwrite_handler(0, 0x1fff, read8sm_delegate(*this, FUNC(nes_vt02_vt03_soc_device::chr_r)), write8sm_delegate(*this, FUNC(nes_vt02_vt03_soc_device::chr_w))); m_write_0_callback.resolve_safe(); m_read_0_callback.resolve_safe(0xff); @@ -249,7 +260,7 @@ void nes_vt_soc_device::device_start() m_extra_read_3_callback.resolve_safe(0xff); } -void nes_vt_soc_device::device_reset() +void nes_vt02_vt03_soc_device::device_reset() { // what are the actual defaults? m_410x[0x0] = 0x00; @@ -280,7 +291,7 @@ void nes_vt_soc_device::device_reset() } -uint32_t nes_vt_soc_device::get_banks(uint8_t bnk) +uint32_t nes_vt02_vt03_soc_device::get_banks(uint8_t bnk) { switch (m_410x[0xb] & 0x07) { @@ -298,7 +309,7 @@ uint32_t nes_vt_soc_device::get_banks(uint8_t bnk) } // 8000 needs to bank in 60000 ( bank 0x30 ) -void nes_vt_soc_device::update_banks() +void nes_vt02_vt03_soc_device::update_banks() { uint8_t bank; @@ -337,7 +348,7 @@ void nes_vt_soc_device::update_banks() m_bankaddr[3] = get_banks(bank); } -uint16_t nes_vt_soc_device::decode_nt_addr(uint16_t addr) +uint16_t nes_vt02_vt03_soc_device::decode_nt_addr(uint16_t addr) { bool vert_mirror = !(m_410x[0x6] & 0x01); int a11 = (addr >> 11) & 0x01; @@ -346,12 +357,12 @@ uint16_t nes_vt_soc_device::decode_nt_addr(uint16_t addr) return ((vert_mirror ? a10 : a11) << 10) | base; } -void nes_vt_soc_device::vt03_410x_w(offs_t offset, uint8_t data) +void nes_vt02_vt03_soc_device::vt03_410x_w(offs_t offset, uint8_t data) { scrambled_410x_w(offset, data); } -uint8_t nes_vt_soc_device::vt03_410x_r(offs_t offset) +uint8_t nes_vt02_vt03_soc_device::vt03_410x_r(offs_t offset) { return m_410x[offset]; } @@ -359,7 +370,7 @@ uint8_t nes_vt_soc_device::vt03_410x_r(offs_t offset) // Source: https://wiki.nesdev.com/w/index.php/NES_2.0_submappers/Proposals#NES_2.0_Mapper_256 -void nes_vt_soc_device::scrambled_410x_w(uint16_t offset, uint8_t data) +void nes_vt02_vt03_soc_device::scrambled_410x_w(uint16_t offset, uint8_t data) { switch (offset) { @@ -456,7 +467,7 @@ void nes_vt_soc_device::scrambled_410x_w(uint16_t offset, uint8_t data) -uint8_t nes_vt_soc_device::spr_r(offs_t offset) +uint8_t nes_vt02_vt03_soc_device::spr_r(offs_t offset) { if (m_4242 & 0x1 || m_411d & 0x04) { @@ -471,7 +482,7 @@ uint8_t nes_vt_soc_device::spr_r(offs_t offset) } } -uint8_t nes_vt_soc_device::chr_r(offs_t offset) +uint8_t nes_vt02_vt03_soc_device::chr_r(offs_t offset) { if (m_4242 & 0x1 || m_411d & 0x04) // newer VT platforms only (not VT03/09), split out { @@ -487,7 +498,7 @@ uint8_t nes_vt_soc_device::chr_r(offs_t offset) } -void nes_vt_soc_device::chr_w(offs_t offset, uint8_t data) +void nes_vt02_vt03_soc_device::chr_w(offs_t offset, uint8_t data) { if (m_4242 & 0x1 || m_411d & 0x04) // newer VT platforms only (not VT03/09), split out { @@ -505,17 +516,17 @@ void nes_vt_soc_device::chr_w(offs_t offset, uint8_t data) -void nes_vt_soc_device::scanline_irq(int scanline, int vblank, int blanked) +void nes_vt02_vt03_soc_device::scanline_irq(int scanline, int vblank, int blanked) { video_irq(false, scanline, vblank, blanked); } -void nes_vt_soc_device::hblank_irq(int scanline, int vblank, int blanked) +void nes_vt02_vt03_soc_device::hblank_irq(int scanline, int vblank, int blanked) { video_irq(true, scanline, vblank, blanked); } -void nes_vt_soc_device::video_irq(bool hblank, int scanline, int vblank, int blanked) +void nes_vt02_vt03_soc_device::video_irq(bool hblank, int scanline, int vblank, int blanked) { //TSYNEN if (((m_410x[0xb] >> 7) & 0x01) == hblank) @@ -546,12 +557,12 @@ void nes_vt_soc_device::video_irq(bool hblank, int scanline, int vblank, int bla } /* todo, handle custom VT nametable stuff here */ -uint8_t nes_vt_soc_device::nt_r(offs_t offset) +uint8_t nes_vt02_vt03_soc_device::nt_r(offs_t offset) { return m_ntram[decode_nt_addr(offset)]; } -void nes_vt_soc_device::nt_w(offs_t offset, uint8_t data) +void nes_vt02_vt03_soc_device::nt_w(offs_t offset, uint8_t data) { //logerror("nt wr %04x %02x", offset, data); m_ntram[decode_nt_addr(offset)] = data; @@ -562,7 +573,7 @@ void nes_vt_soc_device::nt_w(offs_t offset, uint8_t data) -int nes_vt_soc_device::calculate_real_video_address(int addr, int extended, int readtype) +int nes_vt02_vt03_soc_device::calculate_real_video_address(int addr, int extended, int readtype) { // might be a VT09 only feature (alt 4bpp mode?) int alt_order = m_ppu->get_201x_reg(0x0) & 0x40; @@ -771,13 +782,13 @@ int nes_vt_soc_device::calculate_real_video_address(int addr, int extended, int } /* - nes_vt_soc_device::vt03_8000_mapper_w notes + nes_vt02_vt03_soc_device::vt03_8000_mapper_w notes used for MMC3/other mapper compatibility some consoles have scrambled registers for crude copy protection */ -void nes_vt_soc_device::scrambled_8000_w(uint16_t offset, uint8_t data) +void nes_vt02_vt03_soc_device::scrambled_8000_w(uint16_t offset, uint8_t data) { offset &= 0x7fff; @@ -903,7 +914,7 @@ void nes_vt_soc_device::scrambled_8000_w(uint16_t offset, uint8_t data) // MMC3 compatibility mode -void nes_vt_soc_device::set_8000_scramble(uint8_t reg0, uint8_t reg1, uint8_t reg2, uint8_t reg3, uint8_t reg4, uint8_t reg5, uint8_t reg6, uint8_t reg7) +void nes_vt02_vt03_soc_device::set_8000_scramble(uint8_t reg0, uint8_t reg1, uint8_t reg2, uint8_t reg3, uint8_t reg4, uint8_t reg5, uint8_t reg6, uint8_t reg7) { m_8000_scramble[0] = reg0; // TODO: name the regs m_8000_scramble[1] = reg1; @@ -915,13 +926,13 @@ void nes_vt_soc_device::set_8000_scramble(uint8_t reg0, uint8_t reg1, uint8_t re m_8000_scramble[7] = reg7; } -void nes_vt_soc_device::set_410x_scramble(uint8_t reg0, uint8_t reg1) +void nes_vt02_vt03_soc_device::set_410x_scramble(uint8_t reg0, uint8_t reg1) { m_410x_scramble[0] = reg0; // TODO: name the regs m_410x_scramble[1] = reg1; } -void nes_vt_soc_device::vt03_8000_mapper_w(offs_t offset, uint8_t data) +void nes_vt02_vt03_soc_device::vt03_8000_mapper_w(offs_t offset, uint8_t data) { scrambled_8000_w(offset, data); //logerror("%s: vt03_8000_mapper_w (%04x) %02x\n", machine().describe_context(), offset+0x8000, data ); @@ -929,29 +940,29 @@ void nes_vt_soc_device::vt03_8000_mapper_w(offs_t offset, uint8_t data) /* APU plumbing, this is because we have a plain M6502 core in the VT03, otherwise this is handled in the core */ -uint8_t nes_vt_soc_device::psg1_4014_r() +uint8_t nes_vt02_vt03_soc_device::psg1_4014_r() { //return m_apu->read(0x14); return 0x00; } -uint8_t nes_vt_soc_device::psg1_4015_r() +uint8_t nes_vt02_vt03_soc_device::psg1_4015_r() { return m_apu->read(0x15); } -void nes_vt_soc_device::psg1_4015_w(uint8_t data) +void nes_vt02_vt03_soc_device::psg1_4015_w(uint8_t data) { m_apu->write(0x15, data); } -void nes_vt_soc_device::psg1_4017_w(uint8_t data) +void nes_vt02_vt03_soc_device::psg1_4017_w(uint8_t data) { m_apu->write(0x17, data); } // early units (VT03?) have a DMA bug in NTSC mode -void nes_vt_soc_device::vt_dma_w(uint8_t data) +void nes_vt02_vt03_soc_device::vt_dma_w(uint8_t data) { if (!m_force_baddma) do_dma(data, true); @@ -961,7 +972,7 @@ void nes_vt_soc_device::vt_dma_w(uint8_t data) -void nes_vt_soc_device::do_dma(uint8_t data, bool has_ntsc_bug) +void nes_vt02_vt03_soc_device::do_dma(uint8_t data, bool has_ntsc_bug) { // only NTSC systems have 'broken' DMA which requires the DMA addresses to be shifted by 1, PAL systems work as expected if (m_ppu->get_is_pal()) @@ -1014,28 +1025,28 @@ void nes_vt_soc_device::do_dma(uint8_t data, bool has_ntsc_bug) } -void nes_vt_soc_device::vt03_4034_w(uint8_t data) +void nes_vt02_vt03_soc_device::vt03_4034_w(uint8_t data) { logerror("vt03_4034_w %02x\n", data); m_vdma_ctrl = data; } -uint8_t nes_vt_soc_device::in0_r() +uint8_t nes_vt02_vt03_soc_device::in0_r() { return m_read_0_callback(); } -uint8_t nes_vt_soc_device::in1_r() +uint8_t nes_vt02_vt03_soc_device::in1_r() { return m_read_1_callback(); } -void nes_vt_soc_device::in0_w(offs_t offset, uint8_t data) +void nes_vt02_vt03_soc_device::in0_w(offs_t offset, uint8_t data) { m_write_0_callback(offset, data); } -void nes_vt_soc_device::extra_io_control_w(uint8_t data) +void nes_vt02_vt03_soc_device::extra_io_control_w(uint8_t data) { /* 410d Extra I/O control @@ -1053,7 +1064,7 @@ void nes_vt_soc_device::extra_io_control_w(uint8_t data) logerror("%s: extra_io_control_w %02x\n", machine().describe_context(), data); } -uint8_t nes_vt_soc_device::extrain_01_r() +uint8_t nes_vt02_vt03_soc_device::extrain_01_r() { // TODO: check status of 410d port to make sure we only read from enabled ports uint8_t in0 = 0x00, in1 = 0x00; @@ -1064,7 +1075,7 @@ uint8_t nes_vt_soc_device::extrain_01_r() return in0 | (in1<<4); } -uint8_t nes_vt_soc_device::extrain_23_r() +uint8_t nes_vt02_vt03_soc_device::extrain_23_r() { // TODO: check status of 410d port to make sure we only read from enabled ports uint8_t in2 = 0x00, in3 = 0x00; @@ -1075,19 +1086,19 @@ uint8_t nes_vt_soc_device::extrain_23_r() return in2 | (in3<<4); } -void nes_vt_soc_device::extraout_01_w(uint8_t data) +void nes_vt02_vt03_soc_device::extraout_01_w(uint8_t data) { // TODO: use callbacks for this as output can be hooked up to anything logerror("%s: extraout_01_w %02x\n", machine().describe_context(), data); } -void nes_vt_soc_device::extraout_23_w(uint8_t data) +void nes_vt02_vt03_soc_device::extraout_23_w(uint8_t data) { // TODO: use callbacks for this as output can be hooked up to anything logerror("%s: extraout_23_w %02x\n", machine().describe_context(), data); } -uint8_t nes_vt_soc_device::rs232flags_region_r() +uint8_t nes_vt02_vt03_soc_device::rs232flags_region_r() { /* 0x4119 RS232 Flags + Region @@ -1113,7 +1124,7 @@ uint8_t nes_vt_soc_device::rs232flags_region_r() } -uint8_t nes_vt_soc_device::external_space_read(offs_t offset) +uint8_t nes_vt02_vt03_soc_device::external_space_read(offs_t offset) { address_space& spc = this->space(AS_PROGRAM); int bank = (offset & 0x6000) >> 13; @@ -1121,7 +1132,7 @@ uint8_t nes_vt_soc_device::external_space_read(offs_t offset) return spc.read_byte(address); } -void nes_vt_soc_device::external_space_write(offs_t offset, uint8_t data) +void nes_vt02_vt03_soc_device::external_space_write(offs_t offset, uint8_t data) { if ((m_410x[0xb] & 0x08)) { @@ -1136,7 +1147,7 @@ void nes_vt_soc_device::external_space_write(offs_t offset, uint8_t data) } }; -void nes_vt_soc_device::nes_vt_map(address_map &map) +void nes_vt02_vt03_soc_device::nes_vt_map(address_map &map) { map(0x0000, 0x07ff).ram().mirror(0x1800); // zudugo relies on mirror when selecting 'game' menu @@ -1147,68 +1158,68 @@ void nes_vt_soc_device::nes_vt_map(address_map &map) map(0x4000, 0x4013).rw(m_apu, FUNC(nesapu_device::read), FUNC(nesapu_device::write)); - map(0x4014, 0x4014).r(FUNC(nes_vt_soc_device::psg1_4014_r)).w(FUNC(nes_vt_soc_device::vt_dma_w)); - map(0x4015, 0x4015).rw(FUNC(nes_vt_soc_device::psg1_4015_r), FUNC(nes_vt_soc_device::psg1_4015_w)); // PSG status / first control register - map(0x4016, 0x4016).rw(FUNC(nes_vt_soc_device::in0_r), FUNC(nes_vt_soc_device::in0_w)); - map(0x4017, 0x4017).r(FUNC(nes_vt_soc_device::in1_r)).w(FUNC(nes_vt_soc_device::psg1_4017_w)); + map(0x4014, 0x4014).r(FUNC(nes_vt02_vt03_soc_device::psg1_4014_r)).w(FUNC(nes_vt02_vt03_soc_device::vt_dma_w)); + map(0x4015, 0x4015).rw(FUNC(nes_vt02_vt03_soc_device::psg1_4015_r), FUNC(nes_vt02_vt03_soc_device::psg1_4015_w)); // PSG status / first control register + map(0x4016, 0x4016).rw(FUNC(nes_vt02_vt03_soc_device::in0_r), FUNC(nes_vt02_vt03_soc_device::in0_w)); + map(0x4017, 0x4017).r(FUNC(nes_vt02_vt03_soc_device::in1_r)).w(FUNC(nes_vt02_vt03_soc_device::psg1_4017_w)); - map(0x4034, 0x4034).w(FUNC(nes_vt_soc_device::vt03_4034_w)); + map(0x4034, 0x4034).w(FUNC(nes_vt02_vt03_soc_device::vt03_4034_w)); - map(0x4100, 0x410b).r(FUNC(nes_vt_soc_device::vt03_410x_r)).w(FUNC(nes_vt_soc_device::vt03_410x_w)); + map(0x4100, 0x410b).r(FUNC(nes_vt02_vt03_soc_device::vt03_410x_r)).w(FUNC(nes_vt02_vt03_soc_device::vt03_410x_w)); // 0x410c unused - map(0x410d, 0x410d).w(FUNC(nes_vt_soc_device::extra_io_control_w)); - map(0x410e, 0x410e).rw(FUNC(nes_vt_soc_device::extrain_01_r), FUNC(nes_vt_soc_device::extraout_01_w)); - map(0x410f, 0x410f).rw(FUNC(nes_vt_soc_device::extrain_23_r), FUNC(nes_vt_soc_device::extraout_23_w)); + map(0x410d, 0x410d).w(FUNC(nes_vt02_vt03_soc_device::extra_io_control_w)); + map(0x410e, 0x410e).rw(FUNC(nes_vt02_vt03_soc_device::extrain_01_r), FUNC(nes_vt02_vt03_soc_device::extraout_01_w)); + map(0x410f, 0x410f).rw(FUNC(nes_vt02_vt03_soc_device::extrain_23_r), FUNC(nes_vt02_vt03_soc_device::extraout_23_w)); // 0x4114 RS232 timer (low) // 0x4115 RS232 timer (high) // 0x4116 unused // 0x4117 unused // 0x4118 unused - map(0x4119, 0x4119).r(FUNC(nes_vt_soc_device::rs232flags_region_r)); + map(0x4119, 0x4119).r(FUNC(nes_vt02_vt03_soc_device::rs232flags_region_r)); // 0x411a RS232 TX data // 0x411b RS232 RX data - map(0x8000, 0xffff).rw(FUNC(nes_vt_soc_device::external_space_read), FUNC(nes_vt_soc_device::external_space_write)); + map(0x8000, 0xffff).rw(FUNC(nes_vt02_vt03_soc_device::external_space_read), FUNC(nes_vt02_vt03_soc_device::external_space_write)); map(0x6000, 0x7fff).ram(); } -WRITE_LINE_MEMBER(nes_vt_soc_device::apu_irq) +WRITE_LINE_MEMBER(nes_vt02_vt03_soc_device::apu_irq) { // TODO // set_input_line(N2A03_APU_IRQ_LINE, state ? ASSERT_LINE : CLEAR_LINE); } -uint8_t nes_vt_soc_device::apu_read_mem(offs_t offset) +uint8_t nes_vt02_vt03_soc_device::apu_read_mem(offs_t offset) { // TODO return 0x00;//mintf->program->read_byte(offset); } -uint32_t nes_vt_soc_device::screen_update(screen_device& screen, bitmap_rgb32& bitmap, const rectangle& cliprect) +uint32_t nes_vt02_vt03_soc_device::screen_update(screen_device& screen, bitmap_rgb32& bitmap, const rectangle& cliprect) { return m_ppu->screen_update(screen, bitmap, cliprect); } -device_memory_interface::space_config_vector nes_vt_soc_device::memory_space_config() const +device_memory_interface::space_config_vector nes_vt02_vt03_soc_device::memory_space_config() const { return space_config_vector { std::make_pair(AS_PROGRAM, &m_space_config) }; } -void nes_vt_soc_device::do_pal_timings_and_ppu_replacement(machine_config& config) +void nes_vt02_vt03_soc_device::do_pal_timings_and_ppu_replacement(machine_config& config) { m_maincpu->set_clock(PALC_APU_CLOCK); PPU_VT03PAL(config.replace(), m_ppu, N2A03_PAL_XTAL); m_ppu->set_cpu_tag(m_maincpu); m_ppu->int_callback().set_inputline(m_maincpu, INPUT_LINE_NMI); - m_ppu->read_bg().set(FUNC(nes_vt_soc_device::chr_r)); - m_ppu->read_sp().set(FUNC(nes_vt_soc_device::spr_r)); + m_ppu->read_bg().set(FUNC(nes_vt02_vt03_soc_device::chr_r)); + m_ppu->read_sp().set(FUNC(nes_vt02_vt03_soc_device::spr_r)); m_ppu->set_screen(m_screen); m_screen->set_refresh_hz(50.0070); @@ -1219,10 +1230,10 @@ void nes_vt_soc_device::do_pal_timings_and_ppu_replacement(machine_config& confi } -void nes_vt_soc_device::device_add_mconfig(machine_config &config) +void nes_vt02_vt03_soc_device::device_add_mconfig(machine_config &config) { N2A03_CORE(config, m_maincpu, NTSC_APU_CLOCK); // Butterfly Catch in vgpocket confirms N2A03 core type, not 6502 - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_soc_device::nes_vt_map); + m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt02_vt03_soc_device::nes_vt_map); SCREEN(config, m_screen, SCREEN_TYPE_RASTER); m_screen->set_refresh_hz(60.0988); @@ -1230,27 +1241,27 @@ void nes_vt_soc_device::device_add_mconfig(machine_config &config) (ppu2c0x_device::VBLANK_LAST_SCANLINE_NTSC-ppu2c0x_device::VBLANK_FIRST_SCANLINE+1+2))); m_screen->set_size(32*8, 262); m_screen->set_visarea(0*8, 32*8-1, 0*8, 30*8-1); - m_screen->set_screen_update(FUNC(nes_vt_soc_device::screen_update)); + m_screen->set_screen_update(FUNC(nes_vt02_vt03_soc_device::screen_update)); PPU_VT03(config, m_ppu, N2A03_NTSC_XTAL); m_ppu->set_cpu_tag(m_maincpu); m_ppu->int_callback().set_inputline(m_maincpu, INPUT_LINE_NMI); - m_ppu->read_bg().set(FUNC(nes_vt_soc_device::chr_r)); - m_ppu->read_sp().set(FUNC(nes_vt_soc_device::spr_r)); + m_ppu->read_bg().set(FUNC(nes_vt02_vt03_soc_device::chr_r)); + m_ppu->read_sp().set(FUNC(nes_vt02_vt03_soc_device::spr_r)); m_ppu->set_screen(m_screen); /* sound hardware */ SPEAKER(config, "mono").front_center(); NES_APU_VT(config, m_apu, NTSC_APU_CLOCK); - m_apu->irq().set(FUNC(nes_vt_soc_device::apu_irq)); - m_apu->mem_read().set(FUNC(nes_vt_soc_device::apu_read_mem)); + m_apu->irq().set(FUNC(nes_vt02_vt03_soc_device::apu_irq)); + m_apu->mem_read().set(FUNC(nes_vt02_vt03_soc_device::apu_read_mem)); m_apu->add_route(ALL_OUTPUTS, "mono", 0.50); } -void nes_vt_soc_pal_device::device_add_mconfig(machine_config& config) +void nes_vt02_vt03_soc_pal_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_device::device_add_mconfig(config); + nes_vt02_vt03_soc_device::device_add_mconfig(config); do_pal_timings_and_ppu_replacement(config); } @@ -1259,40 +1270,40 @@ void nes_vt_soc_pal_device::device_add_mconfig(machine_config& config) /* 'Scramble' specifics */ /***********************************************************************************************************************************************************/ -void nes_vt_soc_scramble_device::device_add_mconfig(machine_config& config) +void nes_vt02_vt03_soc_scramble_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_device::device_add_mconfig(config); + nes_vt02_vt03_soc_device::device_add_mconfig(config); N2A03_CORE_SWAP_OP_D5_D6(config.replace(), m_maincpu, NTSC_APU_CLOCK); // Insect Chase in polmega confirms N2A03 core type, not 6502 - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_soc_scramble_device::nes_vt_map); + m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt02_vt03_soc_scramble_device::nes_vt_map); } /***********************************************************************************************************************************************************/ /* '4K' specifics */ /***********************************************************************************************************************************************************/ -void nes_vt_soc_4kram_device::device_add_mconfig(machine_config& config) +void nes_vt09_soc_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_device::device_add_mconfig(config); - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_soc_4kram_device::nes_vt_map); + nes_vt02_vt03_soc_device::device_add_mconfig(config); + m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt09_soc_device::nes_vt_4k_ram_map); } -void nes_vt_soc_4kram_device::device_start() +void nes_vt09_soc_device::device_start() { - nes_vt_soc_device::device_start(); + nes_vt02_vt03_soc_device::device_start(); m_upper_write_412c_callback.resolve_safe(); m_upper_read_412c_callback.resolve_safe(0xff); m_upper_read_412d_callback.resolve_safe(0xff); } -void nes_vt_soc_4kram_device::nes_vt_4k_ram_map(address_map &map) +void nes_vt09_soc_device::nes_vt_4k_ram_map(address_map &map) { - nes_vt_soc_device::nes_vt_map(map); + nes_vt02_vt03_soc_device::nes_vt_map(map); map(0x0800, 0x0fff).ram(); -// map(0x412c, 0x412c).rw(FUNC(nes_vt_soc_4kram_device::vtfp_412c_r, FUNC(nes_vt_soc_4kram_device::vtfp_412c_extbank_w)); // GPIO -// map(0x412d, 0x412d).r(FUNC(nes_vt_soc_4kram_device::vtfp_412d_r)); // GPIO +// map(0x412c, 0x412c).rw(FUNC(nes_vt09_soc_device::vtfp_412c_r, FUNC(nes_vt09_soc_device::vtfp_412c_extbank_w)); // GPIO +// map(0x412d, 0x412d).r(FUNC(nes_vt09_soc_device::vtfp_412d_r)); // GPIO } @@ -1300,31 +1311,31 @@ void nes_vt_soc_4kram_device::nes_vt_4k_ram_map(address_map &map) /* 'CY' specifics (base = '4K') */ /***********************************************************************************************************************************************************/ -void nes_vt_soc_4kram_cy_device::device_add_mconfig(machine_config& config) +void nes_vt09_soc_cy_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_device::device_add_mconfig(config); - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_soc_4kram_cy_device::nes_vt_cy_map); + nes_vt02_vt03_soc_device::device_add_mconfig(config); + m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt09_soc_cy_device::nes_vt_cy_map); } -void nes_vt_soc_4kram_cy_device::nes_vt_cy_map(address_map &map) +void nes_vt09_soc_cy_device::nes_vt_cy_map(address_map &map) { nes_vt_4k_ram_map(map); - map(0x41b0, 0x41bf).r(FUNC(nes_vt_soc_4kram_cy_device::vt03_41bx_r)).w(FUNC(nes_vt_soc_4kram_cy_device::vt03_41bx_w)); - map(0x4130, 0x4136).r(FUNC(nes_vt_soc_4kram_cy_device::vt03_413x_r)).w(FUNC(nes_vt_soc_4kram_cy_device::vt03_413x_w)); - map(0x414f, 0x414f).r(FUNC(nes_vt_soc_4kram_cy_device::vt03_414f_r)); - map(0x415c, 0x415c).r(FUNC(nes_vt_soc_4kram_cy_device::vt03_415c_r)); + map(0x41b0, 0x41bf).r(FUNC(nes_vt09_soc_cy_device::vt03_41bx_r)).w(FUNC(nes_vt09_soc_cy_device::vt03_41bx_w)); + map(0x4130, 0x4136).r(FUNC(nes_vt09_soc_cy_device::vt03_413x_r)).w(FUNC(nes_vt09_soc_cy_device::vt03_413x_w)); + map(0x414f, 0x414f).r(FUNC(nes_vt09_soc_cy_device::vt03_414f_r)); + map(0x415c, 0x415c).r(FUNC(nes_vt09_soc_cy_device::vt03_415c_r)); - map(0x48a0, 0x48af).r(FUNC(nes_vt_soc_4kram_cy_device::vt03_48ax_r)).w(FUNC(nes_vt_soc_4kram_cy_device::vt03_48ax_w)); + map(0x48a0, 0x48af).r(FUNC(nes_vt09_soc_cy_device::vt03_48ax_r)).w(FUNC(nes_vt09_soc_cy_device::vt03_48ax_w)); } -void nes_vt_soc_4kram_cy_device::device_start() +void nes_vt09_soc_cy_device::device_start() { - nes_vt_soc_device::device_start(); + nes_vt02_vt03_soc_device::device_start(); save_item(NAME(m_413x)); } -uint8_t nes_vt_soc_4kram_cy_device::vt03_41bx_r(offs_t offset) +uint8_t nes_vt09_soc_cy_device::vt03_41bx_r(offs_t offset) { switch (offset) { @@ -1335,18 +1346,18 @@ uint8_t nes_vt_soc_4kram_cy_device::vt03_41bx_r(offs_t offset) } } -void nes_vt_soc_4kram_cy_device::vt03_41bx_w(offs_t offset, uint8_t data) +void nes_vt09_soc_cy_device::vt03_41bx_w(offs_t offset, uint8_t data) { logerror("vt03_41bx_w %02x %02x\n", offset, data); } -uint8_t nes_vt_soc_4kram_cy_device::vt03_413x_r(offs_t offset) +uint8_t nes_vt09_soc_cy_device::vt03_413x_r(offs_t offset) { logerror("vt03_413x_r %02x\n", offset); return m_413x[offset]; } -void nes_vt_soc_4kram_cy_device::vt03_413x_w(offs_t offset, uint8_t data) +void nes_vt09_soc_cy_device::vt03_413x_w(offs_t offset, uint8_t data) { logerror("vt03_413x_w %02x %02x\n", offset, data); // VT168 style ALU ?? @@ -1372,23 +1383,23 @@ void nes_vt_soc_4kram_cy_device::vt03_413x_w(offs_t offset, uint8_t data) } } -uint8_t nes_vt_soc_4kram_cy_device::vt03_414f_r() +uint8_t nes_vt09_soc_cy_device::vt03_414f_r() { return 0xff; } -uint8_t nes_vt_soc_4kram_cy_device::vt03_415c_r() +uint8_t nes_vt09_soc_cy_device::vt03_415c_r() { return 0xff; } -void nes_vt_soc_4kram_cy_device::vt03_48ax_w(offs_t offset, uint8_t data) +void nes_vt09_soc_cy_device::vt03_48ax_w(offs_t offset, uint8_t data) { logerror("vt03_48ax_w %02x %02x\n", offset, data); } -uint8_t nes_vt_soc_4kram_cy_device::vt03_48ax_r(offs_t offset) +uint8_t nes_vt09_soc_cy_device::vt03_48ax_r(offs_t offset) { switch (offset) { @@ -1405,19 +1416,19 @@ uint8_t nes_vt_soc_4kram_cy_device::vt03_48ax_r(offs_t offset) /* 'BT' specifics (base = '4K') */ /***********************************************************************************************************************************************************/ -void nes_vt_soc_4kram_bt_device::device_add_mconfig(machine_config& config) +void nes_vt09_soc_bt_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_device::device_add_mconfig(config); - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_soc_4kram_bt_device::nes_vt_bt_map); + nes_vt02_vt03_soc_device::device_add_mconfig(config); + m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt09_soc_bt_device::nes_vt_bt_map); } -void nes_vt_soc_4kram_bt_device::nes_vt_bt_map(address_map &map) +void nes_vt09_soc_bt_device::nes_vt_bt_map(address_map &map) { nes_vt_4k_ram_map(map); - map(0x412c, 0x412c).w(FUNC(nes_vt_soc_4kram_bt_device::vt03_412c_extbank_w)); + map(0x412c, 0x412c).w(FUNC(nes_vt09_soc_bt_device::vt03_412c_extbank_w)); } -void nes_vt_soc_4kram_bt_device::vt03_412c_extbank_w(uint8_t data) +void nes_vt09_soc_bt_device::vt03_412c_extbank_w(uint8_t data) { m_upper_write_412c_callback(data); } @@ -1427,13 +1438,13 @@ void nes_vt_soc_4kram_bt_device::vt03_412c_extbank_w(uint8_t data) /* 'HH' specifics (base = '4K') */ /***********************************************************************************************************************************************************/ -void nes_vt_soc_4kram_hh_device::device_add_mconfig(machine_config& config) +void nes_vt369_soc_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_device::device_add_mconfig(config); - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_soc_4kram_hh_device::nes_vt_hh_map); + nes_vt02_vt03_soc_device::device_add_mconfig(config); + m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt369_soc_device::nes_vt_hh_map); } -void nes_vt_soc_4kram_hh_device::vtfp_411d_w(uint8_t data) +void nes_vt369_soc_device::vtfp_411d_w(uint8_t data) { // controls chram access and mapper emulation modes in later models logerror("vtfp_411d_w %02x\n", data); @@ -1441,41 +1452,41 @@ void nes_vt_soc_4kram_hh_device::vtfp_411d_w(uint8_t data) update_banks(); } -uint8_t nes_vt_soc_4kram_hh_device::vthh_414a_r() +uint8_t nes_vt369_soc_device::vthh_414a_r() { return 0x80; } -void nes_vt_soc_4kram_hh_device::nes_vt_hh_map(address_map &map) +void nes_vt369_soc_device::nes_vt_hh_map(address_map &map) { - nes_vt_soc_device::nes_vt_map(map); + nes_vt02_vt03_soc_device::nes_vt_map(map); map(0x0000, 0x1fff).mask(0x0fff).ram(); - map(0x414a, 0x414a).r(FUNC(nes_vt_soc_4kram_hh_device::vthh_414a_r)); - map(0x411d, 0x411d).w(FUNC(nes_vt_soc_4kram_hh_device::vtfp_411d_w)); + map(0x414a, 0x414a).r(FUNC(nes_vt369_soc_device::vthh_414a_r)); + map(0x411d, 0x411d).w(FUNC(nes_vt369_soc_device::vtfp_411d_w)); } /***********************************************************************************************************************************************************/ /* 'FP' specifics (base = 'HH') */ // used by fcpocket, dgun2573, rminitv /***********************************************************************************************************************************************************/ -void nes_vt_soc_4kram_fp_device::device_add_mconfig(machine_config& config) +void nes_vt32_soc_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_device::device_add_mconfig(config); + nes_vt02_vt03_soc_device::device_add_mconfig(config); M6502_VTSCR(config.replace(), m_maincpu, NTSC_APU_CLOCK); // are these later chips N2A03 core, or 6502 core derived? - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_soc_4kram_fp_device::nes_vt_fp_map); + m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt32_soc_device::nes_vt_fp_map); } -uint8_t nes_vt_soc_4kram_fp_device::vtfp_4119_r() +uint8_t nes_vt32_soc_device::vtfp_4119_r() { // would be PAL/NTSC etc. in base system, maybe different here? return 0x00; } -void nes_vt_soc_4kram_fp_device::vtfp_411e_w(uint8_t data) +void nes_vt32_soc_device::vtfp_411e_w(uint8_t data) { logerror("411e_w %02x\n", data); if (data == 0x05) @@ -1484,7 +1495,7 @@ void nes_vt_soc_4kram_fp_device::vtfp_411e_w(uint8_t data) dynamic_cast(*m_maincpu).set_next_scramble(false); } -void nes_vt_soc_4kram_fp_device::vtfp_4a00_w(uint8_t data) +void nes_vt32_soc_device::vtfp_4a00_w(uint8_t data) { logerror("4a00_w %02x\n", data); //if(data == 0x80) @@ -1492,40 +1503,40 @@ void nes_vt_soc_4kram_fp_device::vtfp_4a00_w(uint8_t data) } -void nes_vt_soc_4kram_fp_device::vtfp_412c_extbank_w(uint8_t data) +void nes_vt32_soc_device::vtfp_412c_extbank_w(uint8_t data) { m_upper_write_412c_callback(data); } -uint8_t nes_vt_soc_4kram_fp_device::vtfp_412d_r() +uint8_t nes_vt32_soc_device::vtfp_412d_r() { return m_upper_read_412d_callback(); } -void nes_vt_soc_4kram_fp_device::vtfp_4242_w(uint8_t data) +void nes_vt32_soc_device::vtfp_4242_w(uint8_t data) { logerror("vtfp_4242_w %02x\n", data); m_4242 = data; } -void nes_vt_soc_4kram_fp_device::nes_vt_fp_map(address_map &map) +void nes_vt32_soc_device::nes_vt_fp_map(address_map &map) { - nes_vt_soc_4kram_hh_device::nes_vt_hh_map(map); + nes_vt369_soc_device::nes_vt_hh_map(map); - map(0x4119, 0x4119).r(FUNC(nes_vt_soc_4kram_fp_device::vtfp_4119_r)); - map(0x411e, 0x411e).w(FUNC(nes_vt_soc_4kram_fp_device::vtfp_411e_w)); // encryption toggle + map(0x4119, 0x4119).r(FUNC(nes_vt32_soc_device::vtfp_4119_r)); + map(0x411e, 0x411e).w(FUNC(nes_vt32_soc_device::vtfp_411e_w)); // encryption toggle - map(0x412c, 0x412c).w(FUNC(nes_vt_soc_4kram_fp_device::vtfp_412c_extbank_w)); // GPIO - map(0x412d, 0x412d).r(FUNC(nes_vt_soc_4kram_fp_device::vtfp_412d_r)); // GPIO + map(0x412c, 0x412c).w(FUNC(nes_vt32_soc_device::vtfp_412c_extbank_w)); // GPIO + map(0x412d, 0x412d).r(FUNC(nes_vt32_soc_device::vtfp_412d_r)); // GPIO - map(0x4242, 0x4242).w(FUNC(nes_vt_soc_4kram_fp_device::vtfp_4242_w)); + map(0x4242, 0x4242).w(FUNC(nes_vt32_soc_device::vtfp_4242_w)); - map(0x4a00, 0x4a00).w(FUNC(nes_vt_soc_4kram_fp_device::vtfp_4a00_w)); + map(0x4a00, 0x4a00).w(FUNC(nes_vt32_soc_device::vtfp_4a00_w)); } -void nes_vt_soc_4kram_fp_pal_device::device_add_mconfig(machine_config& config) +void nes_vt32_soc_pal_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_4kram_fp_device::device_add_mconfig(config); + nes_vt32_soc_device::device_add_mconfig(config); do_pal_timings_and_ppu_replacement(config); } @@ -1533,59 +1544,59 @@ void nes_vt_soc_4kram_fp_pal_device::device_add_mconfig(machine_config& config) /* 'DG' specifics (base = '4K') */ /***********************************************************************************************************************************************************/ -void nes_vt_soc_8kram_dg_device::device_add_mconfig(machine_config& config) +void nes_vt3x_soc_dg_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_device::device_add_mconfig(config); - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_soc_8kram_dg_device::nes_vt_dg_map); + nes_vt02_vt03_soc_device::device_add_mconfig(config); + m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt3x_soc_dg_device::nes_vt_dg_map); } -void nes_vt_soc_8kram_dg_device::vt03_411c_w(uint8_t data) +void nes_vt3x_soc_dg_device::vt03_411c_w(uint8_t data) { logerror("vt03_411c_w %02x\n", data); m_411c = data; update_banks(); } -void nes_vt_soc_8kram_dg_device::nes_vt_dg_map(address_map &map) +void nes_vt3x_soc_dg_device::nes_vt_dg_map(address_map &map) { - nes_vt_soc_device::nes_vt_map(map); + nes_vt02_vt03_soc_device::nes_vt_map(map); map(0x0000, 0x1fff).ram(); - map(0x411c, 0x411c).w(FUNC(nes_vt_soc_8kram_dg_device::vt03_411c_w)); + map(0x411c, 0x411c).w(FUNC(nes_vt3x_soc_dg_device::vt03_411c_w)); } /***********************************************************************************************************************************************************/ /* 'FA' specifics (base = 'DG') */ // used by fapocket /***********************************************************************************************************************************************************/ -void nes_vt_soc_8kram_fa_device::device_add_mconfig(machine_config& config) +void nes_vt3x_soc_fa_device::device_add_mconfig(machine_config& config) { - nes_vt_soc_device::device_add_mconfig(config); - m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt_soc_8kram_fa_device::nes_vt_fa_map); + nes_vt02_vt03_soc_device::device_add_mconfig(config); + m_maincpu->set_addrmap(AS_PROGRAM, &nes_vt3x_soc_fa_device::nes_vt_fa_map); } -uint8_t nes_vt_soc_8kram_fa_device::vtfa_412c_r() +uint8_t nes_vt3x_soc_fa_device::vtfa_412c_r() { return m_upper_read_412c_callback(); } -void nes_vt_soc_8kram_fa_device::vtfa_412c_extbank_w(uint8_t data) +void nes_vt3x_soc_fa_device::vtfa_412c_extbank_w(uint8_t data) { m_upper_write_412c_callback(data); } -void nes_vt_soc_8kram_fa_device::vtfp_4242_w(uint8_t data) +void nes_vt3x_soc_fa_device::vtfp_4242_w(uint8_t data) { logerror("vtfp_4242_w %02x\n", data); m_4242 = data; } -void nes_vt_soc_8kram_fa_device::nes_vt_fa_map(address_map &map) +void nes_vt3x_soc_fa_device::nes_vt_fa_map(address_map &map) { - nes_vt_soc_8kram_dg_device::nes_vt_dg_map(map); + nes_vt3x_soc_dg_device::nes_vt_dg_map(map); - map(0x412c, 0x412c).r(FUNC(nes_vt_soc_8kram_fa_device::vtfa_412c_r)).w(FUNC(nes_vt_soc_8kram_fa_device::vtfa_412c_extbank_w)); - map(0x4242, 0x4242).w(FUNC(nes_vt_soc_8kram_fa_device::vtfp_4242_w)); + map(0x412c, 0x412c).r(FUNC(nes_vt3x_soc_fa_device::vtfa_412c_r)).w(FUNC(nes_vt3x_soc_fa_device::vtfa_412c_extbank_w)); + map(0x4242, 0x4242).w(FUNC(nes_vt3x_soc_fa_device::vtfp_4242_w)); } diff --git a/src/mame/machine/nes_vt_soc.h b/src/mame/machine/nes_vt_soc.h index 7ab011cf8b6..b5cd3eb48bd 100644 --- a/src/mame/machine/nes_vt_soc.h +++ b/src/mame/machine/nes_vt_soc.h @@ -13,10 +13,10 @@ #include "screen.h" #include "speaker.h" -class nes_vt_soc_device : public device_t, public device_memory_interface +class nes_vt02_vt03_soc_device : public device_t, public device_memory_interface { public: - nes_vt_soc_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock); + nes_vt02_vt03_soc_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock); void program_map(address_map &map); @@ -56,7 +56,7 @@ public: void set_default_palette_mode(vtxx_pal_mode pmode) { m_default_palette_mode = pmode; } protected: - nes_vt_soc_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, uint32_t clock); + nes_vt02_vt03_soc_device(const machine_config &mconfig, device_type type, const char *tag, device_t *owner, uint32_t clock); virtual void device_start() override; virtual void device_reset() override; @@ -163,28 +163,28 @@ private: bool m_use_raster_timing_hack; }; -class nes_vt_soc_pal_device : public nes_vt_soc_device +class nes_vt02_vt03_soc_pal_device : public nes_vt02_vt03_soc_device { public: - nes_vt_soc_pal_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt02_vt03_soc_pal_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); protected: virtual void device_add_mconfig(machine_config& config) override; }; -class nes_vt_soc_scramble_device : public nes_vt_soc_device +class nes_vt02_vt03_soc_scramble_device : public nes_vt02_vt03_soc_device { public: - nes_vt_soc_scramble_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt02_vt03_soc_scramble_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); protected: virtual void device_add_mconfig(machine_config& config) override; }; -class nes_vt_soc_4kram_device : public nes_vt_soc_device +class nes_vt09_soc_device : public nes_vt02_vt03_soc_device { public: - nes_vt_soc_4kram_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt09_soc_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); auto upper_read_412c_callback() { return m_upper_read_412c_callback.bind(); } auto upper_read_412d_callback() { return m_upper_read_412d_callback.bind(); } @@ -193,7 +193,7 @@ public: protected: - nes_vt_soc_4kram_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock); + nes_vt09_soc_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock); void device_start() override; virtual void device_add_mconfig(machine_config& config) override; @@ -206,10 +206,10 @@ protected: devcb_read8 m_upper_read_412d_callback; }; -class nes_vt_soc_4kram_cy_device : public nes_vt_soc_4kram_device +class nes_vt09_soc_cy_device : public nes_vt09_soc_device { public: - nes_vt_soc_4kram_cy_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt09_soc_cy_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); protected: virtual void device_add_mconfig(machine_config& config) override; @@ -233,10 +233,10 @@ protected: uint8_t m_413x[8]; // CY only? }; -class nes_vt_soc_4kram_bt_device : public nes_vt_soc_4kram_device +class nes_vt09_soc_bt_device : public nes_vt09_soc_device { public: - nes_vt_soc_4kram_bt_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt09_soc_bt_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); protected: virtual void device_add_mconfig(machine_config& config) override; @@ -246,13 +246,13 @@ protected: void vt03_412c_extbank_w(uint8_t data); }; -class nes_vt_soc_4kram_hh_device : public nes_vt_soc_4kram_device +class nes_vt369_soc_device : public nes_vt09_soc_device { public: - nes_vt_soc_4kram_hh_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt369_soc_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); protected: - nes_vt_soc_4kram_hh_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock); + nes_vt369_soc_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock); virtual void device_add_mconfig(machine_config& config) override; @@ -263,13 +263,13 @@ protected: }; -class nes_vt_soc_4kram_fp_device : public nes_vt_soc_4kram_hh_device +class nes_vt32_soc_device : public nes_vt369_soc_device { public: - nes_vt_soc_4kram_fp_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt32_soc_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); protected: - nes_vt_soc_4kram_fp_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock); + nes_vt32_soc_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock); virtual void device_add_mconfig(machine_config& config) override; @@ -283,23 +283,23 @@ protected: void vtfp_4a00_w(uint8_t data); }; -class nes_vt_soc_4kram_fp_pal_device : public nes_vt_soc_4kram_fp_device +class nes_vt32_soc_pal_device : public nes_vt32_soc_device { public: - nes_vt_soc_4kram_fp_pal_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt32_soc_pal_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); protected: virtual void device_add_mconfig(machine_config& config) override; }; -class nes_vt_soc_8kram_dg_device : public nes_vt_soc_4kram_device +class nes_vt3x_soc_dg_device : public nes_vt09_soc_device { public: - nes_vt_soc_8kram_dg_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt3x_soc_dg_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); protected: - nes_vt_soc_8kram_dg_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock); + nes_vt3x_soc_dg_device(const machine_config& mconfig, device_type type, const char* tag, device_t* owner, uint32_t clock); virtual void device_add_mconfig(machine_config& config) override; @@ -308,10 +308,10 @@ protected: void vt03_411c_w(uint8_t data); }; -class nes_vt_soc_8kram_fa_device : public nes_vt_soc_8kram_dg_device +class nes_vt3x_soc_fa_device : public nes_vt3x_soc_dg_device { public: - nes_vt_soc_8kram_fa_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); + nes_vt3x_soc_fa_device(const machine_config& mconfig, const char* tag, device_t* owner, uint32_t clock); protected: @@ -325,19 +325,19 @@ protected: }; -DECLARE_DEVICE_TYPE(NES_VT_SOC, nes_vt_soc_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_PAL, nes_vt_soc_pal_device) +DECLARE_DEVICE_TYPE(NES_VT02_VT03_SOC, nes_vt02_vt03_soc_device) +DECLARE_DEVICE_TYPE(NES_VT02_VT03_SOC_PAL, nes_vt02_vt03_soc_pal_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_SCRAMBLE, nes_vt_soc_scramble_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_4KRAM, nes_vt_soc_4kram_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_4KRAM_CY, nes_vt_soc_4kram_cy_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_4KRAM_BT, nes_vt_soc_4kram_bt_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_4KRAM_HH, nes_vt_soc_4kram_hh_device) +DECLARE_DEVICE_TYPE(NES_VT02_VT03_SOC_SCRAMBLE, nes_vt02_vt03_soc_scramble_device) +DECLARE_DEVICE_TYPE(NES_VT09_SOC, nes_vt09_soc_device) +DECLARE_DEVICE_TYPE(NES_VT09_SOC_CY, nes_vt09_soc_cy_device) +DECLARE_DEVICE_TYPE(NES_VT09_SOC_BT, nes_vt09_soc_bt_device) +DECLARE_DEVICE_TYPE(NES_VT369_SOC, nes_vt369_soc_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_4KRAM_FP, nes_vt_soc_4kram_fp_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_4KRAM_FP_PAL, nes_vt_soc_4kram_fp_pal_device) +DECLARE_DEVICE_TYPE(NES_VT32_SOC, nes_vt32_soc_device) +DECLARE_DEVICE_TYPE(NES_VT32_SOC_PAL, nes_vt32_soc_pal_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_8KRAM_DG, nes_vt_soc_8kram_dg_device) -DECLARE_DEVICE_TYPE(NES_VT_SOC_8KRAM_FA, nes_vt_soc_8kram_fa_device) +DECLARE_DEVICE_TYPE(NES_VT3X_SOC_DG, nes_vt3x_soc_dg_device) +DECLARE_DEVICE_TYPE(NES_VT3X_SOC_FA, nes_vt3x_soc_fa_device) #endif // MAME_MACHINE_NES_VT_SOC_H diff --git a/src/mame/mame.lst b/src/mame/mame.lst index ea4e82908ab..80edca0d8e9 100644 --- a/src/mame/mame.lst +++ b/src/mame/mame.lst @@ -32199,118 +32199,122 @@ max10in1 vsmaxx25 vsmaxx15 -@source:nes_vt.cpp +@source:nes_vt02_vt03.cpp vdogdeme vdogdemo -pinkjelly // From V.R. Technology VT SDK -vtpinball // From V.R. Technology VT SDK -vtsndtest // From V.R. Technology VT SDK -vtboxing // From V.R. Technology VT SDK +pinkjelly +vtpinball +vtsndtest +vtboxing +ablpinb +sporzpp +sporzbx +sporztn +wldsoctv +mc_dgear +sudopptv +megapad +ablmini +solargm +zudugo +timetp36 +timetp7 +majkon +majgnc +vsmaxx17 +polmega +dgun851 +silv35 +vsmaxxvd +vsmaxx77 +techni4 +senwld +protpp +mc_sp69 +ablping +mc_sam60 +zdog +pjoyn50 +pjoys30 +pjoys60 +sarc110 +sarc110a +mc_110cb +mc_138cb +cbrs8 +rfcp168 +gprnrs1 +gprnrs16 +ddrdismx +ddrstraw +dbdancem +sen101 +mc_dg101 +mc_aa2 +mc_105te +mc_8x6cb +mc_9x6ss +mc_9x6sa +mc_7x6ss +mc_8x6ss +mc_dcat8 +mc_dcat8a +mc_89in1 +mc_tv200 +dgun2500 +ppgc200g + +@source:nes_vt09.cpp msiwwe msiwwea msidd msimpac -msisinv msimm2 +msisinv msifrog -ablpinb -mc_dgear -dgun2500 +cybar120 +vsmaxtx2 +senario25 +rcapnp +dturbogt +ventur25 +vgpocket +vgpmini +vgtablet + +@source:nes_vt32_vt369.cpp +bittboy +mc_pg150 +mc_hh210 +dvnimbus +unkra200 +fapocket +sy889 +sy888b +mc_cb280 +mog_m320 +dgun2573 +dgun2573a +rminitv +fcpocket dgun2561 +dgun2593 lxcmcy lxcmc250 lxcmcysw lxcmcyfz lxcmcydp lxcmcysp -lxcmcypp lxcmcycr +lxcmcypp lxccminn lxccplan rtvgc300 rtvgc300fz red5mam -cybar120 -sen101 -mc_dg101 -mc_aa2 -mc_105te -mc_sp69 -vsmaxx17 -vsmaxtx2 -vsmaxx77 -vsmaxxvd -polmega -silv35 -dturbogt -rcapnp -ventur25 -lpgm240 -mc_dcat8 -mc_dcat8a -pjoyn50 -pjoys30 -pjoys60 -sarc110 -sarc110a -mc_8x6cb -mc_9x6ss -mc_9x6sa -mc_110cb -mc_138cb -mc_7x6ss -mc_8x6ss -mc_sam60 -vgtablet -gprnrs1 -gprnrs16 -ddrdismx // (c) 2006 Majesco / Konami [(c) 2001 Disney on title screen] -ddrstraw // (c) 2006 Majesco / Konami -dbdancem -megapad -timetp36 -timetp7 -majkon -majgnc -sudopptv -zudugo -ablping -protpp -vgpocket -vgpmini -sy889 -sy888b -rfcp168 -dgun2573 -dgun2573a -dgun2593 -bittboy -mc_89in1 -mc_cb280 -mc_pg150 -mc_hh210 -dvnimbus -cbrs8 -mc_tv200 -rminitv -unkra200 -ppgc200g -fcpocket -mog_m320 -fapocket -zdog -otrail denv150 -techni4 -senario25 -dgun851 -sporzpp -sporzbx -sporztn -wldsoctv -solargm -ablmini -senwld +lpgm240 +otrail zonefusn @source:newbrain.cpp diff --git a/src/mame/mess.flt b/src/mame/mess.flt index c0552dbdd3a..c7e09d2b09b 100644 --- a/src/mame/mess.flt +++ b/src/mame/mess.flt @@ -646,7 +646,9 @@ neogeocd.cpp nes.cpp nes_clone.cpp nes_sh6578.cpp -nes_vt.cpp +nes_vt02_vt03.cpp +nes_vt09.cpp +nes_vt32_vt369.cpp newbrain.cpp news_38xx.cpp news_68k.cpp