trunk/src/mame/drivers/capbowl.c
| r244638 | r244639 | |
| 103 | 103 | * |
| 104 | 104 | *************************************/ |
| 105 | 105 | |
| 106 | | INTERRUPT_GEN_MEMBER(capbowl_state::capbowl_interrupt) |
| 106 | INTERRUPT_GEN_MEMBER(capbowl_state::interrupt) |
| 107 | 107 | { |
| 108 | 108 | if (ioport("SERVICE")->read() & 1) /* get status of the F2 key */ |
| 109 | 109 | device.execute().set_input_line(INPUT_LINE_NMI, PULSE_LINE); /* trigger self test */ |
| r244638 | r244639 | |
| 121 | 121 | { |
| 122 | 122 | switch (id) |
| 123 | 123 | { |
| 124 | | case TIMER_CAPBOWL_UPDATE: |
| 125 | | capbowl_update(ptr, param); |
| 124 | case TIMER_UPDATE: |
| 125 | update(ptr, param); |
| 126 | 126 | break; |
| 127 | 127 | default: |
| 128 | 128 | assert_always(FALSE, "Unknown id in capbowl_state::device_timer"); |
| r244638 | r244639 | |
| 130 | 130 | } |
| 131 | 131 | |
| 132 | 132 | |
| 133 | | TIMER_CALLBACK_MEMBER(capbowl_state::capbowl_update) |
| 133 | TIMER_CALLBACK_MEMBER(capbowl_state::update) |
| 134 | 134 | { |
| 135 | 135 | int scanline = param; |
| 136 | 136 | |
| 137 | 137 | m_screen->update_partial(scanline - 1); |
| 138 | 138 | scanline += 32; |
| 139 | 139 | if (scanline > 240) scanline = 32; |
| 140 | | timer_set(m_screen->time_until_pos(scanline), TIMER_CAPBOWL_UPDATE, scanline); |
| 140 | m_update_timer->adjust(m_screen->time_until_pos(scanline), scanline); |
| 141 | 141 | } |
| 142 | 142 | |
| 143 | 143 | |
| r244638 | r244639 | |
| 190 | 190 | * |
| 191 | 191 | *************************************/ |
| 192 | 192 | |
| 193 | | WRITE8_MEMBER(capbowl_state::capbowl_sndcmd_w) |
| 193 | WRITE8_MEMBER(capbowl_state::sndcmd_w) |
| 194 | 194 | { |
| 195 | 195 | m_audiocpu->set_input_line(M6809_IRQ_LINE, HOLD_LINE); |
| 196 | 196 | soundlatch_byte_w(space, offset, data); |
| 197 | 197 | } |
| 198 | 198 | |
| 199 | 199 | |
| 200 | | |
| 201 | 200 | /************************************* |
| 202 | 201 | * |
| 203 | | * Handler called by the 2203 emulator |
| 204 | | * when the internal timers cause an IRQ |
| 205 | | * |
| 206 | | *************************************/ |
| 207 | | |
| 208 | | WRITE_LINE_MEMBER(capbowl_state::firqhandler) |
| 209 | | { |
| 210 | | m_audiocpu->set_input_line(M6809_FIRQ_LINE, state ? ASSERT_LINE : CLEAR_LINE); |
| 211 | | } |
| 212 | | |
| 213 | | |
| 214 | | |
| 215 | | /************************************* |
| 216 | | * |
| 217 | 202 | * Main CPU memory handlers |
| 218 | 203 | * |
| 219 | 204 | *************************************/ |
| r244638 | r244639 | |
| 223 | 208 | AM_RANGE(0x4000, 0x4000) AM_WRITEONLY AM_SHARE("rowaddress") |
| 224 | 209 | AM_RANGE(0x4800, 0x4800) AM_WRITE(capbowl_rom_select_w) |
| 225 | 210 | AM_RANGE(0x5000, 0x57ff) AM_RAM AM_SHARE("nvram") |
| 226 | | AM_RANGE(0x5800, 0x5fff) AM_READWRITE(capbowl_tms34061_r, capbowl_tms34061_w) |
| 227 | | AM_RANGE(0x6000, 0x6000) AM_WRITE(capbowl_sndcmd_w) |
| 211 | AM_RANGE(0x5800, 0x5fff) AM_READWRITE(tms34061_r, tms34061_w) |
| 212 | AM_RANGE(0x6000, 0x6000) AM_WRITE(sndcmd_w) |
| 228 | 213 | AM_RANGE(0x6800, 0x6800) AM_WRITE(track_reset_w) AM_READNOP /* + watchdog */ |
| 229 | 214 | AM_RANGE(0x7000, 0x7000) AM_READ(track_0_r) /* + other inputs */ |
| 230 | 215 | AM_RANGE(0x7800, 0x7800) AM_READ(track_1_r) /* + other inputs */ |
| r244638 | r244639 | |
| 236 | 221 | AM_RANGE(0x0000, 0x001f) AM_READWRITE(bowlrama_blitter_r, bowlrama_blitter_w) |
| 237 | 222 | AM_RANGE(0x4000, 0x4000) AM_WRITEONLY AM_SHARE("rowaddress") |
| 238 | 223 | AM_RANGE(0x5000, 0x57ff) AM_RAM AM_SHARE("nvram") |
| 239 | | AM_RANGE(0x5800, 0x5fff) AM_READWRITE(capbowl_tms34061_r, capbowl_tms34061_w) |
| 240 | | AM_RANGE(0x6000, 0x6000) AM_WRITE(capbowl_sndcmd_w) |
| 224 | AM_RANGE(0x5800, 0x5fff) AM_READWRITE(tms34061_r, tms34061_w) |
| 225 | AM_RANGE(0x6000, 0x6000) AM_WRITE(sndcmd_w) |
| 241 | 226 | AM_RANGE(0x6800, 0x6800) AM_WRITE(track_reset_w) AM_READNOP /* + watchdog */ |
| 242 | 227 | AM_RANGE(0x7000, 0x7000) AM_READ(track_0_r) /* + other inputs */ |
| 243 | 228 | AM_RANGE(0x7800, 0x7800) AM_READ(track_1_r) /* + other inputs */ |
| r244638 | r244639 | |
| 301 | 286 | |
| 302 | 287 | /************************************* |
| 303 | 288 | * |
| 304 | | * TMS34061 interfacing |
| 305 | | * |
| 306 | | *************************************/ |
| 307 | | |
| 308 | | WRITE_LINE_MEMBER(capbowl_state::generate_tms34061_interrupt) |
| 309 | | { |
| 310 | | m_maincpu->set_input_line(M6809_FIRQ_LINE, state); |
| 311 | | } |
| 312 | | |
| 313 | | /************************************* |
| 314 | | * |
| 315 | 289 | * Machine driver |
| 316 | 290 | * |
| 317 | 291 | *************************************/ |
| 318 | 292 | |
| 319 | 293 | void capbowl_state::machine_start() |
| 320 | 294 | { |
| 295 | m_update_timer = timer_alloc(TIMER_UPDATE); |
| 296 | |
| 321 | 297 | save_item(NAME(m_blitter_addr)); |
| 322 | | save_item(NAME(m_last_trackball_val[0])); |
| 323 | | save_item(NAME(m_last_trackball_val[1])); |
| 298 | save_item(NAME(m_last_trackball_val)); |
| 324 | 299 | } |
| 325 | 300 | |
| 326 | 301 | void capbowl_state::machine_reset() |
| 327 | 302 | { |
| 328 | | timer_set(m_screen->time_until_pos(32), TIMER_CAPBOWL_UPDATE, 32); |
| 303 | m_update_timer->adjust(m_screen->time_until_pos(32), 32); |
| 329 | 304 | |
| 330 | 305 | m_blitter_addr = 0; |
| 331 | 306 | m_last_trackball_val[0] = 0; |
| r244638 | r244639 | |
| 338 | 313 | /* basic machine hardware */ |
| 339 | 314 | MCFG_CPU_ADD("maincpu", M6809E, MASTER_CLOCK) |
| 340 | 315 | MCFG_CPU_PROGRAM_MAP(capbowl_map) |
| 341 | | MCFG_CPU_VBLANK_INT_DRIVER("screen", capbowl_state, capbowl_interrupt) |
| 316 | MCFG_CPU_VBLANK_INT_DRIVER("screen", capbowl_state, interrupt) |
| 342 | 317 | MCFG_WATCHDOG_TIME_INIT(PERIOD_OF_555_ASTABLE(100000.0, 100000.0, 0.1e-6) * 15.5) // ~0.3s |
| 343 | 318 | |
| 344 | 319 | MCFG_CPU_ADD("audiocpu", M6809E, MASTER_CLOCK) |
| r244638 | r244639 | |
| 354 | 329 | MCFG_SCREEN_SIZE(360, 256) |
| 355 | 330 | MCFG_SCREEN_VISIBLE_AREA(0, 359, 0, 244) |
| 356 | 331 | MCFG_SCREEN_REFRESH_RATE(57) |
| 357 | | MCFG_SCREEN_UPDATE_DRIVER(capbowl_state, screen_update_capbowl) |
| 332 | MCFG_SCREEN_UPDATE_DRIVER(capbowl_state, screen_update) |
| 358 | 333 | |
| 359 | 334 | MCFG_DEVICE_ADD("tms34061", TMS34061, 0) |
| 360 | 335 | MCFG_TMS34061_ROWSHIFT(8) /* VRAM address is (row << rowshift) | col */ |
| 361 | 336 | MCFG_TMS34061_VRAM_SIZE(0x10000) /* size of video RAM */ |
| 362 | | MCFG_TMS34061_INTERRUPT_CB(WRITELINE(capbowl_state, generate_tms34061_interrupt)) /* interrupt gen callback */ |
| 337 | MCFG_TMS34061_INTERRUPT_CB(INPUTLINE("maincpu", M6809_FIRQ_LINE)) /* interrupt gen callback */ |
| 363 | 338 | |
| 364 | 339 | /* sound hardware */ |
| 365 | 340 | MCFG_SPEAKER_STANDARD_MONO("mono") |
| 366 | 341 | |
| 367 | 342 | MCFG_SOUND_ADD("ymsnd", YM2203, MASTER_CLOCK/2) |
| 368 | | MCFG_YM2203_IRQ_HANDLER(WRITELINE(capbowl_state, firqhandler)) |
| 343 | MCFG_YM2203_IRQ_HANDLER(INPUTLINE("audiocpu", M6809_FIRQ_LINE)) |
| 369 | 344 | MCFG_AY8910_PORT_A_READ_CB(DEVREAD8("ticket", ticket_dispenser_device, read)) |
| 370 | 345 | MCFG_AY8910_PORT_B_WRITE_CB(DEVWRITE8("ticket", ticket_dispenser_device, write)) /* Also a status LED. See memory map above */ |
| 371 | 346 | MCFG_SOUND_ROUTE(0, "mono", 0.07) |
| r244638 | r244639 | |
| 492 | 467 | * |
| 493 | 468 | *************************************/ |
| 494 | 469 | |
| 495 | | GAME( 1988, capbowl, 0, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Capcom Bowling (set 1)", 0 ) |
| 496 | | GAME( 1988, capbowl2, capbowl, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Capcom Bowling (set 2)", 0 ) |
| 497 | | GAME( 1988, capbowl3, capbowl, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Capcom Bowling (set 3)", 0 ) |
| 498 | | GAME( 1988, capbowl4, capbowl, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Capcom Bowling (set 4)", 0 ) |
| 499 | | GAME( 1989, clbowl, capbowl, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Coors Light Bowling", 0 ) |
| 500 | | GAME( 1991, bowlrama, 0, bowlrama, capbowl, driver_device, 0, ROT270, "P&P Marketing", "Bowl-O-Rama", 0 ) |
| 470 | GAME( 1988, capbowl, 0, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Capcom Bowling (set 1)", GAME_SUPPORTS_SAVE ) |
| 471 | GAME( 1988, capbowl2, capbowl, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Capcom Bowling (set 2)", GAME_SUPPORTS_SAVE ) |
| 472 | GAME( 1988, capbowl3, capbowl, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Capcom Bowling (set 3)", GAME_SUPPORTS_SAVE ) |
| 473 | GAME( 1988, capbowl4, capbowl, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Capcom Bowling (set 4)", GAME_SUPPORTS_SAVE ) |
| 474 | GAME( 1989, clbowl, capbowl, capbowl, capbowl, capbowl_state, capbowl, ROT270, "Incredible Technologies / Capcom", "Coors Light Bowling", GAME_SUPPORTS_SAVE ) |
| 475 | GAME( 1991, bowlrama, 0, bowlrama, capbowl, driver_device, 0, ROT270, "P&P Marketing", "Bowl-O-Rama", GAME_SUPPORTS_SAVE ) |
trunk/src/mame/includes/capbowl.h
| r244638 | r244639 | |
| 12 | 12 | public: |
| 13 | 13 | enum |
| 14 | 14 | { |
| 15 | | TIMER_CAPBOWL_UPDATE |
| 15 | TIMER_UPDATE |
| 16 | 16 | }; |
| 17 | 17 | |
| 18 | 18 | capbowl_state(const machine_config &mconfig, device_type type, const char *tag) |
| 19 | 19 | : driver_device(mconfig, type, tag), |
| 20 | | m_rowaddress(*this, "rowaddress"), |
| 21 | 20 | m_maincpu(*this, "maincpu"), |
| 22 | 21 | m_audiocpu(*this, "audiocpu"), |
| 23 | 22 | m_tms34061(*this, "tms34061"), |
| 24 | | m_screen(*this, "screen") { } |
| 23 | m_screen(*this, "screen"), |
| 24 | m_rowaddress(*this, "rowaddress") { } |
| 25 | 25 | |
| 26 | /* devices */ |
| 27 | required_device<cpu_device> m_maincpu; |
| 28 | required_device<cpu_device> m_audiocpu; |
| 29 | required_device<tms34061_device> m_tms34061; |
| 30 | required_device<screen_device> m_screen; |
| 31 | |
| 26 | 32 | /* memory pointers */ |
| 27 | 33 | required_shared_ptr<UINT8> m_rowaddress; |
| 28 | 34 | |
| r244638 | r244639 | |
| 31 | 37 | |
| 32 | 38 | /* input-related */ |
| 33 | 39 | UINT8 m_last_trackball_val[2]; |
| 40 | |
| 41 | emu_timer *m_update_timer; |
| 34 | 42 | |
| 35 | | /* devices */ |
| 36 | | required_device<cpu_device> m_maincpu; |
| 37 | | required_device<cpu_device> m_audiocpu; |
| 38 | | required_device<tms34061_device> m_tms34061; |
| 39 | | required_device<screen_device> m_screen; |
| 40 | | |
| 41 | | DECLARE_WRITE8_MEMBER(capbowl_rom_select_w); |
| 43 | // common |
| 42 | 44 | DECLARE_READ8_MEMBER(track_0_r); |
| 43 | 45 | DECLARE_READ8_MEMBER(track_1_r); |
| 44 | 46 | DECLARE_WRITE8_MEMBER(track_reset_w); |
| 45 | | DECLARE_WRITE8_MEMBER(capbowl_sndcmd_w); |
| 46 | | DECLARE_WRITE8_MEMBER(capbowl_tms34061_w); |
| 47 | | DECLARE_READ8_MEMBER(capbowl_tms34061_r); |
| 47 | DECLARE_WRITE8_MEMBER(sndcmd_w); |
| 48 | DECLARE_WRITE8_MEMBER(tms34061_w); |
| 49 | DECLARE_READ8_MEMBER(tms34061_r); |
| 50 | |
| 51 | // capbowl specific |
| 52 | DECLARE_WRITE8_MEMBER(capbowl_rom_select_w); |
| 53 | |
| 54 | // bowlrama specific |
| 48 | 55 | DECLARE_WRITE8_MEMBER(bowlrama_blitter_w); |
| 49 | 56 | DECLARE_READ8_MEMBER(bowlrama_blitter_r); |
| 57 | |
| 50 | 58 | DECLARE_DRIVER_INIT(capbowl); |
| 51 | 59 | virtual void machine_start(); |
| 52 | 60 | virtual void machine_reset(); |
| 53 | | UINT32 screen_update_capbowl(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect); |
| 54 | | INTERRUPT_GEN_MEMBER(capbowl_interrupt); |
| 55 | | TIMER_CALLBACK_MEMBER(capbowl_update); |
| 61 | |
| 62 | INTERRUPT_GEN_MEMBER(interrupt); |
| 63 | TIMER_CALLBACK_MEMBER(update); |
| 64 | |
| 65 | UINT32 screen_update(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect); |
| 56 | 66 | inline rgb_t pen_for_pixel( UINT8 *src, UINT8 pix ); |
| 57 | | DECLARE_WRITE_LINE_MEMBER(firqhandler); |
| 58 | | DECLARE_WRITE_LINE_MEMBER(generate_tms34061_interrupt); |
| 59 | 67 | |
| 60 | 68 | protected: |
| 61 | 69 | virtual void device_timer(emu_timer &timer, device_timer_id id, int param, void *ptr); |