From 6a9f8b89a042daa7e8198d47a42ec940df8ad7ac Mon Sep 17 00:00:00 2001 From: David Haywood Date: Sat, 19 Jan 2019 01:08:05 +0000 Subject: [PATCH] new NOT WORKING ---- Storio [Team Europe] (#4514) * new NOT WORKING ---- Storio [Team Europe] created this so that Clawgrip can add to it * add seemingly pointless line to seemingly pointless file * move info (nw) * vtech (nw) --- hash/vreader.xml | 50 ----------------- hash/vtech_storio_cart.xml | 60 ++++++++++++++++++++ scripts/target/mame/mess.lua | 1 + src/mame/drivers/storio.cpp | 106 +++++++++++++++++++++++++++++++++++ src/mame/mame.lst | 3 + src/mame/mess.flt | 1 + 6 files changed, 171 insertions(+), 50 deletions(-) delete mode 100644 hash/vreader.xml create mode 100644 hash/vtech_storio_cart.xml create mode 100644 src/mame/drivers/storio.cpp diff --git a/hash/vreader.xml b/hash/vreader.xml deleted file mode 100644 index 6379cd82362..00000000000 --- a/hash/vreader.xml +++ /dev/null @@ -1,50 +0,0 @@ - - - - - - - diff --git a/hash/vtech_storio_cart.xml b/hash/vtech_storio_cart.xml new file mode 100644 index 00000000000..61c43ae6364 --- /dev/null +++ b/hash/vtech_storio_cart.xml @@ -0,0 +1,60 @@ + + + + + + + + + + Scooby-Doo!-Scooby-Doo y la momia (Spain) + 200? + VTech + + + + + + + + diff --git a/scripts/target/mame/mess.lua b/scripts/target/mame/mess.lua index 7607a7ec7d2..6d3eaba6d54 100644 --- a/scripts/target/mame/mess.lua +++ b/scripts/target/mame/mess.lua @@ -3624,6 +3624,7 @@ files { MAME_DIR .. "src/mame/drivers/inteladv.cpp", MAME_DIR .. "src/mame/drivers/vsmile.cpp", MAME_DIR .. "src/mame/drivers/clickstart.cpp", + MAME_DIR .. "src/mame/drivers/storio.cpp", } createMESSProjects(_target, _subtarget, "wang") diff --git a/src/mame/drivers/storio.cpp b/src/mame/drivers/storio.cpp new file mode 100644 index 00000000000..704457dc2c0 --- /dev/null +++ b/src/mame/drivers/storio.cpp @@ -0,0 +1,106 @@ +// license:BSD-3-Clause +// copyright-holders:David Haywood +/****************************************************************************** + + vtech Storio + + Skeleton driver, to reference Software List so that it gets validated + + TODO: everything! + +*******************************************************************************/ + +#include "emu.h" + +#include "bus/generic/slot.h" +#include "bus/generic/carts.h" + +#include "screen.h" +#include "softlist.h" +#include "speaker.h" + +class vtech_storio_state : public driver_device +{ +public: + vtech_storio_state(const machine_config &mconfig, device_type type, const char *tag) + : driver_device(mconfig, type, tag) + , m_screen(*this, "screen") + , m_cart(*this, "cartslot") + , m_cart_region(nullptr) + { } + + void vtech_storio(machine_config &config); + +private: + virtual void machine_start() override; + virtual void machine_reset() override; + + DECLARE_DEVICE_IMAGE_LOAD_MEMBER(cart); + + required_device m_screen; + required_device m_cart; + memory_region *m_cart_region; + + uint32_t screen_update_storio(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect); +}; + +uint32_t vtech_storio_state::screen_update_storio(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect) +{ + return 0; +} + +void vtech_storio_state::machine_start() +{ + // if there's a cart, override the standard mapping + if (m_cart && m_cart->exists()) + { + std::string region_tag; + m_cart_region = memregion(region_tag.assign(m_cart->tag()).append(GENERIC_ROM_REGION_TAG).c_str()); + } +} + +void vtech_storio_state::machine_reset() +{ +} + +DEVICE_IMAGE_LOAD_MEMBER(vtech_storio_state, cart) +{ + uint32_t size = m_cart->common_get_size("rom"); + + m_cart->rom_alloc(size, GENERIC_ROM16_WIDTH, ENDIANNESS_LITTLE); + m_cart->common_load_rom(m_cart->get_rom_base(), size, "rom"); + + return image_init_result::PASS; +} + +static INPUT_PORTS_START( vtech_storio ) +INPUT_PORTS_END + + +void vtech_storio_state::vtech_storio(machine_config &config) +{ + //ARM(config, m_maincpu, XTAL(200'000'000)); // What type of CPU? + + SCREEN(config, m_screen, SCREEN_TYPE_RASTER); + m_screen->set_refresh_hz(60); + m_screen->set_size(320, 262); + m_screen->set_visarea(0, 320-1, 0, 240-1); + m_screen->set_screen_update(FUNC(vtech_storio_state::screen_update_storio)); + + SPEAKER(config, "lspeaker").front_left(); + SPEAKER(config, "rspeaker").front_right(); + + GENERIC_CARTSLOT(config, m_cart, generic_plain_slot, "vtech_storio_cart"); + m_cart->set_width(GENERIC_ROM16_WIDTH); + m_cart->set_device_load(device_image_load_delegate(&vtech_storio_state::device_image_load_cart, this)); + + SOFTWARE_LIST(config, "cart_list").set_original("vtech_storio_cart"); +} + +ROM_START( storio ) + ROM_REGION( 0x800000, "maincpu", ROMREGION_ERASEFF ) + /* load BIOS roms here if it doesn't boot straight from cart? */ +ROM_END + +// year, name, parent, compat, machine, input, class, init, company, fullname, flags +CONS( 200?, storio, 0, 0, vtech_storio, vtech_storio, vtech_storio_state, empty_init, "VTech", "Storio", MACHINE_IS_SKELETON ) diff --git a/src/mame/mame.lst b/src/mame/mame.lst index 93a3d8a367d..d26b2fe273b 100644 --- a/src/mame/mame.lst +++ b/src/mame/mame.lst @@ -35640,6 +35640,9 @@ sorcerer // Sorcerer sorcerer2 // monitor 1.1 1979 sorcererd // Sorcerer with floppies +@source:storio.cpp +storio // (c)200? VTech + @source:sothello.cpp sothello // (c) 1986 Success / Fujiwara. diff --git a/src/mame/mess.flt b/src/mame/mess.flt index fb6e9e399ca..eafe71f2245 100644 --- a/src/mame/mess.flt +++ b/src/mame/mess.flt @@ -697,6 +697,7 @@ squale.cpp ssem.cpp ssystem3.cpp st17xx.cpp +storio.cpp stratos.cpp studio2.cpp sun1.cpp