trunk/src/mame/drivers/cultures.c
| r242153 | r242154 | |
| 20 | 20 | public: |
| 21 | 21 | cultures_state(const machine_config &mconfig, device_type type, const char *tag) |
| 22 | 22 | : driver_device(mconfig, type, tag), |
| 23 | m_maincpu(*this, "maincpu"), |
| 24 | m_gfxdecode(*this, "gfxdecode"), |
| 25 | m_vrambank(*this, "vrambank"), |
| 26 | m_prgbank(*this, "prgbank"), |
| 27 | m_okibank(*this, "okibank"), |
| 28 | m_bg1_rom(*this, "bg1"), |
| 29 | m_bg2_rom(*this, "bg2"), |
| 23 | 30 | m_bg0_videoram(*this, "bg0_videoram"), |
| 24 | 31 | m_bg0_regs_x(*this, "bg0_regs_x"), |
| 25 | 32 | m_bg0_regs_y(*this, "bg0_regs_y"), |
| 26 | 33 | m_bg1_regs_x(*this, "bg1_regs_x"), |
| 27 | 34 | m_bg1_regs_y(*this, "bg1_regs_y"), |
| 28 | 35 | m_bg2_regs_x(*this, "bg2_regs_x"), |
| 29 | | m_bg2_regs_y(*this, "bg2_regs_y"), |
| 30 | | m_maincpu(*this, "maincpu"), |
| 31 | | m_gfxdecode(*this, "gfxdecode"), |
| 32 | | m_palette(*this, "palette"), |
| 33 | | m_vrambank(*this, "vrambank") |
| 36 | m_bg2_regs_y(*this, "bg2_regs_y") |
| 34 | 37 | { } |
| 35 | 38 | |
| 39 | /* devices */ |
| 40 | required_device<cpu_device> m_maincpu; |
| 41 | required_device<gfxdecode_device> m_gfxdecode; |
| 42 | required_device<address_map_bank_device> m_vrambank; |
| 43 | required_memory_bank m_prgbank; |
| 44 | required_memory_bank m_okibank; |
| 45 | |
| 36 | 46 | /* memory pointers */ |
| 47 | required_region_ptr<UINT16> m_bg1_rom; |
| 48 | required_region_ptr<UINT16> m_bg2_rom; |
| 49 | |
| 37 | 50 | required_shared_ptr<UINT8> m_bg0_videoram; |
| 38 | 51 | required_shared_ptr<UINT8> m_bg0_regs_x; |
| 39 | 52 | required_shared_ptr<UINT8> m_bg0_regs_y; |
| r242153 | r242154 | |
| 61 | 74 | virtual void video_start(); |
| 62 | 75 | UINT32 screen_update_cultures(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 63 | 76 | INTERRUPT_GEN_MEMBER(cultures_interrupt); |
| 64 | | required_device<cpu_device> m_maincpu; |
| 65 | | required_device<gfxdecode_device> m_gfxdecode; |
| 66 | | required_device<palette_device> m_palette; |
| 67 | | required_device<address_map_bank_device> m_vrambank; |
| 68 | 77 | }; |
| 69 | 78 | |
| 70 | 79 | |
| 71 | 80 | |
| 72 | 81 | TILE_GET_INFO_MEMBER(cultures_state::get_bg1_tile_info) |
| 73 | 82 | { |
| 74 | | UINT8 *region = memregion("gfx3")->base() + 0x200000 + 0x80000 * m_bg1_bank; |
| 75 | | int code = region[tile_index * 2] + (region[tile_index * 2 + 1] << 8); |
| 76 | | SET_TILE_INFO_MEMBER(2, code, code >> 12, 0); |
| 83 | int const code = m_bg1_rom[0x200000/2 + m_bg1_bank * 0x80000/2 + tile_index]; |
| 84 | SET_TILE_INFO_MEMBER(1, code, code >> 12, 0); |
| 77 | 85 | } |
| 78 | 86 | |
| 79 | 87 | TILE_GET_INFO_MEMBER(cultures_state::get_bg2_tile_info) |
| 80 | 88 | { |
| 81 | | UINT8 *region = memregion("gfx2")->base() + 0x200000 + 0x80000 * m_bg2_bank; |
| 82 | | int code = region[tile_index * 2] + (region[tile_index * 2 + 1] << 8); |
| 83 | | SET_TILE_INFO_MEMBER(1, code, code >> 12, 0); |
| 89 | int const code = m_bg2_rom[0x200000/2 + m_bg2_bank * 0x80000/2 + tile_index]; |
| 90 | SET_TILE_INFO_MEMBER(2, code, code >> 12, 0); |
| 84 | 91 | } |
| 85 | 92 | |
| 86 | 93 | TILE_GET_INFO_MEMBER(cultures_state::get_bg0_tile_info) |
| 87 | 94 | { |
| 88 | | int code = m_bg0_videoram[tile_index * 2] + (m_bg0_videoram[tile_index * 2 + 1] << 8); |
| 95 | int const code = m_bg0_videoram[tile_index * 2] + (m_bg0_videoram[tile_index * 2 + 1] << 8); |
| 89 | 96 | SET_TILE_INFO_MEMBER(0, code, code >> 12, 0); |
| 90 | 97 | } |
| 91 | 98 | |
| r242153 | r242154 | |
| 98 | 105 | m_bg1_tilemap->set_transparent_pen(0); |
| 99 | 106 | m_bg0_tilemap->set_transparent_pen(0); |
| 100 | 107 | |
| 101 | | m_bg0_tilemap->set_scrolldx(502, 10); |
| 102 | | m_bg1_tilemap->set_scrolldx(502, 10); |
| 103 | | m_bg2_tilemap->set_scrolldx(502, 10); |
| 108 | m_bg0_tilemap->set_scrolldx(502, -118); |
| 109 | m_bg1_tilemap->set_scrolldx(502, -118); |
| 110 | m_bg2_tilemap->set_scrolldx(502, -118); |
| 104 | 111 | |
| 105 | | m_bg0_tilemap->set_scrolldy(255, 0); |
| 106 | | m_bg1_tilemap->set_scrolldy(255, 0); |
| 107 | | m_bg2_tilemap->set_scrolldy(255, 0); |
| 112 | m_bg0_tilemap->set_scrolldy(255, -16); |
| 113 | m_bg1_tilemap->set_scrolldy(255, -16); |
| 114 | m_bg2_tilemap->set_scrolldy(255, -16); |
| 108 | 115 | } |
| 109 | 116 | |
| 110 | 117 | UINT32 cultures_state::screen_update_cultures(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| r242153 | r242154 | |
| 138 | 145 | |
| 139 | 146 | WRITE8_MEMBER(cultures_state::cpu_bankswitch_w) |
| 140 | 147 | { |
| 141 | | membank("bank1")->set_entry(data & 0x0f); |
| 148 | m_prgbank->set_entry(data & 0x0f); |
| 142 | 149 | m_vrambank->set_bank((data & 0x20)>>5); |
| 143 | 150 | } |
| 144 | 151 | |
| r242153 | r242154 | |
| 151 | 158 | |
| 152 | 159 | WRITE8_MEMBER(cultures_state::misc_w) |
| 153 | 160 | { |
| 154 | | membank("okibank")->set_entry(data&0x0f); |
| 161 | m_okibank->set_entry(data&0x0f); |
| 155 | 162 | m_irq_enable = data & 0x80; |
| 156 | 163 | } |
| 157 | 164 | |
| r242153 | r242154 | |
| 184 | 191 | |
| 185 | 192 | static ADDRESS_MAP_START( cultures_map, AS_PROGRAM, 8, cultures_state ) |
| 186 | 193 | AM_RANGE(0x0000, 0x3fff) AM_ROM |
| 187 | | AM_RANGE(0x4000, 0x7fff) AM_ROMBANK("bank1") |
| 194 | AM_RANGE(0x4000, 0x7fff) AM_ROMBANK("prgbank") |
| 188 | 195 | AM_RANGE(0x8000, 0xbfff) AM_DEVICE("vrambank", address_map_bank_device, amap8) |
| 189 | 196 | AM_RANGE(0xc000, 0xdfff) AM_RAM |
| 190 | 197 | AM_RANGE(0xf000, 0xffff) AM_RAM |
| r242153 | r242154 | |
| 350 | 357 | }; |
| 351 | 358 | |
| 352 | 359 | static GFXDECODE_START( culture ) |
| 353 | | GFXDECODE_ENTRY("gfx1", 0, gfxlayout, 0x0000, 0x10 ) |
| 354 | | GFXDECODE_ENTRY("gfx2", 0, gfxlayout, 0x1000, 0x10 ) |
| 355 | | GFXDECODE_ENTRY("gfx3", 0, gfxlayout, 0x1000, 0x10 ) |
| 360 | GFXDECODE_ENTRY("bg0", 0, gfxlayout, 0x0000, 16 ) |
| 361 | GFXDECODE_ENTRY("bg1", 0, gfxlayout, 0x1000, 8 ) |
| 362 | GFXDECODE_ENTRY("bg2", 0, gfxlayout, 0x1000, 8 ) |
| 356 | 363 | GFXDECODE_END |
| 357 | 364 | |
| 358 | 365 | INTERRUPT_GEN_MEMBER(cultures_state::cultures_interrupt) |
| r242153 | r242154 | |
| 363 | 370 | |
| 364 | 371 | void cultures_state::machine_start() |
| 365 | 372 | { |
| 366 | | UINT8 *ROM = memregion("maincpu")->base(); |
| 373 | m_prgbank->configure_entries(0, 16, memregion("maincpu")->base(), 0x4000); |
| 374 | m_okibank->configure_entries(0, 0x200000 / 0x20000, memregion("oki")->base(), 0x20000); |
| 375 | m_okibank->set_entry(0); |
| 367 | 376 | |
| 368 | | membank("bank1")->configure_entries(0, 16, &ROM[0x0000], 0x4000); |
| 369 | | membank("okibank")->configure_entries(0, 0x200000 / 0x20000, memregion("oki")->base(), 0x20000); |
| 370 | | membank("okibank")->set_entry(0); |
| 371 | | |
| 372 | 377 | save_item(NAME(m_irq_enable)); |
| 373 | 378 | save_item(NAME(m_bg1_bank)); |
| 374 | 379 | save_item(NAME(m_bg2_bank)); |
| r242153 | r242154 | |
| 376 | 381 | |
| 377 | 382 | void cultures_state::machine_reset() |
| 378 | 383 | { |
| 379 | | membank("okibank")->set_entry(0); |
| 384 | m_okibank->set_entry(0); |
| 380 | 385 | m_vrambank->set_bank(1); |
| 381 | 386 | m_irq_enable = 0; |
| 382 | 387 | m_bg1_bank = 0; |
| r242153 | r242154 | |
| 413 | 418 | MCFG_GFXDECODE_ADD("gfxdecode", "palette", culture) |
| 414 | 419 | MCFG_PALETTE_ADD("palette", 0x3000/2) |
| 415 | 420 | MCFG_PALETTE_FORMAT(xRGBRRRRGGGGBBBB_bit0) |
| 416 | | MCFG_PALETTE_ENDIANNESS(ENDIANNESS_LITTLE) |
| 417 | 421 | |
| 418 | 422 | /* sound hardware */ |
| 419 | 423 | MCFG_SPEAKER_STANDARD_MONO("mono") |
| r242153 | r242154 | |
| 468 | 472 | ROM_REGION( 0x40000, "maincpu", 0 ) |
| 469 | 473 | ROM_LOAD( "ma01.u12", 0x000000, 0x040000, CRC(f57417b3) SHA1(9a2a50222f54e5da9bc5c66863b8be16e33b171f) ) |
| 470 | 474 | |
| 471 | | ROM_REGION( 0x300000, "gfx1", 0 ) |
| 475 | ROM_REGION( 0x400000, "bg0", ROMREGION_ERASE00 ) |
| 472 | 476 | ROM_LOAD( "bg0c.u45", 0x000000, 0x200000, CRC(ad2e1263) SHA1(b28a3d82aaa0421a7b4df837814147b109e7d1a5) ) |
| 473 | 477 | ROM_LOAD( "bg0c2.u46", 0x200000, 0x100000, CRC(97c71c09) SHA1(ffbcee1d9cb39d0824f3aa652c3a24579113cf2e) ) |
| 474 | | |
| 475 | | ROM_REGION( 0x400000, "gfx2", ROMREGION_ERASE00 ) |
| 476 | | ROM_LOAD( "bg1c.u80", 0x000000, 0x200000, CRC(9ab99bd9) SHA1(bce41b6f5d83c8262ba8d37b2dfcd5d7a5e7ace7) ) |
| 477 | | ROM_LOAD( "bg2t.u79", 0x200000, 0x100000, CRC(0610a79f) SHA1(9fc6b2e5c573ed682b2f7fa462c8f42ff99da5ba) ) |
| 478 | 478 | /* 0x300000 - 0x3fffff empty */ |
| 479 | 479 | |
| 480 | | ROM_REGION( 0x400000, "gfx3", ROMREGION_ERASE00 ) |
| 480 | ROM_REGION16_LE( 0x400000, "bg1", ROMREGION_ERASE00 ) |
| 481 | 481 | ROM_LOAD( "bg2c.u68", 0x000000, 0x200000, CRC(fa598644) SHA1(532249e456c34f18a787d5a028df82f2170f604d) ) |
| 482 | 482 | ROM_LOAD( "bg1t.u67", 0x200000, 0x100000, CRC(d2e594ee) SHA1(a84b5ab62dec1867d433ccaeb1381e7593958cf0) ) |
| 483 | 483 | /* 0x300000 - 0x3fffff empty */ |
| 484 | 484 | |
| 485 | ROM_REGION16_LE( 0x400000, "bg2", ROMREGION_ERASE00 ) |
| 486 | ROM_LOAD( "bg1c.u80", 0x000000, 0x200000, CRC(9ab99bd9) SHA1(bce41b6f5d83c8262ba8d37b2dfcd5d7a5e7ace7) ) |
| 487 | ROM_LOAD( "bg2t.u79", 0x200000, 0x100000, CRC(0610a79f) SHA1(9fc6b2e5c573ed682b2f7fa462c8f42ff99da5ba) ) |
| 488 | /* 0x300000 - 0x3fffff empty */ |
| 489 | |
| 485 | 490 | ROM_REGION( 0x200000, "oki", 0 ) |
| 486 | 491 | ROM_LOAD( "pcm.u87", 0x000000, 0x200000, CRC(84206475) SHA1(d1423bd5c7425e121fb4e7845cf57801e9afa7b3) ) |
| 487 | 492 | ROM_END |