mirror of
https://github.com/holub/mame
synced 2025-04-19 23:12:11 +03:00
bus/msx/cart/franky.cpp: Added SuperSoniqs Franky cartridge. (#12357)
This commit is contained in:
parent
57e5ed9c9e
commit
fa1c6edf5f
@ -1991,6 +1991,8 @@ if (BUSES["MSX_SLOT"]~=null) then
|
||||
MAME_DIR .. "src/devices/bus/msx/cart/easi_speech.h",
|
||||
MAME_DIR .. "src/devices/bus/msx/cart/fmpac.cpp",
|
||||
MAME_DIR .. "src/devices/bus/msx/cart/fmpac.h",
|
||||
MAME_DIR .. "src/devices/bus/msx/cart/franky.cpp",
|
||||
MAME_DIR .. "src/devices/bus/msx/cart/franky.h",
|
||||
MAME_DIR .. "src/devices/bus/msx/cart/fs_sr021.cpp",
|
||||
MAME_DIR .. "src/devices/bus/msx/cart/fs_sr021.h",
|
||||
MAME_DIR .. "src/devices/bus/msx/cart/fs_sr022.cpp",
|
||||
|
@ -13,6 +13,7 @@
|
||||
#include "dooly.h"
|
||||
#include "easi_speech.h"
|
||||
#include "fmpac.h"
|
||||
#include "franky.h"
|
||||
#include "fs_sr021.h"
|
||||
#include "fs_sr022.h"
|
||||
#include "halnote.h"
|
||||
@ -100,6 +101,7 @@ void msx_cart(device_slot_interface &device, bool is_in_subslot)
|
||||
device.option_add_internal(slotoptions::EC701, MSX_CART_EC701);
|
||||
device.option_add(slotoptions::BEEPACK, MSX_CART_BEEPACK);
|
||||
device.option_add(slotoptions::BM_012, MSX_CART_BM_012);
|
||||
device.option_add(slotoptions::FRANKY, MSX_CART_FRANKY);
|
||||
device.option_add(slotoptions::HBI55, MSX_CART_HBI55);
|
||||
device.option_add(slotoptions::MOONSOUND, MSX_CART_MOONSOUND);
|
||||
device.option_add(slotoptions::SOFTCARD, MSX_CART_SOFTCARD);
|
||||
|
86
src/devices/bus/msx/cart/franky.cpp
Normal file
86
src/devices/bus/msx/cart/franky.cpp
Normal file
@ -0,0 +1,86 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders:Wilbert Pol
|
||||
/**********************************************************************************
|
||||
|
||||
Emulation of SuperSoniqs' Franky cartridge, the predecessor of SuperSoniqs'
|
||||
PlaySonic cartridge.
|
||||
|
||||
**********************************************************************************/
|
||||
|
||||
#include "emu.h"
|
||||
#include "franky.h"
|
||||
|
||||
#include "video/315_5124.h"
|
||||
|
||||
#include "speaker.h"
|
||||
|
||||
namespace {
|
||||
|
||||
class msx_cart_franky_device : public device_t, public msx_cart_interface
|
||||
{
|
||||
public:
|
||||
msx_cart_franky_device(const machine_config &mconfig, const char *tag, device_t *owner, u32 clock)
|
||||
: device_t(mconfig, MSX_CART_FRANKY, tag, owner, clock)
|
||||
, msx_cart_interface(mconfig, *this)
|
||||
, m_vdp(*this, "vdp")
|
||||
, m_screen(*this, "screen")
|
||||
{ }
|
||||
|
||||
protected:
|
||||
virtual void device_start() override;
|
||||
|
||||
// device_t implementation
|
||||
virtual void device_add_mconfig(machine_config &config) override;
|
||||
|
||||
private:
|
||||
uint32_t screen_update(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect);
|
||||
|
||||
required_device<sega315_5124_device> m_vdp;
|
||||
required_device<screen_device> m_screen;
|
||||
};
|
||||
|
||||
|
||||
void msx_cart_franky_device::device_add_mconfig(machine_config &config)
|
||||
{
|
||||
SPEAKER(config, "franky").front_center();
|
||||
|
||||
SCREEN(config, m_screen, SCREEN_TYPE_RASTER);
|
||||
|
||||
m_screen->set_raw(XTAL(10'738'635)/2,
|
||||
sega315_5124_device::WIDTH,
|
||||
sega315_5124_device::LBORDER_START + sega315_5124_device::LBORDER_WIDTH - 2,
|
||||
sega315_5124_device::LBORDER_START + sega315_5124_device::LBORDER_WIDTH + 256 + 10,
|
||||
sega315_5124_device::HEIGHT_NTSC,
|
||||
sega315_5124_device::TBORDER_START + sega315_5124_device::NTSC_224_TBORDER_HEIGHT,
|
||||
sega315_5124_device::TBORDER_START + sega315_5124_device::NTSC_224_TBORDER_HEIGHT + 224);
|
||||
m_screen->set_refresh_hz(XTAL(10'738'635)/2 / (sega315_5124_device::WIDTH * sega315_5124_device::HEIGHT_NTSC));
|
||||
m_screen->set_screen_update(FUNC(msx_cart_franky_device::screen_update));
|
||||
|
||||
SEGA315_5246(config, m_vdp, XTAL(10'738'635));
|
||||
m_vdp->set_screen(m_screen);
|
||||
m_vdp->set_is_pal(false);
|
||||
m_vdp->n_int().set(*this, FUNC(msx_cart_franky_device::irq_out));
|
||||
// There is no NMI signal on the cartridge slot, so no way to hook this up
|
||||
// m_vdp->n_nmi().set_inputline(maincpu, INPUT_LINE_NMI);
|
||||
m_vdp->add_route(ALL_OUTPUTS, "franky", 1.00);
|
||||
}
|
||||
|
||||
|
||||
void msx_cart_franky_device::device_start()
|
||||
{
|
||||
io_space().install_write_handler(0x48, 0x49, emu::rw_delegate(*m_vdp, FUNC(sega315_5124_device::psg_w)));
|
||||
io_space().install_read_handler(0x48, 0x48, emu::rw_delegate(*m_vdp, FUNC(sega315_5124_device::vcount_read)));
|
||||
io_space().install_read_handler(0x49, 0x49, emu::rw_delegate(*m_vdp, FUNC(sega315_5124_device::hcount_read)));
|
||||
io_space().install_readwrite_handler(0x88, 0x88, emu::rw_delegate(*m_vdp, FUNC(sega315_5124_device::data_read)), emu::rw_delegate(*m_vdp, FUNC(sega315_5124_device::data_write)));
|
||||
io_space().install_readwrite_handler(0x89, 0x89, emu::rw_delegate(*m_vdp, FUNC(sega315_5124_device::control_read)), emu::rw_delegate(*m_vdp, FUNC(sega315_5124_device::control_write)));
|
||||
}
|
||||
|
||||
|
||||
uint32_t msx_cart_franky_device::screen_update(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect)
|
||||
{
|
||||
return m_vdp->screen_update(screen, bitmap, cliprect);
|
||||
}
|
||||
|
||||
} // anonymous namespace
|
||||
|
||||
DEFINE_DEVICE_TYPE_PRIVATE(MSX_CART_FRANKY, msx_cart_interface, msx_cart_franky_device, "msx_cart_franky", "MSX Cartridge - Franky")
|
13
src/devices/bus/msx/cart/franky.h
Normal file
13
src/devices/bus/msx/cart/franky.h
Normal file
@ -0,0 +1,13 @@
|
||||
// license:BSD-3-Clause
|
||||
// copyright-holders:Wilbert Pol
|
||||
#ifndef MAME_BUS_MSX_CART_FRANKY_H
|
||||
#define MAME_BUS_MSX_CART_FRANKY_H
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "bus/msx/slot/cartridge.h"
|
||||
|
||||
|
||||
DECLARE_DEVICE_TYPE(MSX_CART_FRANKY, msx_cart_interface)
|
||||
|
||||
#endif // MAME_BUS_MSX_CART_FRANKY_H
|
@ -34,6 +34,7 @@ char const *const DOOLY = "dooly";
|
||||
char const *const EASISPEECH = "easispeech";
|
||||
char const *const EC701 = "ec701";
|
||||
char const *const FMPAC = "fmpac";
|
||||
char const *const FRANKY = "franky";
|
||||
char const *const FS_SR021 = "fs_sr021";
|
||||
char const *const FS_SR022 = "fs_sr022";
|
||||
char const *const GAMEMASTER2 = "gamemaster2";
|
||||
|
@ -37,6 +37,7 @@ extern char const *const DOOLY;
|
||||
extern char const *const EASISPEECH;
|
||||
extern char const *const EC701;
|
||||
extern char const *const FMPAC;
|
||||
extern char const *const FRANKY;
|
||||
extern char const *const FS_SR021;
|
||||
extern char const *const FS_SR022;
|
||||
extern char const *const GAMEMASTER2;
|
||||
|
Loading…
Reference in New Issue
Block a user