xyonix,c: added save state support (nw)

This commit is contained in:
Osso13 2015-01-14 19:12:36 +01:00
parent 67d993bf43
commit b0264399ef
3 changed files with 36 additions and 22 deletions

View File

@ -25,7 +25,15 @@ TODO:
#include "includes/xyonix.h" #include "includes/xyonix.h"
WRITE8_MEMBER(xyonix_state::xyonix_irqack_w) void xyonix_state::machine_start()
{
save_item(NAME(m_e0_data));
save_item(NAME(m_credits));
save_item(NAME(m_coins));
save_item(NAME(m_prev_coin));
}
WRITE8_MEMBER(xyonix_state::irqack_w)
{ {
m_maincpu->set_input_line(0, CLEAR_LINE); m_maincpu->set_input_line(0, CLEAR_LINE);
} }
@ -71,7 +79,7 @@ void xyonix_state::handle_coins(int coin)
} }
READ8_MEMBER(xyonix_state::xyonix_io_r) READ8_MEMBER(xyonix_state::io_r)
{ {
int regPC = space.device().safe_pc(); int regPC = space.device().safe_pc();
@ -122,7 +130,7 @@ READ8_MEMBER(xyonix_state::xyonix_io_r)
return 0xff; return 0xff;
} }
WRITE8_MEMBER(xyonix_state::xyonix_io_w) WRITE8_MEMBER(xyonix_state::io_w)
{ {
//logerror ("xyonix_port_e0_w %02x - PC = %04x\n", data, space.device().safe_pc()); //logerror ("xyonix_port_e0_w %02x - PC = %04x\n", data, space.device().safe_pc());
m_e0_data = data; m_e0_data = data;
@ -133,7 +141,7 @@ WRITE8_MEMBER(xyonix_state::xyonix_io_w)
static ADDRESS_MAP_START( main_map, AS_PROGRAM, 8, xyonix_state ) static ADDRESS_MAP_START( main_map, AS_PROGRAM, 8, xyonix_state )
AM_RANGE(0x0000, 0xbfff) AM_ROM AM_RANGE(0x0000, 0xbfff) AM_ROM
AM_RANGE(0xc000, 0xdfff) AM_RAM AM_RANGE(0xc000, 0xdfff) AM_RAM
AM_RANGE(0xe000, 0xffff) AM_RAM_WRITE(xyonix_vidram_w) AM_SHARE("vidram") AM_RANGE(0xe000, 0xffff) AM_RAM_WRITE(vidram_w) AM_SHARE("vidram")
ADDRESS_MAP_END ADDRESS_MAP_END
static ADDRESS_MAP_START( port_map, AS_IO, 8, xyonix_state ) static ADDRESS_MAP_START( port_map, AS_IO, 8, xyonix_state )
@ -141,9 +149,9 @@ static ADDRESS_MAP_START( port_map, AS_IO, 8, xyonix_state )
AM_RANGE(0x20, 0x20) AM_READNOP AM_DEVWRITE("sn1", sn76496_device, write) /* SN76496 ready signal */ AM_RANGE(0x20, 0x20) AM_READNOP AM_DEVWRITE("sn1", sn76496_device, write) /* SN76496 ready signal */
AM_RANGE(0x21, 0x21) AM_READNOP AM_DEVWRITE("sn2", sn76496_device, write) AM_RANGE(0x21, 0x21) AM_READNOP AM_DEVWRITE("sn2", sn76496_device, write)
AM_RANGE(0x40, 0x40) AM_WRITENOP /* NMI ack? */ AM_RANGE(0x40, 0x40) AM_WRITENOP /* NMI ack? */
AM_RANGE(0x50, 0x50) AM_WRITE(xyonix_irqack_w) AM_RANGE(0x50, 0x50) AM_WRITE(irqack_w)
AM_RANGE(0x60, 0x61) AM_WRITENOP /* mc6845 */ AM_RANGE(0x60, 0x61) AM_WRITENOP /* mc6845 */
AM_RANGE(0xe0, 0xe0) AM_READWRITE(xyonix_io_r, xyonix_io_w) AM_RANGE(0xe0, 0xe0) AM_READWRITE(io_r, io_w)
ADDRESS_MAP_END ADDRESS_MAP_END
/* Inputs Ports **************************************************************/ /* Inputs Ports **************************************************************/
@ -226,7 +234,7 @@ static MACHINE_CONFIG_START( xyonix, xyonix_state )
MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0)) MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0))
MCFG_SCREEN_SIZE(80*4, 32*8) MCFG_SCREEN_SIZE(80*4, 32*8)
MCFG_SCREEN_VISIBLE_AREA(0, 80*4-1, 0, 28*8-1) MCFG_SCREEN_VISIBLE_AREA(0, 80*4-1, 0, 28*8-1)
MCFG_SCREEN_UPDATE_DRIVER(xyonix_state, screen_update_xyonix) MCFG_SCREEN_UPDATE_DRIVER(xyonix_state, screen_update)
MCFG_SCREEN_PALETTE("palette") MCFG_SCREEN_PALETTE("palette")
MCFG_GFXDECODE_ADD("gfxdecode", "palette", xyonix) MCFG_GFXDECODE_ADD("gfxdecode", "palette", xyonix)
@ -259,4 +267,4 @@ ROM_END
/* GAME drivers **************************************************************/ /* GAME drivers **************************************************************/
GAME( 1989, xyonix, 0, xyonix, xyonix, driver_device, 0, ROT0, "Philko", "Xyonix", 0 ) GAME( 1989, xyonix, 0, xyonix, xyonix, driver_device, 0, ROT0, "Philko", "Xyonix", GAME_SUPPORTS_SAVE )

View File

@ -3,26 +3,32 @@ class xyonix_state : public driver_device
public: public:
xyonix_state(const machine_config &mconfig, device_type type, const char *tag) xyonix_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag), : driver_device(mconfig, type, tag),
m_vidram(*this, "vidram"),
m_maincpu(*this, "maincpu"), m_maincpu(*this, "maincpu"),
m_gfxdecode(*this, "gfxdecode") { } m_gfxdecode(*this, "gfxdecode"),
m_vidram(*this, "vidram") { }
required_device<cpu_device> m_maincpu;
required_device<gfxdecode_device> m_gfxdecode;
required_shared_ptr<UINT8> m_vidram; required_shared_ptr<UINT8> m_vidram;
tilemap_t *m_tilemap; tilemap_t *m_tilemap;
int m_e0_data; int m_e0_data;
int m_credits; int m_credits;
int m_coins; int m_coins;
int m_prev_coin; int m_prev_coin;
DECLARE_WRITE8_MEMBER(xyonix_irqack_w);
DECLARE_READ8_MEMBER(xyonix_io_r); DECLARE_WRITE8_MEMBER(irqack_w);
DECLARE_WRITE8_MEMBER(xyonix_io_w); DECLARE_READ8_MEMBER(io_r);
DECLARE_WRITE8_MEMBER(xyonix_vidram_w); DECLARE_WRITE8_MEMBER(io_w);
TILE_GET_INFO_MEMBER(get_xyonix_tile_info); DECLARE_WRITE8_MEMBER(vidram_w);
virtual void machine_start();
virtual void video_start(); virtual void video_start();
TILE_GET_INFO_MEMBER(get_tile_info);
DECLARE_PALETTE_INIT(xyonix); DECLARE_PALETTE_INIT(xyonix);
UINT32 screen_update_xyonix(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); UINT32 screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
void handle_coins(int coin); void handle_coins(int coin);
required_device<cpu_device> m_maincpu;
required_device<gfxdecode_device> m_gfxdecode;
}; };

View File

@ -31,7 +31,7 @@ PALETTE_INIT_MEMBER(xyonix_state, xyonix)
} }
TILE_GET_INFO_MEMBER(xyonix_state::get_xyonix_tile_info) TILE_GET_INFO_MEMBER(xyonix_state::get_tile_info)
{ {
int tileno; int tileno;
int attr = m_vidram[tile_index+0x1000+1]; int attr = m_vidram[tile_index+0x1000+1];
@ -41,7 +41,7 @@ TILE_GET_INFO_MEMBER(xyonix_state::get_xyonix_tile_info)
SET_TILE_INFO_MEMBER(0,tileno,attr >> 4,0); SET_TILE_INFO_MEMBER(0,tileno,attr >> 4,0);
} }
WRITE8_MEMBER(xyonix_state::xyonix_vidram_w) WRITE8_MEMBER(xyonix_state::vidram_w)
{ {
m_vidram[offset] = data; m_vidram[offset] = data;
m_tilemap->mark_tile_dirty((offset-1)&0x0fff); m_tilemap->mark_tile_dirty((offset-1)&0x0fff);
@ -49,10 +49,10 @@ WRITE8_MEMBER(xyonix_state::xyonix_vidram_w)
void xyonix_state::video_start() void xyonix_state::video_start()
{ {
m_tilemap = &machine().tilemap().create(m_gfxdecode, tilemap_get_info_delegate(FUNC(xyonix_state::get_xyonix_tile_info),this), TILEMAP_SCAN_ROWS, 4, 8, 80, 32); m_tilemap = &machine().tilemap().create(m_gfxdecode, tilemap_get_info_delegate(FUNC(xyonix_state::get_tile_info),this), TILEMAP_SCAN_ROWS, 4, 8, 80, 32);
} }
UINT32 xyonix_state::screen_update_xyonix(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) UINT32 xyonix_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
{ {
m_tilemap->draw(screen, bitmap, cliprect, 0, 0); m_tilemap->draw(screen, bitmap, cliprect, 0, 0);
return 0; return 0;