trunk/src/mame/drivers/tbowl.c
| r243817 | r243818 | |
| 20 | 20 | #include "includes/tbowl.h" |
| 21 | 21 | |
| 22 | 22 | |
| 23 | | WRITE8_MEMBER(tbowl_state::tbowl_coin_counter_w) |
| 23 | WRITE8_MEMBER(tbowl_state::coincounter_w) |
| 24 | 24 | { |
| 25 | 25 | coin_counter_w(machine(), 0, data & 1); |
| 26 | 26 | } |
| r243817 | r243818 | |
| 31 | 31 | |
| 32 | 32 | ***/ |
| 33 | 33 | |
| 34 | | WRITE8_MEMBER(tbowl_state::tbowlb_bankswitch_w) |
| 34 | WRITE8_MEMBER(tbowl_state::boardb_bankswitch_w) |
| 35 | 35 | { |
| 36 | 36 | membank("mainbank")->set_entry(data >> 3); |
| 37 | 37 | } |
| 38 | 38 | |
| 39 | | WRITE8_MEMBER(tbowl_state::tbowlc_bankswitch_w) |
| 39 | WRITE8_MEMBER(tbowl_state::boardc_bankswitch_w) |
| 40 | 40 | { |
| 41 | 41 | membank("subbank")->set_entry(data >> 3); |
| 42 | 42 | } |
| r243817 | r243818 | |
| 45 | 45 | |
| 46 | 46 | ***/ |
| 47 | 47 | |
| 48 | | WRITE8_MEMBER(tbowl_state::tbowl_sound_command_w) |
| 48 | WRITE8_MEMBER(tbowl_state::sound_command_w) |
| 49 | 49 | { |
| 50 | 50 | soundlatch_byte_w(space, offset, data); |
| 51 | 51 | m_audiocpu->set_input_line(INPUT_LINE_NMI, PULSE_LINE); |
| r243817 | r243818 | |
| 66 | 66 | static ADDRESS_MAP_START( 6206B_map, AS_PROGRAM, 8, tbowl_state ) |
| 67 | 67 | AM_RANGE(0x0000, 0x7fff) AM_ROM |
| 68 | 68 | AM_RANGE(0x8000, 0x9fff) AM_RAM |
| 69 | | AM_RANGE(0xa000, 0xbfff) AM_RAM_WRITE(tbowl_bg2videoram_w) AM_SHARE("bg2videoram") |
| 70 | | AM_RANGE(0xc000, 0xdfff) AM_RAM_WRITE(tbowl_bgvideoram_w) AM_SHARE("bgvideoram") |
| 71 | | AM_RANGE(0xe000, 0xefff) AM_RAM_WRITE(tbowl_txvideoram_w) AM_SHARE("txvideoram") |
| 69 | AM_RANGE(0xa000, 0xbfff) AM_RAM_WRITE(bg2videoram_w) AM_SHARE("bg2videoram") |
| 70 | AM_RANGE(0xc000, 0xdfff) AM_RAM_WRITE(bgvideoram_w) AM_SHARE("bgvideoram") |
| 71 | AM_RANGE(0xe000, 0xefff) AM_RAM_WRITE(txvideoram_w) AM_SHARE("txvideoram") |
| 72 | 72 | // AM_RANGE(0xf000, 0xf000) AM_WRITE(unknown_write) * written during start-up, not again */ |
| 73 | 73 | AM_RANGE(0xf000, 0xf7ff) AM_ROMBANK("mainbank") |
| 74 | 74 | AM_RANGE(0xf800, 0xfbff) AM_RAM AM_SHARE("shared_ram") /* check */ |
| 75 | | AM_RANGE(0xfc00, 0xfc00) AM_READ_PORT("P1") AM_WRITE(tbowlb_bankswitch_w) |
| 75 | AM_RANGE(0xfc00, 0xfc00) AM_READ_PORT("P1") AM_WRITE(boardb_bankswitch_w) |
| 76 | 76 | AM_RANGE(0xfc01, 0xfc01) AM_READ_PORT("P2") |
| 77 | 77 | // AM_RANGE(0xfc01, 0xfc01) AM_WRITE(unknown_write) /* written during start-up, not again */ |
| 78 | 78 | AM_RANGE(0xfc02, 0xfc02) AM_READ_PORT("P3") |
| 79 | 79 | // AM_RANGE(0xfc02, 0xfc02) AM_WRITE(unknown_write) /* written during start-up, not again */ |
| 80 | | AM_RANGE(0xfc03, 0xfc03) AM_READ_PORT("P4") AM_WRITE(tbowl_coin_counter_w) |
| 80 | AM_RANGE(0xfc03, 0xfc03) AM_READ_PORT("P4") AM_WRITE(coincounter_w) |
| 81 | 81 | // AM_RANGE(0xfc05, 0xfc05) AM_WRITE(unknown_write) /* no idea */ |
| 82 | 82 | // AM_RANGE(0xfc06, 0xfc06) AM_READ(dummy_r) /* Read During NMI */ |
| 83 | 83 | AM_RANGE(0xfc07, 0xfc07) AM_READ_PORT("SYSTEM") |
| r243817 | r243818 | |
| 86 | 86 | AM_RANGE(0xfc09, 0xfc09) AM_READ_PORT("DSW2") |
| 87 | 87 | AM_RANGE(0xfc0a, 0xfc0a) AM_READ_PORT("DSW3") |
| 88 | 88 | // AM_RANGE(0xfc0a, 0xfc0a) AM_WRITE(unknown_write) /* hardly used .. */ |
| 89 | | AM_RANGE(0xfc0d, 0xfc0d) AM_WRITE(tbowl_sound_command_w) /* not sure, used quite a bit */ |
| 90 | | AM_RANGE(0xfc10, 0xfc10) AM_WRITE(tbowl_bg2xscroll_lo) |
| 91 | | AM_RANGE(0xfc11, 0xfc11) AM_WRITE(tbowl_bg2xscroll_hi) |
| 92 | | AM_RANGE(0xfc12, 0xfc12) AM_WRITE(tbowl_bg2yscroll_lo) |
| 93 | | AM_RANGE(0xfc13, 0xfc13) AM_WRITE(tbowl_bg2yscroll_hi) |
| 94 | | AM_RANGE(0xfc14, 0xfc14) AM_WRITE(tbowl_bgxscroll_lo) |
| 95 | | AM_RANGE(0xfc15, 0xfc15) AM_WRITE(tbowl_bgxscroll_hi) |
| 96 | | AM_RANGE(0xfc16, 0xfc16) AM_WRITE(tbowl_bgyscroll_lo) |
| 97 | | AM_RANGE(0xfc17, 0xfc17) AM_WRITE(tbowl_bgyscroll_hi) |
| 89 | AM_RANGE(0xfc0d, 0xfc0d) AM_WRITE(sound_command_w) /* not sure, used quite a bit */ |
| 90 | AM_RANGE(0xfc10, 0xfc10) AM_WRITE(bg2xscroll_lo) |
| 91 | AM_RANGE(0xfc11, 0xfc11) AM_WRITE(bg2xscroll_hi) |
| 92 | AM_RANGE(0xfc12, 0xfc12) AM_WRITE(bg2yscroll_lo) |
| 93 | AM_RANGE(0xfc13, 0xfc13) AM_WRITE(bg2yscroll_hi) |
| 94 | AM_RANGE(0xfc14, 0xfc14) AM_WRITE(bgxscroll_lo) |
| 95 | AM_RANGE(0xfc15, 0xfc15) AM_WRITE(bgxscroll_hi) |
| 96 | AM_RANGE(0xfc16, 0xfc16) AM_WRITE(bgyscroll_lo) |
| 97 | AM_RANGE(0xfc17, 0xfc17) AM_WRITE(bgyscroll_hi) |
| 98 | 98 | ADDRESS_MAP_END |
| 99 | 99 | |
| 100 | 100 | /* Board C */ |
| 101 | | WRITE8_MEMBER(tbowl_state::tbowl_trigger_nmi) |
| 101 | WRITE8_MEMBER(tbowl_state::trigger_nmi) |
| 102 | 102 | { |
| 103 | 103 | /* trigger NMI on 6206B's Cpu? (guess but seems to work..) */ |
| 104 | 104 | m_maincpu->set_input_line(INPUT_LINE_NMI, PULSE_LINE); |
| r243817 | r243818 | |
| 112 | 112 | AM_RANGE(0xe000, 0xefff) AM_RAM_DEVWRITE("palette", palette_device, write) AM_SHARE("palette") // 2x palettes, one for each monitor? |
| 113 | 113 | AM_RANGE(0xf000, 0xf7ff) AM_ROMBANK("subbank") |
| 114 | 114 | AM_RANGE(0xf800, 0xfbff) AM_RAM AM_SHARE("shared_ram") |
| 115 | | AM_RANGE(0xfc00, 0xfc00) AM_WRITE(tbowlc_bankswitch_w) |
| 115 | AM_RANGE(0xfc00, 0xfc00) AM_WRITE(boardc_bankswitch_w) |
| 116 | 116 | AM_RANGE(0xfc01, 0xfc01) AM_WRITENOP /* ? */ |
| 117 | | AM_RANGE(0xfc02, 0xfc02) AM_WRITE(tbowl_trigger_nmi) /* ? */ |
| 117 | AM_RANGE(0xfc02, 0xfc02) AM_WRITE(trigger_nmi) /* ? */ |
| 118 | 118 | AM_RANGE(0xfc03, 0xfc03) AM_WRITENOP /* ? */ |
| 119 | 119 | AM_RANGE(0xfc06, 0xfc06) AM_WRITENOP /* ? */ |
| 120 | 120 | ADDRESS_MAP_END |
| 121 | 121 | |
| 122 | 122 | /* Board A */ |
| 123 | 123 | |
| 124 | | WRITE8_MEMBER(tbowl_state::tbowl_adpcm_start_w) |
| 124 | WRITE8_MEMBER(tbowl_state::adpcm_start_w) |
| 125 | 125 | { |
| 126 | 126 | msm5205_device *adpcm = (offset & 1) ? m_msm2 : m_msm1; |
| 127 | 127 | m_adpcm_pos[offset & 1] = data << 8; |
| 128 | 128 | adpcm->reset_w(0); |
| 129 | 129 | } |
| 130 | 130 | |
| 131 | | WRITE8_MEMBER(tbowl_state::tbowl_adpcm_end_w) |
| 131 | WRITE8_MEMBER(tbowl_state::adpcm_end_w) |
| 132 | 132 | { |
| 133 | 133 | m_adpcm_end[offset & 1] = (data + 1) << 8; |
| 134 | 134 | } |
| 135 | 135 | |
| 136 | | WRITE8_MEMBER(tbowl_state::tbowl_adpcm_vol_w) |
| 136 | WRITE8_MEMBER(tbowl_state::adpcm_vol_w) |
| 137 | 137 | { |
| 138 | 138 | msm5205_device *adpcm = (offset & 1) ? m_msm2 : m_msm1; |
| 139 | 139 | adpcm->set_volume((data & 0x7f) * 100 / 0x7f); |
| 140 | 140 | } |
| 141 | 141 | |
| 142 | | void tbowl_state::tbowl_adpcm_int( msm5205_device *device, int num ) |
| 142 | void tbowl_state::adpcm_int( msm5205_device *device, int num ) |
| 143 | 143 | { |
| 144 | 144 | if (m_adpcm_pos[num] >= m_adpcm_end[num] || |
| 145 | 145 | m_adpcm_pos[num] >= memregion("adpcm")->bytes()/2) |
| r243817 | r243818 | |
| 158 | 158 | } |
| 159 | 159 | } |
| 160 | 160 | |
| 161 | | WRITE_LINE_MEMBER(tbowl_state::tbowl_adpcm_int_1) |
| 161 | WRITE_LINE_MEMBER(tbowl_state::adpcm_int_1) |
| 162 | 162 | { |
| 163 | | tbowl_adpcm_int(m_msm1, 0); |
| 163 | adpcm_int(m_msm1, 0); |
| 164 | 164 | } |
| 165 | 165 | |
| 166 | | WRITE_LINE_MEMBER(tbowl_state::tbowl_adpcm_int_2) |
| 166 | WRITE_LINE_MEMBER(tbowl_state::adpcm_int_2) |
| 167 | 167 | { |
| 168 | | tbowl_adpcm_int(m_msm2, 1); |
| 168 | adpcm_int(m_msm2, 1); |
| 169 | 169 | } |
| 170 | 170 | |
| 171 | 171 | static ADDRESS_MAP_START( 6206A_map, AS_PROGRAM, 8, tbowl_state ) |
| r243817 | r243818 | |
| 173 | 173 | AM_RANGE(0xc000, 0xc7ff) AM_RAM |
| 174 | 174 | AM_RANGE(0xd000, 0xd001) AM_DEVWRITE("ym1", ym3812_device, write) |
| 175 | 175 | AM_RANGE(0xd800, 0xd801) AM_DEVWRITE("ym2", ym3812_device, write) |
| 176 | | AM_RANGE(0xe000, 0xe001) AM_WRITE(tbowl_adpcm_end_w) |
| 177 | | AM_RANGE(0xe002, 0xe003) AM_WRITE(tbowl_adpcm_start_w) |
| 178 | | AM_RANGE(0xe004, 0xe005) AM_WRITE(tbowl_adpcm_vol_w) |
| 176 | AM_RANGE(0xe000, 0xe001) AM_WRITE(adpcm_end_w) |
| 177 | AM_RANGE(0xe002, 0xe003) AM_WRITE(adpcm_start_w) |
| 178 | AM_RANGE(0xe004, 0xe005) AM_WRITE(adpcm_vol_w) |
| 179 | 179 | AM_RANGE(0xe006, 0xe006) AM_WRITENOP |
| 180 | 180 | AM_RANGE(0xe007, 0xe007) AM_WRITENOP /* NMI acknowledge */ |
| 181 | 181 | AM_RANGE(0xe010, 0xe010) AM_READ(soundlatch_byte_r) |
| r243817 | r243818 | |
| 418 | 418 | { |
| 419 | 419 | membank("mainbank")->configure_entries(0, 32, memregion("maincpu")->base() + 0x10000, 0x800); |
| 420 | 420 | membank("subbank")->configure_entries(0, 32, memregion("sub")->base() + 0x10000, 0x800); |
| 421 | |
| 422 | save_item(NAME(m_adpcm_pos)); |
| 423 | save_item(NAME(m_adpcm_end)); |
| 424 | save_item(NAME(m_adpcm_data)); |
| 425 | |
| 421 | 426 | } |
| 422 | 427 | |
| 423 | 428 | void tbowl_state::machine_reset() |
| r243817 | r243818 | |
| 459 | 464 | MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0)) |
| 460 | 465 | MCFG_SCREEN_SIZE(32*8, 32*8) |
| 461 | 466 | MCFG_SCREEN_VISIBLE_AREA(0*8, 32*8-1, 2*8, 30*8-1) |
| 462 | | MCFG_SCREEN_UPDATE_DRIVER(tbowl_state, screen_update_tbowl_left) |
| 467 | MCFG_SCREEN_UPDATE_DRIVER(tbowl_state, screen_update_left) |
| 463 | 468 | MCFG_SCREEN_PALETTE("palette") |
| 464 | 469 | |
| 465 | 470 | MCFG_SCREEN_ADD("rscreen", RASTER) |
| r243817 | r243818 | |
| 467 | 472 | MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(0)) |
| 468 | 473 | MCFG_SCREEN_SIZE(32*8, 32*8) |
| 469 | 474 | MCFG_SCREEN_VISIBLE_AREA(0*8, 32*8-1, 2*8, 30*8-1) |
| 470 | | MCFG_SCREEN_UPDATE_DRIVER(tbowl_state, screen_update_tbowl_right) |
| 475 | MCFG_SCREEN_UPDATE_DRIVER(tbowl_state, screen_update_right) |
| 471 | 476 | MCFG_SCREEN_PALETTE("palette") |
| 472 | 477 | |
| 473 | 478 | |
| r243817 | r243818 | |
| 483 | 488 | |
| 484 | 489 | /* something for the samples? */ |
| 485 | 490 | MCFG_SOUND_ADD("msm1", MSM5205, 384000) |
| 486 | | MCFG_MSM5205_VCLK_CB(WRITELINE(tbowl_state, tbowl_adpcm_int_1)) /* interrupt function */ |
| 491 | MCFG_MSM5205_VCLK_CB(WRITELINE(tbowl_state, adpcm_int_1)) /* interrupt function */ |
| 487 | 492 | MCFG_MSM5205_PRESCALER_SELECTOR(MSM5205_S48_4B) /* 8KHz */ |
| 488 | 493 | MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.50) |
| 489 | 494 | |
| 490 | 495 | MCFG_SOUND_ADD("msm2", MSM5205, 384000) |
| 491 | | MCFG_MSM5205_VCLK_CB(WRITELINE(tbowl_state, tbowl_adpcm_int_2)) /* interrupt function */ |
| 496 | MCFG_MSM5205_VCLK_CB(WRITELINE(tbowl_state, adpcm_int_2)) /* interrupt function */ |
| 492 | 497 | MCFG_MSM5205_PRESCALER_SELECTOR(MSM5205_S48_4B) /* 8KHz */ |
| 493 | 498 | MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.50) |
| 494 | 499 | MACHINE_CONFIG_END |
| r243817 | r243818 | |
| 697 | 702 | ROM_LOAD( "6206a.2", 0x10000, 0x10000, CRC(1e9e5936) SHA1(60370d1de28b1c5ffeff7843702aaddb19ff1f58) ) |
| 698 | 703 | ROM_END |
| 699 | 704 | |
| 700 | | GAME( 1987, tbowl, 0, tbowl, tbowl, driver_device, 0, ROT0, "Tecmo", "Tecmo Bowl (World)", 0 ) |
| 701 | | GAME( 1987, tbowlp, tbowl, tbowl, tbowl, driver_device, 0, ROT0, "Tecmo", "Tecmo Bowl (World, prototype?)", 0 ) // or early version, handwritten labels |
| 702 | | GAME( 1987, tbowlj, tbowl, tbowl, tbowlj, driver_device, 0, ROT0, "Tecmo", "Tecmo Bowl (Japan)", 0 ) |
| 705 | GAME( 1987, tbowl, 0, tbowl, tbowl, driver_device, 0, ROT0, "Tecmo", "Tecmo Bowl (World)", GAME_SUPPORTS_SAVE ) |
| 706 | GAME( 1987, tbowlp, tbowl, tbowl, tbowl, driver_device, 0, ROT0, "Tecmo", "Tecmo Bowl (World, prototype?)", GAME_SUPPORTS_SAVE ) // or early version, handwritten labels |
| 707 | GAME( 1987, tbowlj, tbowl, tbowl, tbowlj, driver_device, 0, ROT0, "Tecmo", "Tecmo Bowl (Japan)", GAME_SUPPORTS_SAVE ) |
trunk/src/mame/includes/tbowl.h
| r243817 | r243818 | |
| 6 | 6 | public: |
| 7 | 7 | tbowl_state(const machine_config &mconfig, device_type type, const char *tag) |
| 8 | 8 | : driver_device(mconfig, type, tag), |
| 9 | | m_txvideoram(*this, "txvideoram"), |
| 10 | | m_bgvideoram(*this, "bgvideoram"), |
| 11 | | m_bg2videoram(*this, "bg2videoram"), |
| 12 | | m_spriteram(*this, "spriteram"), |
| 13 | 9 | m_maincpu(*this, "maincpu"), |
| 14 | 10 | m_audiocpu(*this, "audiocpu"), |
| 15 | 11 | m_msm1(*this, "msm1"), |
| 16 | 12 | m_msm2(*this, "msm2"), |
| 17 | 13 | m_gfxdecode(*this, "gfxdecode"), |
| 18 | 14 | m_palette(*this, "palette"), |
| 19 | | m_sprgen(*this, "spritegen") |
| 15 | m_sprgen(*this, "spritegen"), |
| 16 | m_txvideoram(*this, "txvideoram"), |
| 17 | m_bgvideoram(*this, "bgvideoram"), |
| 18 | m_bg2videoram(*this, "bg2videoram"), |
| 19 | m_spriteram(*this, "spriteram") |
| 20 | 20 | { } |
| 21 | 21 | |
| 22 | | int m_adpcm_pos[2]; |
| 23 | | int m_adpcm_end[2]; |
| 24 | | int m_adpcm_data[2]; |
| 22 | required_device<cpu_device> m_maincpu; |
| 23 | required_device<cpu_device> m_audiocpu; |
| 24 | required_device<msm5205_device> m_msm1; |
| 25 | required_device<msm5205_device> m_msm2; |
| 26 | required_device<gfxdecode_device> m_gfxdecode; |
| 27 | required_device<palette_device> m_palette; |
| 28 | required_device<tecmo_spr_device> m_sprgen; |
| 29 | |
| 25 | 30 | required_shared_ptr<UINT8> m_txvideoram; |
| 26 | 31 | required_shared_ptr<UINT8> m_bgvideoram; |
| 27 | 32 | required_shared_ptr<UINT8> m_bg2videoram; |
| 28 | 33 | required_shared_ptr<UINT8> m_spriteram; |
| 34 | |
| 29 | 35 | tilemap_t *m_tx_tilemap; |
| 30 | 36 | tilemap_t *m_bg_tilemap; |
| 31 | 37 | tilemap_t *m_bg2_tilemap; |
| r243817 | r243818 | |
| 33 | 39 | UINT16 m_yscroll; |
| 34 | 40 | UINT16 m_bg2xscroll; |
| 35 | 41 | UINT16 m_bg2yscroll; |
| 36 | | DECLARE_WRITE8_MEMBER(tbowl_coin_counter_w); |
| 37 | | DECLARE_WRITE8_MEMBER(tbowlb_bankswitch_w); |
| 38 | | DECLARE_WRITE8_MEMBER(tbowlc_bankswitch_w); |
| 39 | | DECLARE_WRITE8_MEMBER(tbowl_sound_command_w); |
| 40 | | DECLARE_WRITE8_MEMBER(tbowl_trigger_nmi); |
| 41 | | DECLARE_WRITE8_MEMBER(tbowl_adpcm_start_w); |
| 42 | | DECLARE_WRITE8_MEMBER(tbowl_adpcm_end_w); |
| 43 | | DECLARE_WRITE8_MEMBER(tbowl_adpcm_vol_w); |
| 44 | | DECLARE_WRITE8_MEMBER(tbowl_txvideoram_w); |
| 45 | | DECLARE_WRITE8_MEMBER(tbowl_bg2videoram_w); |
| 46 | | DECLARE_WRITE8_MEMBER(tbowl_bgxscroll_lo); |
| 47 | | DECLARE_WRITE8_MEMBER(tbowl_bgxscroll_hi); |
| 48 | | DECLARE_WRITE8_MEMBER(tbowl_bgyscroll_lo); |
| 49 | | DECLARE_WRITE8_MEMBER(tbowl_bgyscroll_hi); |
| 50 | | DECLARE_WRITE8_MEMBER(tbowl_bgvideoram_w); |
| 51 | | DECLARE_WRITE8_MEMBER(tbowl_bg2xscroll_lo); |
| 52 | | DECLARE_WRITE8_MEMBER(tbowl_bg2xscroll_hi); |
| 53 | | DECLARE_WRITE8_MEMBER(tbowl_bg2yscroll_lo); |
| 54 | | DECLARE_WRITE8_MEMBER(tbowl_bg2yscroll_hi); |
| 42 | int m_adpcm_pos[2]; |
| 43 | int m_adpcm_end[2]; |
| 44 | int m_adpcm_data[2]; |
| 45 | |
| 46 | DECLARE_WRITE8_MEMBER(coincounter_w); |
| 47 | DECLARE_WRITE8_MEMBER(boardb_bankswitch_w); |
| 48 | DECLARE_WRITE8_MEMBER(boardc_bankswitch_w); |
| 49 | DECLARE_WRITE8_MEMBER(sound_command_w); |
| 50 | DECLARE_WRITE8_MEMBER(trigger_nmi); |
| 51 | DECLARE_WRITE8_MEMBER(adpcm_start_w); |
| 52 | DECLARE_WRITE8_MEMBER(adpcm_end_w); |
| 53 | DECLARE_WRITE8_MEMBER(adpcm_vol_w); |
| 54 | DECLARE_WRITE8_MEMBER(txvideoram_w); |
| 55 | DECLARE_WRITE8_MEMBER(bg2videoram_w); |
| 56 | DECLARE_WRITE8_MEMBER(bgxscroll_lo); |
| 57 | DECLARE_WRITE8_MEMBER(bgxscroll_hi); |
| 58 | DECLARE_WRITE8_MEMBER(bgyscroll_lo); |
| 59 | DECLARE_WRITE8_MEMBER(bgyscroll_hi); |
| 60 | DECLARE_WRITE8_MEMBER(bgvideoram_w); |
| 61 | DECLARE_WRITE8_MEMBER(bg2xscroll_lo); |
| 62 | DECLARE_WRITE8_MEMBER(bg2xscroll_hi); |
| 63 | DECLARE_WRITE8_MEMBER(bg2yscroll_lo); |
| 64 | DECLARE_WRITE8_MEMBER(bg2yscroll_hi); |
| 65 | |
| 55 | 66 | TILE_GET_INFO_MEMBER(get_tx_tile_info); |
| 56 | 67 | TILE_GET_INFO_MEMBER(get_bg_tile_info); |
| 57 | 68 | TILE_GET_INFO_MEMBER(get_bg2_tile_info); |
| 69 | |
| 58 | 70 | virtual void machine_start(); |
| 59 | 71 | virtual void machine_reset(); |
| 60 | 72 | virtual void video_start(); |
| 61 | | UINT32 screen_update_tbowl_left(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 62 | | UINT32 screen_update_tbowl_right(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 63 | | void tbowl_draw_sprites(bitmap_ind16 &bitmap,const rectangle &cliprect, int xscroll, UINT8* spriteram); |
| 64 | | void tbowl_adpcm_int(msm5205_device *device, int chip); |
| 65 | | DECLARE_WRITE_LINE_MEMBER(tbowl_adpcm_int_1); |
| 66 | | DECLARE_WRITE_LINE_MEMBER(tbowl_adpcm_int_2); |
| 67 | | required_device<cpu_device> m_maincpu; |
| 68 | | required_device<cpu_device> m_audiocpu; |
| 69 | | required_device<msm5205_device> m_msm1; |
| 70 | | required_device<msm5205_device> m_msm2; |
| 71 | | required_device<gfxdecode_device> m_gfxdecode; |
| 72 | | required_device<palette_device> m_palette; |
| 73 | | |
| 74 | | required_device<tecmo_spr_device> m_sprgen; |
| 73 | |
| 74 | UINT32 screen_update_left(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 75 | UINT32 screen_update_right(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 76 | |
| 77 | void adpcm_int(msm5205_device *device, int chip); |
| 78 | DECLARE_WRITE_LINE_MEMBER(adpcm_int_1); |
| 79 | DECLARE_WRITE_LINE_MEMBER(adpcm_int_2); |
| 75 | 80 | }; |
trunk/src/mame/video/tbowl.c
| r243817 | r243818 | |
| 19 | 19 | SET_TILE_INFO_MEMBER(0,tileno,col,0); |
| 20 | 20 | } |
| 21 | 21 | |
| 22 | | WRITE8_MEMBER(tbowl_state::tbowl_txvideoram_w) |
| 22 | WRITE8_MEMBER(tbowl_state::txvideoram_w) |
| 23 | 23 | { |
| 24 | 24 | m_txvideoram[offset] = data; |
| 25 | 25 | m_tx_tilemap->mark_tile_dirty(offset & 0x7ff); |
| r243817 | r243818 | |
| 38 | 38 | SET_TILE_INFO_MEMBER(1,tileno,col,0); |
| 39 | 39 | } |
| 40 | 40 | |
| 41 | | WRITE8_MEMBER(tbowl_state::tbowl_bg2videoram_w) |
| 41 | WRITE8_MEMBER(tbowl_state::bg2videoram_w) |
| 42 | 42 | { |
| 43 | 43 | m_bg2videoram[offset] = data; |
| 44 | 44 | m_bg2_tilemap->mark_tile_dirty(offset & 0xfff); |
| 45 | 45 | } |
| 46 | 46 | |
| 47 | | WRITE8_MEMBER(tbowl_state::tbowl_bgxscroll_lo) |
| 47 | WRITE8_MEMBER(tbowl_state::bgxscroll_lo) |
| 48 | 48 | { |
| 49 | 49 | m_xscroll = (m_xscroll & 0xff00) | data; |
| 50 | 50 | } |
| 51 | 51 | |
| 52 | | WRITE8_MEMBER(tbowl_state::tbowl_bgxscroll_hi) |
| 52 | WRITE8_MEMBER(tbowl_state::bgxscroll_hi) |
| 53 | 53 | { |
| 54 | 54 | m_xscroll = (m_xscroll & 0x00ff) | (data << 8); |
| 55 | 55 | } |
| 56 | 56 | |
| 57 | | WRITE8_MEMBER(tbowl_state::tbowl_bgyscroll_lo) |
| 57 | WRITE8_MEMBER(tbowl_state::bgyscroll_lo) |
| 58 | 58 | { |
| 59 | 59 | m_yscroll = (m_yscroll & 0xff00) | data; |
| 60 | 60 | } |
| 61 | 61 | |
| 62 | | WRITE8_MEMBER(tbowl_state::tbowl_bgyscroll_hi) |
| 62 | WRITE8_MEMBER(tbowl_state::bgyscroll_hi) |
| 63 | 63 | { |
| 64 | 64 | m_yscroll = (m_yscroll & 0x00ff) | (data << 8); |
| 65 | 65 | } |
| r243817 | r243818 | |
| 78 | 78 | SET_TILE_INFO_MEMBER(2,tileno,col,0); |
| 79 | 79 | } |
| 80 | 80 | |
| 81 | | WRITE8_MEMBER(tbowl_state::tbowl_bgvideoram_w) |
| 81 | WRITE8_MEMBER(tbowl_state::bgvideoram_w) |
| 82 | 82 | { |
| 83 | 83 | m_bgvideoram[offset] = data; |
| 84 | 84 | m_bg_tilemap->mark_tile_dirty(offset & 0xfff); |
| 85 | 85 | } |
| 86 | 86 | |
| 87 | | WRITE8_MEMBER(tbowl_state::tbowl_bg2xscroll_lo) |
| 87 | WRITE8_MEMBER(tbowl_state::bg2xscroll_lo) |
| 88 | 88 | { |
| 89 | 89 | m_bg2xscroll = (m_bg2xscroll & 0xff00) | data; |
| 90 | 90 | } |
| 91 | 91 | |
| 92 | | WRITE8_MEMBER(tbowl_state::tbowl_bg2xscroll_hi) |
| 92 | WRITE8_MEMBER(tbowl_state::bg2xscroll_hi) |
| 93 | 93 | { |
| 94 | 94 | m_bg2xscroll = (m_bg2xscroll & 0x00ff) | (data << 8); |
| 95 | 95 | } |
| 96 | 96 | |
| 97 | | WRITE8_MEMBER(tbowl_state::tbowl_bg2yscroll_lo) |
| 97 | WRITE8_MEMBER(tbowl_state::bg2yscroll_lo) |
| 98 | 98 | { |
| 99 | 99 | m_bg2yscroll = (m_bg2yscroll & 0xff00) | data; |
| 100 | 100 | } |
| 101 | 101 | |
| 102 | | WRITE8_MEMBER(tbowl_state::tbowl_bg2yscroll_hi) |
| 102 | WRITE8_MEMBER(tbowl_state::bg2yscroll_hi) |
| 103 | 103 | { |
| 104 | 104 | m_bg2yscroll = (m_bg2yscroll & 0x00ff) | (data << 8); |
| 105 | 105 | } |
| r243817 | r243818 | |
| 116 | 116 | m_tx_tilemap->set_transparent_pen(0); |
| 117 | 117 | m_bg_tilemap->set_transparent_pen(0); |
| 118 | 118 | m_bg2_tilemap->set_transparent_pen(0); |
| 119 | |
| 120 | save_item(NAME(m_xscroll)); |
| 121 | save_item(NAME(m_yscroll)); |
| 122 | save_item(NAME(m_bg2xscroll)); |
| 123 | save_item(NAME(m_bg2yscroll)); |
| 119 | 124 | } |
| 120 | 125 | |
| 121 | 126 | |
| 122 | 127 | |
| 123 | | UINT32 tbowl_state::screen_update_tbowl_left(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 128 | UINT32 tbowl_state::screen_update_left(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 124 | 129 | { |
| 125 | 130 | m_bg_tilemap->set_scrollx(0, m_xscroll ); |
| 126 | 131 | m_bg_tilemap->set_scrolly(0, m_yscroll ); |
| r243817 | r243818 | |
| 138 | 143 | return 0; |
| 139 | 144 | } |
| 140 | 145 | |
| 141 | | UINT32 tbowl_state::screen_update_tbowl_right(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 146 | UINT32 tbowl_state::screen_update_right(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 142 | 147 | { |
| 143 | 148 | m_bg_tilemap->set_scrollx(0, m_xscroll+32*8 ); |
| 144 | 149 | m_bg_tilemap->set_scrolly(0, m_yscroll ); |