onetwo.cpp: small cleanups (nw)

This commit is contained in:
Ivan Vangelista 2018-10-24 23:05:03 +02:00
parent ad3779f1f7
commit 671597da99

View File

@ -33,7 +33,7 @@ OKI M6295
sample 27c020 sample 27c020
sound_prog 27512 sound_prog 27512
COR_x are LN60G resitor packs COR_x are LN60G resistor packs
------------------------------------- -------------------------------------
@ -51,16 +51,14 @@ Note: this is quite clearly a 'Korean bootleg' of Shisensho - Joshiryo-Hen / Mat
#include "screen.h" #include "screen.h"
#include "speaker.h" #include "speaker.h"
#define MASTER_CLOCK XTAL(4'000'000)
class onetwo_state : public driver_device class onetwo_state : public driver_device
{ {
public: public:
onetwo_state(const machine_config &mconfig, device_type type, const char *tag) onetwo_state(const machine_config &mconfig, device_type type, const char *tag)
: driver_device(mconfig, type, tag), : driver_device(mconfig, type, tag),
m_paletteram(*this, "paletteram"), m_paletteram(*this, "paletteram%u", 1U),
m_paletteram2(*this, "paletteram2"),
m_fgram(*this, "fgram"), m_fgram(*this, "fgram"),
m_mainbank(*this, "mainbank"),
m_maincpu(*this, "maincpu"), m_maincpu(*this, "maincpu"),
m_audiocpu(*this, "audiocpu"), m_audiocpu(*this, "audiocpu"),
m_watchdog(*this, "watchdog"), m_watchdog(*this, "watchdog"),
@ -70,11 +68,15 @@ public:
void onetwo(machine_config &config); void onetwo(machine_config &config);
protected:
virtual void machine_start() override;
virtual void video_start() override;
private: private:
/* memory pointers */ /* memory pointers */
required_shared_ptr<uint8_t> m_paletteram; required_shared_ptr_array<uint8_t, 2> m_paletteram;
required_shared_ptr<uint8_t> m_paletteram2;
required_shared_ptr<uint8_t> m_fgram; required_shared_ptr<uint8_t> m_fgram;
required_memory_bank m_mainbank;
/* video-related */ /* video-related */
tilemap_t *m_fg_tilemap; tilemap_t *m_fg_tilemap;
@ -87,15 +89,12 @@ private:
required_device<palette_device> m_palette; required_device<palette_device> m_palette;
required_device<generic_latch_8_device> m_soundlatch; required_device<generic_latch_8_device> m_soundlatch;
DECLARE_WRITE8_MEMBER(onetwo_fgram_w); DECLARE_WRITE8_MEMBER(fgram_w);
DECLARE_WRITE8_MEMBER(onetwo_cpubank_w); DECLARE_WRITE8_MEMBER(cpubank_w);
DECLARE_WRITE8_MEMBER(onetwo_coin_counters_w); DECLARE_WRITE8_MEMBER(coin_counters_w);
DECLARE_WRITE8_MEMBER(palette1_w); template<uint8_t Which> DECLARE_WRITE8_MEMBER(palette_w);
DECLARE_WRITE8_MEMBER(palette2_w);
TILE_GET_INFO_MEMBER(get_fg_tile_info); TILE_GET_INFO_MEMBER(get_fg_tile_info);
virtual void machine_start() override; uint32_t screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
virtual void video_start() override;
uint32_t screen_update_onetwo(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
void set_color(int offset); void set_color(int offset);
void main_cpu(address_map &map); void main_cpu(address_map &map);
void main_cpu_io(address_map &map); void main_cpu_io(address_map &map);
@ -126,7 +125,7 @@ void onetwo_state::video_start()
m_fg_tilemap = &machine().tilemap().create(*m_gfxdecode, tilemap_get_info_delegate(FUNC(onetwo_state::get_fg_tile_info),this), TILEMAP_SCAN_ROWS, 8, 8, 64, 32); m_fg_tilemap = &machine().tilemap().create(*m_gfxdecode, tilemap_get_info_delegate(FUNC(onetwo_state::get_fg_tile_info),this), TILEMAP_SCAN_ROWS, 8, 8, 64, 32);
} }
uint32_t onetwo_state::screen_update_onetwo(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) uint32_t onetwo_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
{ {
m_fg_tilemap->draw(screen, bitmap, cliprect, 0, 0); m_fg_tilemap->draw(screen, bitmap, cliprect, 0, 0);
return 0; return 0;
@ -138,18 +137,18 @@ uint32_t onetwo_state::screen_update_onetwo(screen_device &screen, bitmap_ind16
* *
*************************************/ *************************************/
WRITE8_MEMBER(onetwo_state::onetwo_fgram_w) WRITE8_MEMBER(onetwo_state::fgram_w)
{ {
m_fgram[offset] = data; m_fgram[offset] = data;
m_fg_tilemap->mark_tile_dirty(offset / 2); m_fg_tilemap->mark_tile_dirty(offset / 2);
} }
WRITE8_MEMBER(onetwo_state::onetwo_cpubank_w) WRITE8_MEMBER(onetwo_state::cpubank_w)
{ {
membank("bank1")->set_entry(data); m_mainbank->set_entry(data);
} }
WRITE8_MEMBER(onetwo_state::onetwo_coin_counters_w) WRITE8_MEMBER(onetwo_state::coin_counters_w)
{ {
m_watchdog->watchdog_reset(); m_watchdog->watchdog_reset();
machine().bookkeeping().coin_counter_w(0, BIT(data, 1)); machine().bookkeeping().coin_counter_w(0, BIT(data, 1));
@ -158,23 +157,15 @@ WRITE8_MEMBER(onetwo_state::onetwo_coin_counters_w)
void onetwo_state::set_color(int offset) void onetwo_state::set_color(int offset)
{ {
int r, g, b; int r = m_paletteram[0][offset] & 0x1f;
int g = m_paletteram[1][offset] & 0x1f;
r = m_paletteram[offset] & 0x1f; int b = ((m_paletteram[0][offset] & 0x60) >> 2) | ((m_paletteram[1][offset] & 0xe0) >> 5);
g = m_paletteram2[offset] & 0x1f;
b = ((m_paletteram[offset] & 0x60) >> 2) | ((m_paletteram2[offset] & 0xe0) >> 5);
m_palette->set_pen_color(offset, pal5bit(r), pal5bit(g), pal5bit(b)); m_palette->set_pen_color(offset, pal5bit(r), pal5bit(g), pal5bit(b));
} }
template<uint8_t Which>
WRITE8_MEMBER(onetwo_state::palette1_w) WRITE8_MEMBER(onetwo_state::palette_w)
{ {
m_paletteram[offset] = data; m_paletteram[Which][offset] = data;
set_color(offset);
}
WRITE8_MEMBER(onetwo_state::palette2_w)
{
m_paletteram2[offset] = data;
set_color(offset); set_color(offset);
} }
@ -186,20 +177,20 @@ WRITE8_MEMBER(onetwo_state::palette2_w)
void onetwo_state::main_cpu(address_map &map) void onetwo_state::main_cpu(address_map &map)
{ {
map(0x0000, 0x7fff).rom().region("maincpu", 0x10000); map(0x0000, 0x7fff).rom().region("maincpu", 0);
map(0x8000, 0xbfff).bankr("bank1"); map(0x8000, 0xbfff).bankr(m_mainbank);
map(0xc800, 0xc87f).ram().w(FUNC(onetwo_state::palette1_w)).share("paletteram"); map(0xc800, 0xc87f).ram().w(FUNC(onetwo_state::palette_w<0>)).share(m_paletteram[0]);
map(0xc900, 0xc97f).ram().w(FUNC(onetwo_state::palette2_w)).share("paletteram2"); map(0xc900, 0xc97f).ram().w(FUNC(onetwo_state::palette_w<1>)).share(m_paletteram[1]);
map(0xd000, 0xdfff).ram().w(FUNC(onetwo_state::onetwo_fgram_w)).share("fgram"); map(0xd000, 0xdfff).ram().w(FUNC(onetwo_state::fgram_w)).share(m_fgram);
map(0xe000, 0xffff).ram(); map(0xe000, 0xffff).ram();
} }
void onetwo_state::main_cpu_io(address_map &map) void onetwo_state::main_cpu_io(address_map &map)
{ {
map.global_mask(0xff); map.global_mask(0xff);
map(0x00, 0x00).portr("DSW1").w(FUNC(onetwo_state::onetwo_coin_counters_w)); map(0x00, 0x00).portr("DSW1").w(FUNC(onetwo_state::coin_counters_w));
map(0x01, 0x01).portr("DSW2").w(m_soundlatch, FUNC(generic_latch_8_device::write)); map(0x01, 0x01).portr("DSW2").w(m_soundlatch, FUNC(generic_latch_8_device::write));
map(0x02, 0x02).portr("P1").w(FUNC(onetwo_state::onetwo_cpubank_w)); map(0x02, 0x02).portr("P1").w(FUNC(onetwo_state::cpubank_w));
map(0x03, 0x03).portr("P2"); map(0x03, 0x03).portr("P2");
map(0x04, 0x04).portr("SYSTEM"); map(0x04, 0x04).portr("SYSTEM");
} }
@ -267,7 +258,7 @@ static INPUT_PORTS_START( onetwo )
PORT_DIPSETTING( 0x00, DEF_STR( 1C_6C ) ) PORT_DIPSETTING( 0x00, DEF_STR( 1C_6C ) )
PORT_START("DSW2") PORT_START("DSW2")
PORT_DIPNAME( 0x01, 0x01, DEF_STR( Unknown) ) PORT_DIPLOCATION("SW2:1") /* Flip Sreen? */ PORT_DIPNAME( 0x01, 0x01, DEF_STR( Unknown) ) PORT_DIPLOCATION("SW2:1") /* Flip Screen? */
PORT_DIPSETTING( 0x01, DEF_STR( Off ) ) PORT_DIPSETTING( 0x01, DEF_STR( Off ) )
PORT_DIPSETTING( 0x00, DEF_STR( On ) ) PORT_DIPSETTING( 0x00, DEF_STR( On ) )
PORT_DIPNAME( 0x02, 0x00, DEF_STR( Demo_Sounds ) ) PORT_DIPLOCATION("SW2:2") PORT_DIPNAME( 0x02, 0x00, DEF_STR( Demo_Sounds ) ) PORT_DIPLOCATION("SW2:2")
@ -354,53 +345,49 @@ GFXDECODE_END
void onetwo_state::machine_start() void onetwo_state::machine_start()
{ {
uint8_t *ROM = memregion("maincpu")->base(); m_mainbank->configure_entries(0, 8, memregion("maincpu")->base(), 0x4000);
membank("bank1")->configure_entries(0, 8, &ROM[0x10000], 0x4000);
} }
MACHINE_CONFIG_START(onetwo_state::onetwo) void onetwo_state::onetwo(machine_config &config)
{
/* basic machine hardware */ /* basic machine hardware */
MCFG_DEVICE_ADD("maincpu", Z80,MASTER_CLOCK) /* 4 MHz */ Z80(config, m_maincpu, 4_MHz_XTAL);
MCFG_DEVICE_PROGRAM_MAP(main_cpu) m_maincpu->set_addrmap(AS_PROGRAM, &onetwo_state::main_cpu);
MCFG_DEVICE_IO_MAP(main_cpu_io) m_maincpu->set_addrmap(AS_IO, &onetwo_state::main_cpu_io);
MCFG_DEVICE_VBLANK_INT_DRIVER("screen", onetwo_state, irq0_line_hold) m_maincpu->set_vblank_int("screen", FUNC(onetwo_state::irq0_line_hold));
MCFG_DEVICE_ADD("audiocpu", Z80,MASTER_CLOCK) /* 4 MHz */ Z80(config, m_audiocpu, 4_MHz_XTAL);
MCFG_DEVICE_PROGRAM_MAP(sound_cpu) m_audiocpu->set_addrmap(AS_PROGRAM, &onetwo_state::sound_cpu);
MCFG_DEVICE_IO_MAP(sound_cpu_io) m_audiocpu->set_addrmap(AS_IO, &onetwo_state::sound_cpu_io);
WATCHDOG_TIMER(config, m_watchdog); WATCHDOG_TIMER(config, m_watchdog);
/* video hardware */ /* video hardware */
MCFG_SCREEN_ADD("screen", RASTER) screen_device &screen(SCREEN(config, "screen", SCREEN_TYPE_RASTER));
MCFG_SCREEN_REFRESH_RATE(60) screen.set_refresh_hz(60);
MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(16)) screen.set_vblank_time(ATTOSECONDS_IN_USEC(16));
MCFG_SCREEN_SIZE(512, 256) screen.set_size(512, 256);
MCFG_SCREEN_VISIBLE_AREA(0, 512-1, 0, 256-1) screen.set_visarea(0, 512-1, 0, 256-1);
MCFG_SCREEN_UPDATE_DRIVER(onetwo_state, screen_update_onetwo) screen.set_screen_update(FUNC(onetwo_state::screen_update));
MCFG_SCREEN_PALETTE("palette") screen.set_palette(m_palette);
MCFG_DEVICE_ADD("gfxdecode", GFXDECODE, "palette", gfx_onetwo)
MCFG_PALETTE_ADD("palette", 0x80)
GFXDECODE(config, m_gfxdecode, m_palette, gfx_onetwo);
PALETTE(config, m_palette, 0x80);
/* sound hardware */ /* sound hardware */
SPEAKER(config, "mono").front_center(); SPEAKER(config, "mono").front_center();
MCFG_GENERIC_LATCH_8_ADD("soundlatch") GENERIC_LATCH_8(config, m_soundlatch);
MCFG_GENERIC_LATCH_DATA_PENDING_CB(INPUTLINE("audiocpu", INPUT_LINE_NMI)) m_soundlatch->data_pending_callback().set_inputline(m_audiocpu, INPUT_LINE_NMI);
MCFG_GENERIC_LATCH_SEPARATE_ACKNOWLEDGE(true) m_soundlatch->set_separate_acknowledge(true);
MCFG_DEVICE_ADD("ymsnd", YM3812, MASTER_CLOCK) ym3812_device &ymsnd(YM3812(config, "ymsnd", 4_MHz_XTAL));
MCFG_YM3812_IRQ_HANDLER(INPUTLINE("audiocpu", 0)) ymsnd.irq_handler().set_inputline(m_audiocpu, 0);
MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 1.0) ymsnd.add_route(ALL_OUTPUTS, "mono", 1.0);
MCFG_DEVICE_ADD("oki", OKIM6295, 1056000*2, okim6295_device::PIN7_LOW) // clock frequency & pin 7 not verified okim6295_device &oki(OKIM6295(config, "oki", 1056000*2, okim6295_device::PIN7_LOW)); // clock frequency & pin 7 not verified
MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 1.0) oki.add_route(ALL_OUTPUTS, "mono", 1.0);
MACHINE_CONFIG_END }
/************************************* /*************************************
* *
@ -409,8 +396,8 @@ MACHINE_CONFIG_END
*************************************/ *************************************/
ROM_START( onetwo ) ROM_START( onetwo )
ROM_REGION( 0x30000, "maincpu", 0 ) /* main z80 */ ROM_REGION( 0x20000, "maincpu", 0 ) /* main z80 */
ROM_LOAD( "maincpu", 0x10000, 0x20000, CRC(83431e6e) SHA1(61ab386a1d0af050f091f5df28c55ad5ad1a0d4b) ) ROM_LOAD( "maincpu", 0x00000, 0x20000, CRC(83431e6e) SHA1(61ab386a1d0af050f091f5df28c55ad5ad1a0d4b) )
ROM_REGION( 0x10000, "audiocpu", 0 ) /* sound z80 */ ROM_REGION( 0x10000, "audiocpu", 0 ) /* sound z80 */
ROM_LOAD( "sound_prog", 0x00000, 0x10000, CRC(90aba4f3) SHA1(914b1c8684993ddc7200a3d61e07f4f6d59e9d02) ) ROM_LOAD( "sound_prog", 0x00000, 0x10000, CRC(90aba4f3) SHA1(914b1c8684993ddc7200a3d61e07f4f6d59e9d02) )
@ -425,8 +412,8 @@ ROM_START( onetwo )
ROM_END ROM_END
ROM_START( onetwoe ) ROM_START( onetwoe )
ROM_REGION( 0x30000, "maincpu", 0 ) /* main z80 */ ROM_REGION( 0x20000, "maincpu", 0 ) /* main z80 */
ROM_LOAD( "main_prog", 0x10000, 0x20000, CRC(6c1936e9) SHA1(d8fb3056299c9b45e0b537e77dc0d633882705dd) ) ROM_LOAD( "main_prog", 0x00000, 0x20000, CRC(6c1936e9) SHA1(d8fb3056299c9b45e0b537e77dc0d633882705dd) )
ROM_REGION( 0x10000, "audiocpu", 0 ) /* sound z80 */ ROM_REGION( 0x10000, "audiocpu", 0 ) /* sound z80 */
ROM_LOAD( "sound_prog", 0x00000, 0x10000, CRC(90aba4f3) SHA1(914b1c8684993ddc7200a3d61e07f4f6d59e9d02) ) ROM_LOAD( "sound_prog", 0x00000, 0x10000, CRC(90aba4f3) SHA1(914b1c8684993ddc7200a3d61e07f4f6d59e9d02) )