trunk/src/mame/drivers/mjsister.c
| r31855 | r31856 | |
| 25 | 25 | mjsister_state(const machine_config &mconfig, device_type type, const char *tag) |
| 26 | 26 | : driver_device(mconfig, type, tag), |
| 27 | 27 | m_maincpu(*this, "maincpu"), |
| 28 | | m_palette(*this, "palette") { } |
| 28 | m_palette(*this, "palette"), |
| 29 | m_dac(*this, "dac") { } |
| 29 | 30 | |
| 30 | 31 | /* video-related */ |
| 31 | 32 | bitmap_ind16 *m_tmpbitmap0; |
| r31855 | r31856 | |
| 52 | 53 | /* devices */ |
| 53 | 54 | required_device<cpu_device> m_maincpu; |
| 54 | 55 | required_device<palette_device> m_palette; |
| 55 | | dac_device *m_dac; |
| 56 | required_device<dac_device> m_dac; |
| 56 | 57 | |
| 57 | 58 | /* memory */ |
| 58 | 59 | UINT8 m_videoram0[0x8000]; |
| 59 | 60 | UINT8 m_videoram1[0x8000]; |
| 60 | | DECLARE_WRITE8_MEMBER(mjsister_videoram_w); |
| 61 | | DECLARE_WRITE8_MEMBER(mjsister_dac_adr_s_w); |
| 62 | | DECLARE_WRITE8_MEMBER(mjsister_dac_adr_e_w); |
| 63 | | DECLARE_WRITE8_MEMBER(mjsister_banksel1_w); |
| 64 | | DECLARE_WRITE8_MEMBER(mjsister_banksel2_w); |
| 65 | | DECLARE_WRITE8_MEMBER(mjsister_input_sel1_w); |
| 66 | | DECLARE_WRITE8_MEMBER(mjsister_input_sel2_w); |
| 67 | | DECLARE_READ8_MEMBER(mjsister_keys_r); |
| 61 | DECLARE_WRITE8_MEMBER(videoram_w); |
| 62 | DECLARE_WRITE8_MEMBER(dac_adr_s_w); |
| 63 | DECLARE_WRITE8_MEMBER(dac_adr_e_w); |
| 64 | DECLARE_WRITE8_MEMBER(banksel1_w); |
| 65 | DECLARE_WRITE8_MEMBER(banksel2_w); |
| 66 | DECLARE_WRITE8_MEMBER(input_sel1_w); |
| 67 | DECLARE_WRITE8_MEMBER(input_sel2_w); |
| 68 | DECLARE_READ8_MEMBER(keys_r); |
| 68 | 69 | TIMER_CALLBACK_MEMBER(dac_callback); |
| 69 | 70 | virtual void machine_start(); |
| 70 | 71 | virtual void machine_reset(); |
| 71 | 72 | virtual void video_start(); |
| 72 | | UINT32 screen_update_mjsister(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 73 | | void mjsister_redraw(); |
| 74 | | void mjsister_plot0( int offset, UINT8 data ); |
| 75 | | void mjsister_plot1( int offset, UINT8 data ); |
| 73 | UINT32 screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 74 | void redraw(); |
| 75 | void plot0( int offset, UINT8 data ); |
| 76 | void plot1( int offset, UINT8 data ); |
| 76 | 77 | |
| 77 | 78 | protected: |
| 78 | 79 | virtual void device_timer(emu_timer &timer, device_timer_id id, int param, void *ptr); |
| r31855 | r31856 | |
| 94 | 95 | save_item(NAME(m_videoram1)); |
| 95 | 96 | } |
| 96 | 97 | |
| 97 | | void mjsister_state::mjsister_plot0( int offset, UINT8 data ) |
| 98 | void mjsister_state::plot0( int offset, UINT8 data ) |
| 98 | 99 | { |
| 99 | 100 | int x, y, c1, c2; |
| 100 | 101 | |
| r31855 | r31856 | |
| 108 | 109 | m_tmpbitmap0->pix16(y, x * 2 + 1) = c2; |
| 109 | 110 | } |
| 110 | 111 | |
| 111 | | void mjsister_state::mjsister_plot1( int offset, UINT8 data ) |
| 112 | void mjsister_state::plot1( int offset, UINT8 data ) |
| 112 | 113 | { |
| 113 | 114 | int x, y, c1, c2; |
| 114 | 115 | |
| r31855 | r31856 | |
| 127 | 128 | m_tmpbitmap1->pix16(y, x * 2 + 1) = c2; |
| 128 | 129 | } |
| 129 | 130 | |
| 130 | | WRITE8_MEMBER(mjsister_state::mjsister_videoram_w) |
| 131 | WRITE8_MEMBER(mjsister_state::videoram_w) |
| 131 | 132 | { |
| 132 | 133 | if (m_vrambank) |
| 133 | 134 | { |
| 134 | 135 | m_videoram1[offset] = data; |
| 135 | | mjsister_plot1(offset, data); |
| 136 | plot1(offset, data); |
| 136 | 137 | } |
| 137 | 138 | else |
| 138 | 139 | { |
| 139 | 140 | m_videoram0[offset] = data; |
| 140 | | mjsister_plot0(offset, data); |
| 141 | plot0(offset, data); |
| 141 | 142 | } |
| 142 | 143 | } |
| 143 | 144 | |
| 144 | | UINT32 mjsister_state::screen_update_mjsister(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 145 | UINT32 mjsister_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect) |
| 145 | 146 | { |
| 146 | 147 | int flip = m_flip_screen; |
| 147 | 148 | int i, j; |
| r31855 | r31856 | |
| 152 | 153 | |
| 153 | 154 | for (offs = 0; offs < 0x8000; offs++) |
| 154 | 155 | { |
| 155 | | mjsister_plot0(offs, m_videoram0[offs]); |
| 156 | | mjsister_plot1(offs, m_videoram1[offs]); |
| 156 | plot0(offs, m_videoram0[offs]); |
| 157 | plot1(offs, m_videoram1[offs]); |
| 157 | 158 | } |
| 158 | 159 | m_screen_redraw = 0; |
| 159 | 160 | } |
| r31855 | r31856 | |
| 202 | 203 | m_dac_busy = 0; |
| 203 | 204 | } |
| 204 | 205 | |
| 205 | | WRITE8_MEMBER(mjsister_state::mjsister_dac_adr_s_w) |
| 206 | WRITE8_MEMBER(mjsister_state::dac_adr_s_w) |
| 206 | 207 | { |
| 207 | 208 | m_dac_adr_s = data; |
| 208 | 209 | } |
| 209 | 210 | |
| 210 | | WRITE8_MEMBER(mjsister_state::mjsister_dac_adr_e_w) |
| 211 | WRITE8_MEMBER(mjsister_state::dac_adr_e_w) |
| 211 | 212 | { |
| 212 | 213 | m_dac_adr_e = data; |
| 213 | 214 | m_dac_adr = m_dac_adr_s << 8; |
| r31855 | r31856 | |
| 218 | 219 | m_dac_busy = 1; |
| 219 | 220 | } |
| 220 | 221 | |
| 221 | | WRITE8_MEMBER(mjsister_state::mjsister_banksel1_w) |
| 222 | WRITE8_MEMBER(mjsister_state::banksel1_w) |
| 222 | 223 | { |
| 223 | 224 | int tmp = m_colorbank; |
| 224 | 225 | |
| r31855 | r31856 | |
| 253 | 254 | membank("bank1")->set_entry(m_rombank0 * 2 + m_rombank1); |
| 254 | 255 | } |
| 255 | 256 | |
| 256 | | WRITE8_MEMBER(mjsister_state::mjsister_banksel2_w) |
| 257 | WRITE8_MEMBER(mjsister_state::banksel2_w) |
| 257 | 258 | { |
| 258 | 259 | switch (data) |
| 259 | 260 | { |
| r31855 | r31856 | |
| 270 | 271 | membank("bank1")->set_entry(m_rombank0 * 2 + m_rombank1); |
| 271 | 272 | } |
| 272 | 273 | |
| 273 | | WRITE8_MEMBER(mjsister_state::mjsister_input_sel1_w) |
| 274 | WRITE8_MEMBER(mjsister_state::input_sel1_w) |
| 274 | 275 | { |
| 275 | 276 | m_input_sel1 = data; |
| 276 | 277 | } |
| 277 | 278 | |
| 278 | | WRITE8_MEMBER(mjsister_state::mjsister_input_sel2_w) |
| 279 | WRITE8_MEMBER(mjsister_state::input_sel2_w) |
| 279 | 280 | { |
| 280 | 281 | m_input_sel2 = data; |
| 281 | 282 | } |
| 282 | 283 | |
| 283 | | READ8_MEMBER(mjsister_state::mjsister_keys_r) |
| 284 | READ8_MEMBER(mjsister_state::keys_r) |
| 284 | 285 | { |
| 285 | 286 | int p, i, ret = 0; |
| 286 | 287 | static const char *const keynames[] = { "KEY0", "KEY1", "KEY2", "KEY3", "KEY4", "KEY5" }; |
| r31855 | r31856 | |
| 306 | 307 | static ADDRESS_MAP_START( mjsister_map, AS_PROGRAM, 8, mjsister_state ) |
| 307 | 308 | AM_RANGE(0x0000, 0x77ff) AM_ROM |
| 308 | 309 | AM_RANGE(0x7800, 0x7fff) AM_RAM |
| 309 | | AM_RANGE(0x8000, 0xffff) AM_ROMBANK("bank1") AM_WRITE(mjsister_videoram_w) |
| 310 | AM_RANGE(0x8000, 0xffff) AM_ROMBANK("bank1") AM_WRITE(videoram_w) |
| 310 | 311 | ADDRESS_MAP_END |
| 311 | 312 | |
| 312 | 313 | static ADDRESS_MAP_START( mjsister_io_map, AS_IO, 8, mjsister_state ) |
| r31855 | r31856 | |
| 315 | 316 | AM_RANGE(0x10, 0x10) AM_DEVWRITE("aysnd", ay8910_device, address_w) |
| 316 | 317 | AM_RANGE(0x11, 0x11) AM_DEVREAD("aysnd", ay8910_device, data_r) |
| 317 | 318 | AM_RANGE(0x12, 0x12) AM_DEVWRITE("aysnd", ay8910_device, data_w) |
| 318 | | AM_RANGE(0x20, 0x20) AM_READ(mjsister_keys_r) |
| 319 | AM_RANGE(0x20, 0x20) AM_READ(keys_r) |
| 319 | 320 | AM_RANGE(0x21, 0x21) AM_READ_PORT("IN0") |
| 320 | | AM_RANGE(0x30, 0x30) AM_WRITE(mjsister_banksel1_w) |
| 321 | | AM_RANGE(0x31, 0x31) AM_WRITE(mjsister_banksel2_w) |
| 322 | | AM_RANGE(0x32, 0x32) AM_WRITE(mjsister_input_sel1_w) |
| 323 | | AM_RANGE(0x33, 0x33) AM_WRITE(mjsister_input_sel2_w) |
| 324 | | AM_RANGE(0x34, 0x34) AM_WRITE(mjsister_dac_adr_s_w) |
| 325 | | AM_RANGE(0x35, 0x35) AM_WRITE(mjsister_dac_adr_e_w) |
| 321 | AM_RANGE(0x30, 0x30) AM_WRITE(banksel1_w) |
| 322 | AM_RANGE(0x31, 0x31) AM_WRITE(banksel2_w) |
| 323 | AM_RANGE(0x32, 0x32) AM_WRITE(input_sel1_w) |
| 324 | AM_RANGE(0x33, 0x33) AM_WRITE(input_sel2_w) |
| 325 | AM_RANGE(0x34, 0x34) AM_WRITE(dac_adr_s_w) |
| 326 | AM_RANGE(0x35, 0x35) AM_WRITE(dac_adr_e_w) |
| 326 | 327 | ADDRESS_MAP_END |
| 327 | 328 | |
| 328 | 329 | |
| r31855 | r31856 | |
| 449 | 450 | * |
| 450 | 451 | *************************************/ |
| 451 | 452 | |
| 452 | | void mjsister_state::mjsister_redraw() |
| 453 | void mjsister_state::redraw() |
| 453 | 454 | { |
| 454 | 455 | /* we can skip saving tmpbitmaps because we can redraw them from vram */ |
| 455 | 456 | m_screen_redraw = 1; |
| r31855 | r31856 | |
| 474 | 475 | save_item(NAME(m_dac_bank)); |
| 475 | 476 | save_item(NAME(m_dac_adr_s)); |
| 476 | 477 | save_item(NAME(m_dac_adr_e)); |
| 477 | | machine().save().register_postload(save_prepost_delegate(FUNC(mjsister_state::mjsister_redraw), this)); |
| 478 | machine().save().register_postload(save_prepost_delegate(FUNC(mjsister_state::redraw), this)); |
| 478 | 479 | } |
| 479 | 480 | |
| 480 | 481 | void mjsister_state::machine_reset() |
| r31855 | r31856 | |
| 511 | 512 | MCFG_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500) /* not accurate */) |
| 512 | 513 | MCFG_SCREEN_SIZE(256+4, 256) |
| 513 | 514 | MCFG_SCREEN_VISIBLE_AREA(0, 255+4, 8, 247) |
| 514 | | MCFG_SCREEN_UPDATE_DRIVER(mjsister_state, screen_update_mjsister) |
| 515 | MCFG_SCREEN_UPDATE_DRIVER(mjsister_state, screen_update) |
| 515 | 516 | MCFG_SCREEN_PALETTE("palette") |
| 516 | 517 | |
| 517 | 518 | MCFG_PALETTE_ADD_RRRRGGGGBBBB_PROMS("palette", 256) |