trunk/src/mame/drivers/tecmosys.c
| r243683 | r243684 | |
| 309 | 309 | AM_RANGE(0xa00000, 0xa00001) AM_WRITE(eeprom_w ) |
| 310 | 310 | AM_RANGE(0xa80000, 0xa80005) AM_WRITEONLY AM_SHARE("a80000regs") // a80000-3 scroll? a80004 inverted ? 3 : 0 |
| 311 | 311 | AM_RANGE(0xb00000, 0xb00005) AM_WRITEONLY AM_SHARE("b00000regs") // b00000-3 scrool?, b00004 inverted ? 3 : 0 |
| 312 | | AM_RANGE(0xb80000, 0xb80001) AM_READWRITE(tecmosys_prot_status_r, tecmosys_prot_status_w) |
| 312 | AM_RANGE(0xb80000, 0xb80001) AM_READWRITE(prot_status_r, prot_status_w) |
| 313 | 313 | AM_RANGE(0xc00000, 0xc00005) AM_WRITEONLY AM_SHARE("c00000regs") // c00000-3 scroll? c00004 inverted ? 13 : 10 |
| 314 | 314 | AM_RANGE(0xc80000, 0xc80005) AM_WRITEONLY AM_SHARE("c80000regs") // c80000-3 scrool? c80004 inverted ? 3 : 0 |
| 315 | 315 | AM_RANGE(0xd00000, 0xd00001) AM_READ_PORT("P1") |
| 316 | 316 | AM_RANGE(0xd00002, 0xd00003) AM_READ_PORT("P2") |
| 317 | 317 | AM_RANGE(0xd80000, 0xd80001) AM_READ(eeprom_r) |
| 318 | 318 | AM_RANGE(0xe00000, 0xe00001) AM_WRITE(sound_w ) |
| 319 | | AM_RANGE(0xe80000, 0xe80001) AM_WRITE(tecmosys_prot_data_w) |
| 319 | AM_RANGE(0xe80000, 0xe80001) AM_WRITE(prot_data_w) |
| 320 | 320 | AM_RANGE(0xf00000, 0xf00001) AM_READ(sound_r) |
| 321 | | AM_RANGE(0xf80000, 0xf80001) AM_READ(tecmosys_prot_data_r) |
| 321 | AM_RANGE(0xf80000, 0xf80001) AM_READ(prot_data_r) |
| 322 | 322 | ADDRESS_MAP_END |
| 323 | 323 | |
| 324 | 324 | |
| 325 | | WRITE8_MEMBER(tecmosys_state::tecmosys_z80_bank_w) |
| 325 | WRITE8_MEMBER(tecmosys_state::z80_bank_w) |
| 326 | 326 | { |
| 327 | 327 | membank("bank1")->set_entry(data); |
| 328 | 328 | } |
| 329 | 329 | |
| 330 | | WRITE8_MEMBER(tecmosys_state::tecmosys_oki_bank_w) |
| 330 | WRITE8_MEMBER(tecmosys_state::oki_bank_w) |
| 331 | 331 | { |
| 332 | 332 | UINT8 upperbank = (data & 0x30) >> 4; |
| 333 | 333 | UINT8 lowerbank = (data & 0x03) >> 0; |
| r243683 | r243684 | |
| 347 | 347 | ADDRESS_MAP_GLOBAL_MASK(0xff) |
| 348 | 348 | AM_RANGE(0x00, 0x03) AM_DEVREADWRITE("ymf", ymf262_device, read, write) |
| 349 | 349 | AM_RANGE(0x10, 0x10) AM_DEVREADWRITE("oki", okim6295_device, read, write) |
| 350 | | AM_RANGE(0x20, 0x20) AM_WRITE(tecmosys_oki_bank_w) |
| 351 | | AM_RANGE(0x30, 0x30) AM_WRITE(tecmosys_z80_bank_w) |
| 350 | AM_RANGE(0x20, 0x20) AM_WRITE(oki_bank_w) |
| 351 | AM_RANGE(0x30, 0x30) AM_WRITE(z80_bank_w) |
| 352 | 352 | AM_RANGE(0x40, 0x40) AM_READ(soundlatch_byte_r) |
| 353 | 353 | AM_RANGE(0x50, 0x50) AM_WRITE(soundlatch2_byte_w) |
| 354 | 354 | AM_RANGE(0x60, 0x61) AM_DEVREADWRITE("ymz", ymz280b_device, read, write) |
| r243683 | r243684 | |
| 441 | 441 | void tecmosys_state::machine_start() |
| 442 | 442 | { |
| 443 | 443 | membank("bank1")->configure_entries(0, 16, memregion("audiocpu")->base(), 0x4000); |
| 444 | |
| 445 | save_item(NAME(m_device_read_ptr)); |
| 446 | save_item(NAME(m_device_status)); |
| 447 | save_item(NAME(m_device_value)); |
| 444 | 448 | } |
| 445 | 449 | |
| 446 | 450 | static MACHINE_CONFIG_START( deroon, tecmosys_state ) |
| r243683 | r243684 | |
| 465 | 469 | MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(3000)) |
| 466 | 470 | MCFG_SCREEN_SIZE(64*8, 64*8) |
| 467 | 471 | MCFG_SCREEN_VISIBLE_AREA(0*8, 40*8-1, 0*8, 30*8-1) |
| 468 | | MCFG_SCREEN_UPDATE_DRIVER(tecmosys_state, screen_update_tecmosys) |
| 472 | MCFG_SCREEN_UPDATE_DRIVER(tecmosys_state, screen_update) |
| 469 | 473 | |
| 470 | 474 | MCFG_PALETTE_ADD("palette", 0x4000+0x800) |
| 471 | 475 | MCFG_PALETTE_FORMAT(xGGGGGRRRRRBBBBB) |
| r243683 | r243684 | |
| 620 | 624 | ROM_LOAD( "ae500w07.ad1", 0x080000, 0x080000, CRC(3734f92c) SHA1(048555b5aa89eaf983305c439ba08d32b4a1bb80) ) |
| 621 | 625 | ROM_END |
| 622 | 626 | |
| 623 | | void tecmosys_state::tecmosys_descramble() |
| 627 | void tecmosys_state::descramble() |
| 624 | 628 | { |
| 625 | 629 | UINT8 *gfxsrc = memregion( "gfx1" )->base(); |
| 626 | 630 | size_t srcsize = memregion( "gfx1" )->bytes(); |
| r243683 | r243684 | |
| 644 | 648 | |
| 645 | 649 | DRIVER_INIT_MEMBER(tecmosys_state,deroon) |
| 646 | 650 | { |
| 647 | | tecmosys_descramble(); |
| 648 | | tecmosys_prot_init(0); // machine/tecmosys.c |
| 651 | descramble(); |
| 652 | prot_init(0); // machine/tecmosys.c |
| 649 | 653 | } |
| 650 | 654 | |
| 651 | 655 | DRIVER_INIT_MEMBER(tecmosys_state,tkdensho) |
| 652 | 656 | { |
| 653 | | tecmosys_descramble(); |
| 654 | | tecmosys_prot_init(1); |
| 657 | descramble(); |
| 658 | prot_init(1); |
| 655 | 659 | } |
| 656 | 660 | |
| 657 | 661 | DRIVER_INIT_MEMBER(tecmosys_state,tkdensha) |
| 658 | 662 | { |
| 659 | | tecmosys_descramble(); |
| 660 | | tecmosys_prot_init(2); |
| 663 | descramble(); |
| 664 | prot_init(2); |
| 661 | 665 | } |
| 662 | 666 | |
| 663 | | GAME( 1995, deroon, 0, deroon, deroon, tecmosys_state, deroon, ROT0, "Tecmo", "Deroon DeroDero", 0 ) |
| 664 | | GAME( 1996, tkdensho, 0, deroon, deroon, tecmosys_state, tkdensho, ROT0, "Tecmo", "Toukidenshou - Angel Eyes (VER. 960614)", 0 ) |
| 665 | | GAME( 1996, tkdenshoa, tkdensho, deroon, deroon, tecmosys_state, tkdensha, ROT0, "Tecmo", "Toukidenshou - Angel Eyes (VER. 960427)", 0 ) |
| 667 | GAME( 1995, deroon, 0, deroon, deroon, tecmosys_state, deroon, ROT0, "Tecmo", "Deroon DeroDero", GAME_SUPPORTS_SAVE ) |
| 668 | GAME( 1996, tkdensho, 0, deroon, deroon, tecmosys_state, tkdensho, ROT0, "Tecmo", "Toukidenshou - Angel Eyes (VER. 960614)", GAME_SUPPORTS_SAVE ) |
| 669 | GAME( 1996, tkdenshoa, tkdensho, deroon, deroon, tecmosys_state, tkdensha, ROT0, "Tecmo", "Toukidenshou - Angel Eyes (VER. 960427)", GAME_SUPPORTS_SAVE ) |
trunk/src/mame/drivers/tehkanwc.c
| r243683 | r243684 | |
| 91 | 91 | #include "emu.h" |
| 92 | 92 | #include "cpu/z80/z80.h" |
| 93 | 93 | #include "sound/ay8910.h" |
| 94 | | #include "sound/msm5205.h" |
| 95 | 94 | #include "gridiron.lh" |
| 96 | 95 | #include "includes/tehkanwc.h" |
| 97 | 96 | |
| 97 | |
| 98 | void tehkanwc_state::machine_start() |
| 99 | { |
| 100 | save_item(NAME(m_track0)); |
| 101 | save_item(NAME(m_track1)); |
| 102 | save_item(NAME(m_msm_data_offs)); |
| 103 | save_item(NAME(m_toggle)); |
| 104 | } |
| 105 | |
| 98 | 106 | WRITE8_MEMBER(tehkanwc_state::sub_cpu_halt_w) |
| 99 | 107 | { |
| 100 | 108 | if (data) |
| r243683 | r243684 | |
| 104 | 112 | } |
| 105 | 113 | |
| 106 | 114 | |
| 107 | | READ8_MEMBER(tehkanwc_state::tehkanwc_track_0_r) |
| 115 | READ8_MEMBER(tehkanwc_state::track_0_r) |
| 108 | 116 | { |
| 109 | 117 | int joy; |
| 110 | 118 | |
| r243683 | r243684 | |
| 114 | 122 | return ioport(offset ? "P1Y" : "P1X")->read() - m_track0[offset]; |
| 115 | 123 | } |
| 116 | 124 | |
| 117 | | READ8_MEMBER(tehkanwc_state::tehkanwc_track_1_r) |
| 125 | READ8_MEMBER(tehkanwc_state::track_1_r) |
| 118 | 126 | { |
| 119 | 127 | int joy; |
| 120 | 128 | |
| r243683 | r243684 | |
| 124 | 132 | return ioport(offset ? "P2Y" : "P2X")->read() - m_track1[offset]; |
| 125 | 133 | } |
| 126 | 134 | |
| 127 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_track_0_reset_w) |
| 135 | WRITE8_MEMBER(tehkanwc_state::track_0_reset_w) |
| 128 | 136 | { |
| 129 | 137 | /* reset the trackball counters */ |
| 130 | 138 | m_track0[offset] = ioport(offset ? "P1Y" : "P1X")->read() + data; |
| 131 | 139 | } |
| 132 | 140 | |
| 133 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_track_1_reset_w) |
| 141 | WRITE8_MEMBER(tehkanwc_state::track_1_reset_w) |
| 134 | 142 | { |
| 135 | 143 | /* reset the trackball counters */ |
| 136 | 144 | m_track1[offset] = ioport(offset ? "P2Y" : "P2X")->read() + data; |
| r243683 | r243684 | |
| 169 | 177 | /* Emulate MSM sound samples with counters */ |
| 170 | 178 | |
| 171 | 179 | |
| 172 | | READ8_MEMBER(tehkanwc_state::tehkanwc_portA_r) |
| 180 | READ8_MEMBER(tehkanwc_state::portA_r) |
| 173 | 181 | { |
| 174 | 182 | return m_msm_data_offs & 0xff; |
| 175 | 183 | } |
| 176 | 184 | |
| 177 | | READ8_MEMBER(tehkanwc_state::tehkanwc_portB_r) |
| 185 | READ8_MEMBER(tehkanwc_state::portB_r) |
| 178 | 186 | { |
| 179 | 187 | return (m_msm_data_offs >> 8) & 0xff; |
| 180 | 188 | } |
| 181 | 189 | |
| 182 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_portA_w) |
| 190 | WRITE8_MEMBER(tehkanwc_state::portA_w) |
| 183 | 191 | { |
| 184 | 192 | m_msm_data_offs = (m_msm_data_offs & 0xff00) | data; |
| 185 | 193 | } |
| 186 | 194 | |
| 187 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_portB_w) |
| 195 | WRITE8_MEMBER(tehkanwc_state::portB_w) |
| 188 | 196 | { |
| 189 | 197 | m_msm_data_offs = (m_msm_data_offs & 0x00ff) | (data << 8); |
| 190 | 198 | } |
| r243683 | r243684 | |
| 194 | 202 | m_msm->reset_w(data ? 0 : 1); |
| 195 | 203 | } |
| 196 | 204 | |
| 197 | | WRITE_LINE_MEMBER(tehkanwc_state::tehkanwc_adpcm_int) |
| 205 | WRITE_LINE_MEMBER(tehkanwc_state::adpcm_int) |
| 198 | 206 | { |
| 199 | 207 | UINT8 *SAMPLES = memregion("adpcm")->base(); |
| 200 | 208 | int msm_data = SAMPLES[m_msm_data_offs & 0x7fff]; |
| r243683 | r243684 | |
| 218 | 226 | AM_RANGE(0x0000, 0xbfff) AM_ROM |
| 219 | 227 | AM_RANGE(0xc000, 0xc7ff) AM_RAM |
| 220 | 228 | AM_RANGE(0xc800, 0xcfff) AM_RAM AM_SHARE("share1") |
| 221 | | AM_RANGE(0xd000, 0xd3ff) AM_RAM_WRITE(tehkanwc_videoram_w) AM_SHARE("videoram") |
| 222 | | AM_RANGE(0xd400, 0xd7ff) AM_RAM_WRITE(tehkanwc_colorram_w) AM_SHARE("colorram") |
| 229 | AM_RANGE(0xd000, 0xd3ff) AM_RAM_WRITE(videoram_w) AM_SHARE("videoram") |
| 230 | AM_RANGE(0xd400, 0xd7ff) AM_RAM_WRITE(colorram_w) AM_SHARE("colorram") |
| 223 | 231 | AM_RANGE(0xd800, 0xddff) AM_RAM_DEVWRITE("palette", palette_device, write) AM_SHARE("palette") |
| 224 | 232 | AM_RANGE(0xde00, 0xdfff) AM_RAM AM_SHARE("share5") /* unused part of the palette RAM, I think? Gridiron uses it */ |
| 225 | | AM_RANGE(0xe000, 0xe7ff) AM_RAM_WRITE(tehkanwc_videoram2_w) AM_SHARE("videoram2") |
| 233 | AM_RANGE(0xe000, 0xe7ff) AM_RAM_WRITE(videoram2_w) AM_SHARE("videoram2") |
| 226 | 234 | AM_RANGE(0xe800, 0xebff) AM_RAM AM_SHARE("spriteram") /* sprites */ |
| 227 | | AM_RANGE(0xec00, 0xec01) AM_RAM_WRITE(tehkanwc_scroll_x_w) |
| 228 | | AM_RANGE(0xec02, 0xec02) AM_RAM_WRITE(tehkanwc_scroll_y_w) |
| 229 | | AM_RANGE(0xf800, 0xf801) AM_READWRITE(tehkanwc_track_0_r, tehkanwc_track_0_reset_w) /* track 0 x/y */ |
| 235 | AM_RANGE(0xec00, 0xec01) AM_RAM_WRITE(scroll_x_w) |
| 236 | AM_RANGE(0xec02, 0xec02) AM_RAM_WRITE(scroll_y_w) |
| 237 | AM_RANGE(0xf800, 0xf801) AM_READWRITE(track_0_r, track_0_reset_w) /* track 0 x/y */ |
| 230 | 238 | AM_RANGE(0xf802, 0xf802) AM_READ_PORT("SYSTEM") AM_WRITE(gridiron_led0_w) |
| 231 | 239 | AM_RANGE(0xf803, 0xf803) AM_READ_PORT("P1BUT") |
| 232 | 240 | AM_RANGE(0xf806, 0xf806) AM_READ_PORT("SYSTEM") |
| 233 | | AM_RANGE(0xf810, 0xf811) AM_READWRITE(tehkanwc_track_1_r, tehkanwc_track_1_reset_w) /* track 1 x/y */ |
| 241 | AM_RANGE(0xf810, 0xf811) AM_READWRITE(track_1_r, track_1_reset_w) /* track 1 x/y */ |
| 234 | 242 | AM_RANGE(0xf812, 0xf812) AM_WRITE(gridiron_led1_w) |
| 235 | 243 | AM_RANGE(0xf813, 0xf813) AM_READ_PORT("P2BUT") |
| 236 | 244 | AM_RANGE(0xf820, 0xf820) AM_READ(soundlatch2_byte_r) AM_WRITE(sound_command_w) /* answer from the sound CPU */ |
| 237 | 245 | AM_RANGE(0xf840, 0xf840) AM_READ_PORT("DSW1") AM_WRITE(sub_cpu_halt_w) |
| 238 | 246 | AM_RANGE(0xf850, 0xf850) AM_READ_PORT("DSW2") AM_WRITENOP /* ?? writes 0x00 or 0xff */ |
| 239 | | AM_RANGE(0xf860, 0xf860) AM_READ(watchdog_reset_r) AM_WRITE(tehkanwc_flipscreen_x_w) |
| 240 | | AM_RANGE(0xf870, 0xf870) AM_READ_PORT("DSW3") AM_WRITE(tehkanwc_flipscreen_y_w) |
| 247 | AM_RANGE(0xf860, 0xf860) AM_READ(watchdog_reset_r) AM_WRITE(flipscreen_x_w) |
| 248 | AM_RANGE(0xf870, 0xf870) AM_READ_PORT("DSW3") AM_WRITE(flipscreen_y_w) |
| 241 | 249 | ADDRESS_MAP_END |
| 242 | 250 | |
| 243 | 251 | static ADDRESS_MAP_START( sub_mem, AS_PROGRAM, 8, tehkanwc_state ) |
| 244 | 252 | AM_RANGE(0x0000, 0x7fff) AM_ROM |
| 245 | 253 | AM_RANGE(0x8000, 0xc7ff) AM_RAM |
| 246 | 254 | AM_RANGE(0xc800, 0xcfff) AM_RAM AM_SHARE("share1") |
| 247 | | AM_RANGE(0xd000, 0xd3ff) AM_RAM_WRITE(tehkanwc_videoram_w) AM_SHARE("videoram") |
| 248 | | AM_RANGE(0xd400, 0xd7ff) AM_RAM_WRITE(tehkanwc_colorram_w) AM_SHARE("colorram") |
| 255 | AM_RANGE(0xd000, 0xd3ff) AM_RAM_WRITE(videoram_w) AM_SHARE("videoram") |
| 256 | AM_RANGE(0xd400, 0xd7ff) AM_RAM_WRITE(colorram_w) AM_SHARE("colorram") |
| 249 | 257 | AM_RANGE(0xd800, 0xddff) AM_RAM_DEVWRITE("palette", palette_device, write) AM_SHARE("palette") |
| 250 | 258 | AM_RANGE(0xde00, 0xdfff) AM_RAM AM_SHARE("share5") /* unused part of the palette RAM, I think? Gridiron uses it */ |
| 251 | | AM_RANGE(0xe000, 0xe7ff) AM_RAM_WRITE(tehkanwc_videoram2_w) AM_SHARE("videoram2") |
| 259 | AM_RANGE(0xe000, 0xe7ff) AM_RAM_WRITE(videoram2_w) AM_SHARE("videoram2") |
| 252 | 260 | AM_RANGE(0xe800, 0xebff) AM_RAM AM_SHARE("spriteram") /* sprites */ |
| 253 | | AM_RANGE(0xec00, 0xec01) AM_RAM_WRITE(tehkanwc_scroll_x_w) |
| 254 | | AM_RANGE(0xec02, 0xec02) AM_RAM_WRITE(tehkanwc_scroll_y_w) |
| 261 | AM_RANGE(0xec00, 0xec01) AM_RAM_WRITE(scroll_x_w) |
| 262 | AM_RANGE(0xec02, 0xec02) AM_RAM_WRITE(scroll_y_w) |
| 255 | 263 | AM_RANGE(0xf860, 0xf860) AM_READ(watchdog_reset_r) |
| 256 | 264 | ADDRESS_MAP_END |
| 257 | 265 | |
| r243683 | r243684 | |
| 638 | 646 | MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500) /* not accurate */) |
| 639 | 647 | MCFG_SCREEN_SIZE(32*8, 32*8) |
| 640 | 648 | MCFG_SCREEN_VISIBLE_AREA(0*8, 32*8-1, 2*8, 30*8-1) |
| 641 | | MCFG_SCREEN_UPDATE_DRIVER(tehkanwc_state, screen_update_tehkanwc) |
| 649 | MCFG_SCREEN_UPDATE_DRIVER(tehkanwc_state, screen_update) |
| 642 | 650 | MCFG_SCREEN_PALETTE("palette") |
| 643 | 651 | |
| 644 | 652 | MCFG_GFXDECODE_ADD("gfxdecode", "palette", tehkanwc) |
| r243683 | r243684 | |
| 650 | 658 | MCFG_SPEAKER_STANDARD_MONO("mono") |
| 651 | 659 | |
| 652 | 660 | MCFG_SOUND_ADD("ay1", AY8910, 1536000) |
| 653 | | MCFG_AY8910_PORT_A_WRITE_CB(WRITE8(tehkanwc_state, tehkanwc_portA_w)) |
| 654 | | MCFG_AY8910_PORT_B_WRITE_CB(WRITE8(tehkanwc_state, tehkanwc_portB_w)) |
| 661 | MCFG_AY8910_PORT_A_WRITE_CB(WRITE8(tehkanwc_state, portA_w)) |
| 662 | MCFG_AY8910_PORT_B_WRITE_CB(WRITE8(tehkanwc_state, portB_w)) |
| 655 | 663 | MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.25) |
| 656 | 664 | |
| 657 | 665 | MCFG_SOUND_ADD("ay2", AY8910, 1536000) |
| 658 | | MCFG_AY8910_PORT_A_READ_CB(READ8(tehkanwc_state, tehkanwc_portA_r)) |
| 659 | | MCFG_AY8910_PORT_B_READ_CB(READ8(tehkanwc_state, tehkanwc_portB_r)) |
| 666 | MCFG_AY8910_PORT_A_READ_CB(READ8(tehkanwc_state, portA_r)) |
| 667 | MCFG_AY8910_PORT_B_READ_CB(READ8(tehkanwc_state, portB_r)) |
| 660 | 668 | MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.25) |
| 661 | 669 | |
| 662 | 670 | MCFG_SOUND_ADD("msm", MSM5205, 384000) |
| 663 | | MCFG_MSM5205_VCLK_CB(WRITELINE(tehkanwc_state, tehkanwc_adpcm_int)) /* interrupt function */ |
| 671 | MCFG_MSM5205_VCLK_CB(WRITELINE(tehkanwc_state, adpcm_int)) /* interrupt function */ |
| 664 | 672 | MCFG_MSM5205_PRESCALER_SELECTOR(MSM5205_S48_4B) /* 8KHz */ |
| 665 | 673 | MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.45) |
| 666 | 674 | MACHINE_CONFIG_END |
| r243683 | r243684 | |
| 882 | 890 | |
| 883 | 891 | |
| 884 | 892 | |
| 885 | | GAME( 1985, tehkanwc, 0, tehkanwc, tehkanwc, driver_device, 0, ROT0, "Tehkan", "Tehkan World Cup (set 1)", 0 ) |
| 886 | | GAME( 1985, tehkanwcb, tehkanwc, tehkanwc, tehkanwc, driver_device, 0, ROT0, "Tehkan", "Tehkan World Cup (set 2, bootleg?)", 0 ) |
| 887 | | GAME( 1985, tehkanwcc, tehkanwc, tehkanwc, tehkanwc, driver_device, 0, ROT0, "bootleg", "Tehkan World Cup (set 3, bootleg)", GAME_NOT_WORKING ) // aka 'World Cup 85', different inputs? |
| 888 | | GAMEL(1985, gridiron, 0, tehkanwc, gridiron, driver_device, 0, ROT0, "Tehkan", "Gridiron Fight", 0, layout_gridiron ) |
| 889 | | GAME( 1986, teedoff, 0, tehkanwc, teedoff, tehkanwc_state, teedoff, ROT90, "Tecmo", "Tee'd Off (Japan)", 0 ) |
| 893 | GAME( 1985, tehkanwc, 0, tehkanwc, tehkanwc, driver_device, 0, ROT0, "Tehkan", "Tehkan World Cup (set 1)", GAME_SUPPORTS_SAVE ) |
| 894 | GAME( 1985, tehkanwcb, tehkanwc, tehkanwc, tehkanwc, driver_device, 0, ROT0, "Tehkan", "Tehkan World Cup (set 2, bootleg?)", GAME_SUPPORTS_SAVE ) |
| 895 | GAME( 1985, tehkanwcc, tehkanwc, tehkanwc, tehkanwc, driver_device, 0, ROT0, "bootleg", "Tehkan World Cup (set 3, bootleg)", GAME_NOT_WORKING | GAME_SUPPORTS_SAVE ) // aka 'World Cup 85', different inputs? |
| 896 | GAMEL(1985, gridiron, 0, tehkanwc, gridiron, driver_device, 0, ROT0, "Tehkan", "Gridiron Fight", GAME_SUPPORTS_SAVE, layout_gridiron ) |
| 897 | GAME( 1986, teedoff, 0, tehkanwc, teedoff, tehkanwc_state, teedoff, ROT90, "Tecmo", "Tee'd Off (Japan)", GAME_SUPPORTS_SAVE ) |
trunk/src/mame/includes/tecmosys.h
| r243683 | r243684 | |
| 10 | 10 | public: |
| 11 | 11 | tecmosys_state(const machine_config &mconfig, device_type type, const char *tag) |
| 12 | 12 | : driver_device(mconfig, type, tag), |
| 13 | m_maincpu(*this, "maincpu"), |
| 14 | m_audiocpu(*this, "audiocpu"), |
| 15 | m_eeprom(*this, "eeprom"), |
| 16 | m_gfxdecode(*this, "gfxdecode"), |
| 17 | m_screen(*this, "screen"), |
| 18 | m_palette(*this, "palette"), |
| 13 | 19 | m_spriteram(*this, "spriteram"), |
| 14 | 20 | m_tilemap_paletteram16(*this, "tmap_palette"), |
| 15 | 21 | m_bg2tilemap_ram(*this, "bg2tilemap_ram"), |
| r243683 | r243684 | |
| 23 | 29 | m_b00000regs(*this, "b00000regs"), |
| 24 | 30 | m_c00000regs(*this, "c00000regs"), |
| 25 | 31 | m_c80000regs(*this, "c80000regs"), |
| 26 | | m_880000regs(*this, "880000regs"), |
| 27 | | m_maincpu(*this, "maincpu"), |
| 28 | | m_audiocpu(*this, "audiocpu"), |
| 29 | | m_eeprom(*this, "eeprom"), |
| 30 | | m_gfxdecode(*this, "gfxdecode"), |
| 31 | | m_screen(*this, "screen"), |
| 32 | | m_palette(*this, "palette") { } |
| 32 | m_880000regs(*this, "880000regs") { } |
| 33 | 33 | |
| 34 | required_device<cpu_device> m_maincpu; |
| 35 | required_device<cpu_device> m_audiocpu; |
| 36 | required_device<eeprom_serial_93cxx_device> m_eeprom; |
| 37 | required_device<gfxdecode_device> m_gfxdecode; |
| 38 | required_device<screen_device> m_screen; |
| 39 | required_device<palette_device> m_palette; |
| 40 | |
| 34 | 41 | required_shared_ptr<UINT16> m_spriteram; |
| 35 | 42 | required_shared_ptr<UINT16> m_tilemap_paletteram16; |
| 36 | 43 | required_shared_ptr<UINT16> m_bg2tilemap_ram; |
| r243683 | r243684 | |
| 45 | 52 | required_shared_ptr<UINT16> m_c00000regs; |
| 46 | 53 | required_shared_ptr<UINT16> m_c80000regs; |
| 47 | 54 | required_shared_ptr<UINT16> m_880000regs; |
| 55 | |
| 48 | 56 | int m_spritelist; |
| 49 | 57 | bitmap_ind16 m_sprite_bitmap; |
| 50 | 58 | bitmap_ind16 m_tmp_tilemap_composebitmap; |
| r243683 | r243684 | |
| 57 | 65 | UINT8 m_device_status; |
| 58 | 66 | const struct prot_data* m_device_data; |
| 59 | 67 | UINT8 m_device_value; |
| 68 | |
| 60 | 69 | DECLARE_READ16_MEMBER(sound_r); |
| 61 | 70 | DECLARE_WRITE16_MEMBER(sound_w); |
| 62 | 71 | DECLARE_WRITE16_MEMBER(unk880000_w); |
| 63 | 72 | DECLARE_READ16_MEMBER(unk880000_r); |
| 64 | | DECLARE_WRITE8_MEMBER(tecmosys_z80_bank_w); |
| 65 | | DECLARE_WRITE8_MEMBER(tecmosys_oki_bank_w); |
| 66 | | DECLARE_READ16_MEMBER(tecmosys_prot_status_r); |
| 67 | | DECLARE_WRITE16_MEMBER(tecmosys_prot_status_w); |
| 68 | | DECLARE_READ16_MEMBER(tecmosys_prot_data_r); |
| 69 | | DECLARE_WRITE16_MEMBER(tecmosys_prot_data_w); |
| 73 | DECLARE_WRITE8_MEMBER(z80_bank_w); |
| 74 | DECLARE_WRITE8_MEMBER(oki_bank_w); |
| 75 | DECLARE_READ16_MEMBER(prot_status_r); |
| 76 | DECLARE_WRITE16_MEMBER(prot_status_w); |
| 77 | DECLARE_READ16_MEMBER(prot_data_r); |
| 78 | DECLARE_WRITE16_MEMBER(prot_data_w); |
| 70 | 79 | DECLARE_WRITE16_MEMBER(bg0_tilemap_w); |
| 71 | 80 | DECLARE_WRITE16_MEMBER(bg1_tilemap_w); |
| 72 | 81 | DECLARE_WRITE16_MEMBER(bg2_tilemap_w); |
| r243683 | r243684 | |
| 77 | 86 | DECLARE_WRITE16_MEMBER(bg2_tilemap_lineram_w); |
| 78 | 87 | DECLARE_READ16_MEMBER(eeprom_r); |
| 79 | 88 | DECLARE_WRITE16_MEMBER(eeprom_w); |
| 89 | DECLARE_WRITE_LINE_MEMBER(sound_irq); |
| 90 | |
| 80 | 91 | DECLARE_DRIVER_INIT(tkdensha); |
| 81 | 92 | DECLARE_DRIVER_INIT(deroon); |
| 82 | 93 | DECLARE_DRIVER_INIT(tkdensho); |
| 94 | virtual void machine_start(); |
| 95 | virtual void video_start(); |
| 96 | |
| 83 | 97 | TILE_GET_INFO_MEMBER(get_bg0tile_info); |
| 84 | 98 | TILE_GET_INFO_MEMBER(get_bg1tile_info); |
| 85 | 99 | TILE_GET_INFO_MEMBER(get_bg2tile_info); |
| 86 | 100 | TILE_GET_INFO_MEMBER(get_fg_tile_info); |
| 87 | | virtual void machine_start(); |
| 88 | | virtual void video_start(); |
| 89 | | UINT32 screen_update_tecmosys(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect); |
| 90 | | void tecmosys_prot_init(int which); |
| 91 | | void tecmosys_prot_reset(); |
| 92 | | inline void set_color_555_tecmo(pen_t color, int rshift, int gshift, int bshift, UINT16 data); |
| 93 | | void tecmosys_render_sprites_to_bitmap(bitmap_rgb32 &bitmap, UINT16 extrax, UINT16 extray ); |
| 94 | | void tecmosys_tilemap_copy_to_compose(UINT16 pri); |
| 95 | | void tecmosys_do_final_mix(bitmap_rgb32 &bitmap); |
| 96 | | void tecmosys_descramble(); |
| 97 | | DECLARE_WRITE_LINE_MEMBER(sound_irq); |
| 98 | | required_device<cpu_device> m_maincpu; |
| 99 | | required_device<cpu_device> m_audiocpu; |
| 100 | | required_device<eeprom_serial_93cxx_device> m_eeprom; |
| 101 | | required_device<gfxdecode_device> m_gfxdecode; |
| 102 | | required_device<screen_device> m_screen; |
| 103 | | required_device<palette_device> m_palette; |
| 101 | |
| 102 | UINT32 screen_update(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect); |
| 103 | void prot_init(int which); |
| 104 | void prot_reset(); |
| 105 | inline void set_color_555(pen_t color, int rshift, int gshift, int bshift, UINT16 data); |
| 106 | void render_sprites_to_bitmap(bitmap_rgb32 &bitmap, UINT16 extrax, UINT16 extray ); |
| 107 | void tilemap_copy_to_compose(UINT16 pri); |
| 108 | void do_final_mix(bitmap_rgb32 &bitmap); |
| 109 | void descramble(); |
| 104 | 110 | }; |
trunk/src/mame/includes/tehkanwc.h
| r243683 | r243684 | |
| 10 | 10 | |
| 11 | 11 | tehkanwc_state(const machine_config &mconfig, device_type type, const char *tag) |
| 12 | 12 | : driver_device(mconfig, type, tag), |
| 13 | | m_videoram(*this, "videoram"), |
| 14 | | m_colorram(*this, "colorram"), |
| 15 | | m_videoram2(*this, "videoram2"), |
| 16 | | m_spriteram(*this, "spriteram"), |
| 17 | 13 | m_maincpu(*this, "maincpu"), |
| 18 | 14 | m_audiocpu(*this, "audiocpu"), |
| 19 | 15 | m_subcpu(*this, "sub"), |
| 20 | 16 | m_msm(*this, "msm"), |
| 21 | 17 | m_gfxdecode(*this, "gfxdecode"), |
| 22 | | m_palette(*this, "palette") { } |
| 18 | m_palette(*this, "palette"), |
| 19 | m_videoram(*this, "videoram"), |
| 20 | m_colorram(*this, "colorram"), |
| 21 | m_videoram2(*this, "videoram2"), |
| 22 | m_spriteram(*this, "spriteram") { } |
| 23 | 23 | |
| 24 | required_device<cpu_device> m_maincpu; |
| 25 | required_device<cpu_device> m_audiocpu; |
| 26 | required_device<cpu_device> m_subcpu; |
| 27 | required_device<msm5205_device> m_msm; |
| 28 | required_device<gfxdecode_device> m_gfxdecode; |
| 29 | required_device<palette_device> m_palette; |
| 30 | |
| 31 | required_shared_ptr<UINT8> m_videoram; |
| 32 | required_shared_ptr<UINT8> m_colorram; |
| 33 | required_shared_ptr<UINT8> m_videoram2; |
| 34 | required_shared_ptr<UINT8> m_spriteram; |
| 35 | |
| 24 | 36 | int m_track0[2]; |
| 25 | 37 | int m_track1[2]; |
| 26 | 38 | int m_msm_data_offs; |
| 27 | 39 | int m_toggle; |
| 28 | | required_shared_ptr<UINT8> m_videoram; |
| 29 | | required_shared_ptr<UINT8> m_colorram; |
| 30 | | required_shared_ptr<UINT8> m_videoram2; |
| 31 | 40 | UINT8 m_scroll_x[2]; |
| 32 | 41 | UINT8 m_led0; |
| 33 | 42 | UINT8 m_led1; |
| 34 | 43 | tilemap_t *m_bg_tilemap; |
| 35 | 44 | tilemap_t *m_fg_tilemap; |
| 36 | | required_shared_ptr<UINT8> m_spriteram; |
| 45 | |
| 37 | 46 | DECLARE_WRITE8_MEMBER(sub_cpu_halt_w); |
| 38 | | DECLARE_READ8_MEMBER(tehkanwc_track_0_r); |
| 39 | | DECLARE_READ8_MEMBER(tehkanwc_track_1_r); |
| 40 | | DECLARE_WRITE8_MEMBER(tehkanwc_track_0_reset_w); |
| 41 | | DECLARE_WRITE8_MEMBER(tehkanwc_track_1_reset_w); |
| 47 | DECLARE_READ8_MEMBER(track_0_r); |
| 48 | DECLARE_READ8_MEMBER(track_1_r); |
| 49 | DECLARE_WRITE8_MEMBER(track_0_reset_w); |
| 50 | DECLARE_WRITE8_MEMBER(track_1_reset_w); |
| 42 | 51 | DECLARE_WRITE8_MEMBER(sound_command_w); |
| 43 | 52 | DECLARE_WRITE8_MEMBER(sound_answer_w); |
| 44 | | DECLARE_WRITE8_MEMBER(tehkanwc_videoram_w); |
| 45 | | DECLARE_WRITE8_MEMBER(tehkanwc_colorram_w); |
| 46 | | DECLARE_WRITE8_MEMBER(tehkanwc_videoram2_w); |
| 47 | | DECLARE_WRITE8_MEMBER(tehkanwc_scroll_x_w); |
| 48 | | DECLARE_WRITE8_MEMBER(tehkanwc_scroll_y_w); |
| 49 | | DECLARE_WRITE8_MEMBER(tehkanwc_flipscreen_x_w); |
| 50 | | DECLARE_WRITE8_MEMBER(tehkanwc_flipscreen_y_w); |
| 53 | DECLARE_WRITE8_MEMBER(videoram_w); |
| 54 | DECLARE_WRITE8_MEMBER(colorram_w); |
| 55 | DECLARE_WRITE8_MEMBER(videoram2_w); |
| 56 | DECLARE_WRITE8_MEMBER(scroll_x_w); |
| 57 | DECLARE_WRITE8_MEMBER(scroll_y_w); |
| 58 | DECLARE_WRITE8_MEMBER(flipscreen_x_w); |
| 59 | DECLARE_WRITE8_MEMBER(flipscreen_y_w); |
| 51 | 60 | DECLARE_WRITE8_MEMBER(gridiron_led0_w); |
| 52 | 61 | DECLARE_WRITE8_MEMBER(gridiron_led1_w); |
| 53 | | DECLARE_READ8_MEMBER(tehkanwc_portA_r); |
| 54 | | DECLARE_READ8_MEMBER(tehkanwc_portB_r); |
| 55 | | DECLARE_WRITE8_MEMBER(tehkanwc_portA_w); |
| 56 | | DECLARE_WRITE8_MEMBER(tehkanwc_portB_w); |
| 62 | DECLARE_READ8_MEMBER(portA_r); |
| 63 | DECLARE_READ8_MEMBER(portB_r); |
| 64 | DECLARE_WRITE8_MEMBER(portA_w); |
| 65 | DECLARE_WRITE8_MEMBER(portB_w); |
| 57 | 66 | DECLARE_WRITE8_MEMBER(msm_reset_w); |
| 58 | | DECLARE_DRIVER_INIT(teedoff); |
| 67 | DECLARE_WRITE_LINE_MEMBER(adpcm_int); |
| 68 | |
| 59 | 69 | TILE_GET_INFO_MEMBER(get_bg_tile_info); |
| 60 | 70 | TILE_GET_INFO_MEMBER(get_fg_tile_info); |
| 71 | |
| 72 | DECLARE_DRIVER_INIT(teedoff); |
| 73 | virtual void machine_start(); |
| 61 | 74 | virtual void video_start(); |
| 62 | | UINT32 screen_update_tehkanwc(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 63 | | void gridiron_draw_led(bitmap_ind16 &bitmap, const rectangle &cliprect, UINT8 led,int player); |
| 75 | |
| 76 | UINT32 screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 77 | void draw_led(bitmap_ind16 &bitmap, const rectangle &cliprect, UINT8 led,int player); |
| 64 | 78 | void draw_sprites(bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 65 | | DECLARE_WRITE_LINE_MEMBER(tehkanwc_adpcm_int); |
| 66 | | required_device<cpu_device> m_maincpu; |
| 67 | | required_device<cpu_device> m_audiocpu; |
| 68 | | required_device<cpu_device> m_subcpu; |
| 69 | | required_device<msm5205_device> m_msm; |
| 70 | | required_device<gfxdecode_device> m_gfxdecode; |
| 71 | | required_device<palette_device> m_palette; |
| 79 | |
| 72 | 80 | protected: |
| 73 | 81 | virtual void device_timer(emu_timer &timer, device_timer_id id, int param, void *ptr); |
| 74 | 82 | }; |
trunk/src/mame/video/tecmosys.c
| r243683 | r243684 | |
| 66 | 66 | } |
| 67 | 67 | |
| 68 | 68 | |
| 69 | | inline void tecmosys_state::set_color_555_tecmo(pen_t color, int rshift, int gshift, int bshift, UINT16 data) |
| 69 | inline void tecmosys_state::set_color_555(pen_t color, int rshift, int gshift, int bshift, UINT16 data) |
| 70 | 70 | { |
| 71 | 71 | m_palette->set_pen_color(color, pal5bit(data >> rshift), pal5bit(data >> gshift), pal5bit(data >> bshift)); |
| 72 | 72 | } |
| r243683 | r243684 | |
| 74 | 74 | WRITE16_MEMBER(tecmosys_state::tilemap_paletteram16_xGGGGGRRRRRBBBBB_word_w) |
| 75 | 75 | { |
| 76 | 76 | COMBINE_DATA(&m_tilemap_paletteram16[offset]); |
| 77 | | set_color_555_tecmo(offset+0x4000, 5, 10, 0, m_tilemap_paletteram16[offset]); |
| 77 | set_color_555(offset+0x4000, 5, 10, 0, m_tilemap_paletteram16[offset]); |
| 78 | 78 | } |
| 79 | 79 | |
| 80 | 80 | WRITE16_MEMBER(tecmosys_state::bg0_tilemap_lineram_w) |
| r243683 | r243684 | |
| 97 | 97 | |
| 98 | 98 | |
| 99 | 99 | |
| 100 | | void tecmosys_state::tecmosys_render_sprites_to_bitmap(bitmap_rgb32 &bitmap, UINT16 extrax, UINT16 extray ) |
| 100 | void tecmosys_state::render_sprites_to_bitmap(bitmap_rgb32 &bitmap, UINT16 extrax, UINT16 extray ) |
| 101 | 101 | { |
| 102 | 102 | UINT8 *gfxsrc = memregion ( "gfx1" )->base(); |
| 103 | 103 | int i; |
| r243683 | r243684 | |
| 188 | 188 | } |
| 189 | 189 | } |
| 190 | 190 | |
| 191 | | void tecmosys_state::tecmosys_tilemap_copy_to_compose(UINT16 pri) |
| 191 | void tecmosys_state::tilemap_copy_to_compose(UINT16 pri) |
| 192 | 192 | { |
| 193 | 193 | int y,x; |
| 194 | 194 | UINT16 *srcptr; |
| r243683 | r243684 | |
| 205 | 205 | } |
| 206 | 206 | } |
| 207 | 207 | |
| 208 | | void tecmosys_state::tecmosys_do_final_mix(bitmap_rgb32 &bitmap) |
| 208 | void tecmosys_state::do_final_mix(bitmap_rgb32 &bitmap) |
| 209 | 209 | { |
| 210 | 210 | const pen_t *paldata = m_palette->pens(); |
| 211 | 211 | int y,x; |
| r243683 | r243684 | |
| 275 | 275 | } |
| 276 | 276 | |
| 277 | 277 | |
| 278 | | UINT32 tecmosys_state::screen_update_tecmosys(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect) |
| 278 | UINT32 tecmosys_state::screen_update(screen_device &screen, bitmap_rgb32 &bitmap, const rectangle &cliprect) |
| 279 | 279 | { |
| 280 | 280 | bitmap.fill(m_palette->pen(0x4000), cliprect); |
| 281 | 281 | |
| r243683 | r243684 | |
| 293 | 293 | |
| 294 | 294 | m_tmp_tilemap_renderbitmap.fill(0, cliprect); |
| 295 | 295 | m_bg0tilemap->draw(screen, m_tmp_tilemap_renderbitmap, cliprect, 0,0); |
| 296 | | tecmosys_tilemap_copy_to_compose(0x0000); |
| 296 | tilemap_copy_to_compose(0x0000); |
| 297 | 297 | |
| 298 | 298 | m_tmp_tilemap_renderbitmap.fill(0, cliprect); |
| 299 | 299 | m_bg1tilemap->draw(screen, m_tmp_tilemap_renderbitmap, cliprect, 0,0); |
| 300 | | tecmosys_tilemap_copy_to_compose(0x4000); |
| 300 | tilemap_copy_to_compose(0x4000); |
| 301 | 301 | |
| 302 | 302 | m_tmp_tilemap_renderbitmap.fill(0, cliprect); |
| 303 | 303 | m_bg2tilemap->draw(screen, m_tmp_tilemap_renderbitmap, cliprect, 0,0); |
| 304 | | tecmosys_tilemap_copy_to_compose(0x8000); |
| 304 | tilemap_copy_to_compose(0x8000); |
| 305 | 305 | |
| 306 | 306 | m_tmp_tilemap_renderbitmap.fill(0, cliprect); |
| 307 | 307 | m_txt_tilemap->draw(screen, m_tmp_tilemap_renderbitmap, cliprect, 0,0); |
| 308 | | tecmosys_tilemap_copy_to_compose(0xc000); |
| 308 | tilemap_copy_to_compose(0xc000); |
| 309 | 309 | |
| 310 | 310 | |
| 311 | | tecmosys_do_final_mix(bitmap); |
| 311 | do_final_mix(bitmap); |
| 312 | 312 | |
| 313 | 313 | // prepare sprites for NEXT frame - causes 1 frame palette errors, but prevents sprite lag in tkdensho, which is correct? |
| 314 | | tecmosys_render_sprites_to_bitmap(bitmap, m_880000regs[0x0], m_880000regs[0x1]); |
| 314 | render_sprites_to_bitmap(bitmap, m_880000regs[0x0], m_880000regs[0x1]); |
| 315 | 315 | |
| 316 | 316 | return 0; |
| 317 | 317 | } |
| r243683 | r243684 | |
| 339 | 339 | |
| 340 | 340 | m_bg2tilemap = &machine().tilemap().create(m_gfxdecode, tilemap_get_info_delegate(FUNC(tecmosys_state::get_bg2tile_info),this),TILEMAP_SCAN_ROWS,16,16,32,32); |
| 341 | 341 | m_bg2tilemap->set_transparent_pen(0); |
| 342 | |
| 343 | save_item(NAME(m_spritelist)); |
| 342 | 344 | } |
trunk/src/mame/video/tehkanwc.c
| r243683 | r243684 | |
| 15 | 15 | #include "includes/tehkanwc.h" |
| 16 | 16 | |
| 17 | 17 | |
| 18 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_videoram_w) |
| 18 | WRITE8_MEMBER(tehkanwc_state::videoram_w) |
| 19 | 19 | { |
| 20 | 20 | m_videoram[offset] = data; |
| 21 | 21 | m_fg_tilemap->mark_tile_dirty(offset); |
| 22 | 22 | } |
| 23 | 23 | |
| 24 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_colorram_w) |
| 24 | WRITE8_MEMBER(tehkanwc_state::colorram_w) |
| 25 | 25 | { |
| 26 | 26 | m_colorram[offset] = data; |
| 27 | 27 | m_fg_tilemap->mark_tile_dirty(offset); |
| 28 | 28 | } |
| 29 | 29 | |
| 30 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_videoram2_w) |
| 30 | WRITE8_MEMBER(tehkanwc_state::videoram2_w) |
| 31 | 31 | { |
| 32 | 32 | m_videoram2[offset] = data; |
| 33 | 33 | m_bg_tilemap->mark_tile_dirty(offset / 2); |
| 34 | 34 | } |
| 35 | 35 | |
| 36 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_scroll_x_w) |
| 36 | WRITE8_MEMBER(tehkanwc_state::scroll_x_w) |
| 37 | 37 | { |
| 38 | 38 | m_scroll_x[offset] = data; |
| 39 | 39 | } |
| 40 | 40 | |
| 41 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_scroll_y_w) |
| 41 | WRITE8_MEMBER(tehkanwc_state::scroll_y_w) |
| 42 | 42 | { |
| 43 | 43 | m_bg_tilemap->set_scrolly(0, data); |
| 44 | 44 | } |
| 45 | 45 | |
| 46 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_flipscreen_x_w) |
| 46 | WRITE8_MEMBER(tehkanwc_state::flipscreen_x_w) |
| 47 | 47 | { |
| 48 | 48 | flip_screen_x_set(data & 0x40); |
| 49 | 49 | } |
| 50 | 50 | |
| 51 | | WRITE8_MEMBER(tehkanwc_state::tehkanwc_flipscreen_y_w) |
| 51 | WRITE8_MEMBER(tehkanwc_state::flipscreen_y_w) |
| 52 | 52 | { |
| 53 | 53 | flip_screen_y_set(data & 0x40); |
| 54 | 54 | } |
| r243683 | r243684 | |
| 94 | 94 | 8, 8, 32, 32); |
| 95 | 95 | |
| 96 | 96 | m_fg_tilemap->set_transparent_pen(0); |
| 97 | |
| 98 | save_item(NAME(m_scroll_x)); |
| 99 | save_item(NAME(m_led0)); |
| 100 | save_item(NAME(m_led1)); |
| 97 | 101 | } |
| 98 | 102 | |
| 99 | 103 | /* |
| r243683 | r243684 | |
| 113 | 117 | bit 7 = enable (0 = display off) |
| 114 | 118 | */ |
| 115 | 119 | |
| 116 | | void tehkanwc_state::gridiron_draw_led(bitmap_ind16 &bitmap, const rectangle &cliprect, UINT8 led,int player) |
| 120 | void tehkanwc_state::draw_led(bitmap_ind16 &bitmap, const rectangle &cliprect, UINT8 led,int player) |
| 117 | 121 | { |
| 118 | 122 | if (led&0x80) |
| 119 | 123 | output_set_digit_value(player, led&0x7f); |
| r243683 | r243684 | |
| 123 | 127 | |
| 124 | 128 | void tehkanwc_state::draw_sprites(bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 125 | 129 | { |
| 126 | | UINT8 *spriteram = m_spriteram; |
| 127 | | int offs; |
| 128 | | |
| 129 | | for (offs = 0;offs < m_spriteram.bytes();offs += 4) |
| 130 | for (int offs = 0;offs < m_spriteram.bytes();offs += 4) |
| 130 | 131 | { |
| 131 | | int attr = spriteram[offs + 1]; |
| 132 | | int code = spriteram[offs] + ((attr & 0x08) << 5); |
| 132 | int attr = m_spriteram[offs + 1]; |
| 133 | int code = m_spriteram[offs] + ((attr & 0x08) << 5); |
| 133 | 134 | int color = attr & 0x07; |
| 134 | 135 | int flipx = attr & 0x40; |
| 135 | 136 | int flipy = attr & 0x80; |
| 136 | | int sx = spriteram[offs + 2] + ((attr & 0x20) << 3) - 128; |
| 137 | | int sy = spriteram[offs + 3]; |
| 137 | int sx = m_spriteram[offs + 2] + ((attr & 0x20) << 3) - 128; |
| 138 | int sy = m_spriteram[offs + 3]; |
| 138 | 139 | |
| 139 | 140 | if (flip_screen_x()) |
| 140 | 141 | { |
| r243683 | r243684 | |
| 153 | 154 | } |
| 154 | 155 | } |
| 155 | 156 | |
| 156 | | UINT32 tehkanwc_state::screen_update_tehkanwc(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 157 | UINT32 tehkanwc_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 157 | 158 | { |
| 158 | 159 | m_bg_tilemap->set_scrollx(0, m_scroll_x[0] + 256 * m_scroll_x[1]); |
| 159 | 160 | m_bg_tilemap->draw(screen, bitmap, cliprect, 0, 0); |
| 160 | 161 | m_fg_tilemap->draw(screen, bitmap, cliprect, 0, 0); |
| 161 | 162 | draw_sprites(bitmap, cliprect); |
| 162 | 163 | m_fg_tilemap->draw(screen, bitmap, cliprect, 1, 0); |
| 163 | | gridiron_draw_led(bitmap, cliprect, m_led0, 0); |
| 164 | | gridiron_draw_led(bitmap, cliprect, m_led1, 1); |
| 164 | draw_led(bitmap, cliprect, m_led0, 0); |
| 165 | draw_led(bitmap, cliprect, m_led1, 1); |
| 165 | 166 | return 0; |
| 166 | 167 | } |