trunk/src/mame/drivers/kurukuru.c
| r19728 | r19729 | |
| 8 | 8 | |
| 9 | 9 | |
| 10 | 10 | This hardware seems to be a derivative of MSX2 'on steroids'. |
| 11 | It has many similarites with sothello.c and tonton.c |
| 11 | 12 | |
| 12 | 13 | |
| 13 | 14 | ******************************************************************************* |
| r19728 | r19729 | |
| 357 | 358 | |
| 358 | 359 | WRITE8_MEMBER(kurukuru_state::kurukuru_adpcm_reset_w) |
| 359 | 360 | { |
| 360 | | // d0: reset adpcm chip |
| 361 | | // other bits: ? |
| 362 | | msm5205_reset_w(machine().device("adpcm"), data & 1); |
| 361 | device_t *device = machine().device("adpcm"); |
| 362 | /* |
| 363 | bit 0 = RESET |
| 364 | bit 1 = 4B/3B |
| 365 | bit 2 = S2 |
| 366 | bit 3 = S1 |
| 367 | */ |
| 368 | msm5205_playmode_w(device, BITSWAP8((data>>1), 7,6,5,4,3,0,1,2)); |
| 369 | msm5205_reset_w(device, data & 1); |
| 363 | 370 | update_sound_irq(m_sound_irq_cause); |
| 364 | 371 | } |
| 365 | 372 | |
| r19728 | r19729 | |
| 512 | 519 | static const msm5205_interface msm5205_config = |
| 513 | 520 | { |
| 514 | 521 | kurukuru_msm5205_vck, |
| 515 | | MSM5205_S48_4B /* 8 kHz? */ |
| 522 | MSM5205_S48_4B /* changed on the fly */ |
| 516 | 523 | }; |
| 517 | 524 | |
| 518 | 525 | |
trunk/src/mame/drivers/sothello.c
| r19728 | r19729 | |
| 49 | 49 | : driver_device(mconfig, type, tag), |
| 50 | 50 | m_v9938(*this, "v9938") { } |
| 51 | 51 | |
| 52 | required_device<v9938_device> m_v9938; |
| 53 | |
| 52 | 54 | int m_subcpu_status; |
| 53 | 55 | int m_soundcpu_busy; |
| 54 | 56 | int m_msm_data; |
| 55 | | required_device<v9938_device> m_v9938; |
| 57 | |
| 56 | 58 | DECLARE_WRITE8_MEMBER(bank_w); |
| 57 | 59 | DECLARE_READ8_MEMBER(subcpu_halt_set); |
| 58 | 60 | DECLARE_READ8_MEMBER(subcpu_halt_clear); |
| r19728 | r19729 | |
| 65 | 67 | DECLARE_WRITE8_MEMBER(subcpu_status_w); |
| 66 | 68 | DECLARE_READ8_MEMBER(subcpu_status_r); |
| 67 | 69 | DECLARE_WRITE8_MEMBER(msm_cfg_w); |
| 70 | |
| 68 | 71 | virtual void machine_reset(); |
| 69 | 72 | TIMER_CALLBACK_MEMBER(subcpu_suspend); |
| 70 | 73 | TIMER_CALLBACK_MEMBER(subcpu_resume); |
| r19728 | r19729 | |
| 167 | 170 | bit 2 = S2 1 |
| 168 | 171 | bit 3 = S1 2 |
| 169 | 172 | */ |
| 170 | | msm5205_playmode_w(device, BITSWAP8((data>>1), 7,6,5,4,3,0,1,2)); /* or maybe 7,6,5,4,3,0,2,1 ??? */ |
| 173 | msm5205_playmode_w(device, BITSWAP8((data>>1), 7,6,5,4,3,0,1,2)); |
| 171 | 174 | msm5205_reset_w(device,data&1); |
| 172 | 175 | } |
| 173 | 176 | |
| r19728 | r19729 | |
| 365 | 368 | static MACHINE_CONFIG_START( sothello, sothello_state ) |
| 366 | 369 | |
| 367 | 370 | /* basic machine hardware */ |
| 368 | | |
| 369 | 371 | MCFG_CPU_ADD("maincpu",Z80, MAINCPU_CLOCK) |
| 370 | 372 | MCFG_CPU_PROGRAM_MAP(maincpu_mem_map) |
| 371 | 373 | MCFG_CPU_IO_MAP(maincpu_io_map) |
| r19728 | r19729 | |
| 380 | 382 | |
| 381 | 383 | MCFG_QUANTUM_TIME(attotime::from_hz(600)) |
| 382 | 384 | |
| 383 | | |
| 385 | /* video hardware */ |
| 384 | 386 | MCFG_V9938_ADD("v9938", "screen", VDP_MEM) |
| 385 | 387 | MCFG_V99X8_INTERRUPT_CALLBACK_STATIC(sothello_vdp_interrupt) |
| 386 | 388 | |
| r19728 | r19729 | |
| 408 | 410 | MCFG_SOUND_ADD("msm",MSM5205, MSM_CLOCK) |
| 409 | 411 | MCFG_SOUND_CONFIG(msm_interface) |
| 410 | 412 | MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 1.0) |
| 411 | | |
| 412 | 413 | MACHINE_CONFIG_END |
| 413 | 414 | |
| 414 | 415 | /*************************************************************************** |