trunk/src/mess/drivers/splitsec.c
| r243443 | r243444 | |
| 16 | 16 | *: higher number indicates higher difficulty |
| 17 | 17 | |
| 18 | 18 | |
| 19 | | TODO: |
| 20 | | - MCU clock is unknown |
| 19 | **************************************************************************** |
| 21 | 20 | |
| 21 | Parker Brothers Bank Shot (also released in other regions as Cue Ball) |
| 22 | * TMS1400NLL MP7313-N2 (die labeled MP7313) |
| 23 | |
| 24 | x |
| 25 | |
| 26 | |
| 22 | 27 | ***************************************************************************/ |
| 23 | 28 | |
| 24 | 29 | #include "emu.h" |
| r243443 | r243444 | |
| 26 | 31 | #include "sound/speaker.h" |
| 27 | 32 | |
| 28 | 33 | #include "splitsec.lh" |
| 34 | #include "bankshot.lh" |
| 29 | 35 | |
| 30 | 36 | // The master clock is a single stage RC oscillator: R=24K, C=100pf, |
| 31 | 37 | // according to the TMS 1000 series data manual this is around 375kHz. |
| r243443 | r243444 | |
| 33 | 39 | // to recordings, maybe the RC osc curve is different for TMS1400? |
| 34 | 40 | |
| 35 | 41 | // so for now, the value below is an approximation |
| 36 | | #define MASTER_CLOCK (485000) |
| 42 | #define MASTER_CLOCK (475000) |
| 37 | 43 | |
| 38 | 44 | |
| 39 | 45 | class splitsec_state : public driver_device |
| r243443 | r243444 | |
| 50 | 56 | required_ioport_array<2> m_button_matrix; |
| 51 | 57 | required_device<speaker_sound_device> m_speaker; |
| 52 | 58 | |
| 59 | UINT8 m_input_mux; |
| 53 | 60 | UINT16 m_r; |
| 54 | 61 | UINT16 m_o; |
| 55 | 62 | |
| r243443 | r243444 | |
| 59 | 66 | |
| 60 | 67 | DECLARE_READ8_MEMBER(read_k); |
| 61 | 68 | DECLARE_WRITE16_MEMBER(write_o); |
| 62 | | DECLARE_WRITE16_MEMBER(write_r); |
| 69 | DECLARE_WRITE16_MEMBER(splitsec_write_r); |
| 70 | DECLARE_WRITE16_MEMBER(bankshot_write_r); |
| 63 | 71 | |
| 64 | 72 | TIMER_DEVICE_CALLBACK_MEMBER(leds_decay_tick); |
| 65 | 73 | void leds_update(); |
| r243443 | r243444 | |
| 83 | 91 | |
| 84 | 92 | /* display layout, where number xy is lamp R(x),O(y) |
| 85 | 93 | |
| 94 | Split Second: |
| 95 | |
| 86 | 96 | 00 02 04 |
| 87 | 97 | 10 01 12 03 14 05 16 |
| 88 | 98 | 11 13 15 |
| r243443 | r243444 | |
| 94 | 104 | 71 73 75 |
| 95 | 105 | 50 60 52 62 54 64 56 |
| 96 | 106 | 70 72 74 |
| 107 | |
| 108 | |
| 109 | Bank Shot: |
| 110 | |
| 111 | x |
| 112 | |
| 97 | 113 | */ |
| 98 | 114 | |
| 99 | 115 | void splitsec_state::leds_update() |
| r243443 | r243444 | |
| 156 | 172 | |
| 157 | 173 | // read selected button rows |
| 158 | 174 | for (int i = 0; i < 2; i++) |
| 159 | | if (m_r >> (i+9) & 1) |
| 175 | if (m_input_mux >> i & 1) |
| 160 | 176 | k |= m_button_matrix[i]->read(); |
| 161 | 177 | |
| 162 | 178 | return k; |
| 163 | 179 | } |
| 164 | 180 | |
| 165 | | WRITE16_MEMBER(splitsec_state::write_r) |
| 181 | WRITE16_MEMBER(splitsec_state::write_o) |
| 166 | 182 | { |
| 183 | // O0-O6: led rows |
| 184 | // O7: N/C |
| 185 | m_o = data; |
| 186 | leds_update(); |
| 187 | } |
| 188 | |
| 189 | WRITE16_MEMBER(splitsec_state::splitsec_write_r) |
| 190 | { |
| 167 | 191 | // R8: speaker out |
| 168 | 192 | m_speaker->level_w(data >> 8 & 1); |
| 169 | 193 | |
| 170 | 194 | // R9,R10: input mux |
| 195 | m_input_mux = data >> 9 & 3; |
| 196 | |
| 171 | 197 | // R0-R7: led columns |
| 172 | | m_r = data; |
| 198 | m_r = data & 0xff; |
| 173 | 199 | leds_update(); |
| 174 | 200 | } |
| 175 | 201 | |
| 176 | | WRITE16_MEMBER(splitsec_state::write_o) |
| 202 | WRITE16_MEMBER(splitsec_state::bankshot_write_r) |
| 177 | 203 | { |
| 178 | | // O0-O6: led rows |
| 179 | | // O7: N/C |
| 180 | | m_o = data; |
| 204 | // R0: speaker out |
| 205 | m_speaker->level_w(data & 1); |
| 206 | |
| 207 | // R2,R3: input mux |
| 208 | m_input_mux = data >> 2 & 3; |
| 209 | |
| 210 | // R2-R10: led columns |
| 211 | m_r = data & ~3; |
| 181 | 212 | leds_update(); |
| 182 | 213 | } |
| 183 | 214 | |
| r243443 | r243444 | |
| 203 | 234 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_UNUSED ) |
| 204 | 235 | INPUT_PORTS_END |
| 205 | 236 | |
| 237 | static INPUT_PORTS_START( bankshot ) |
| 238 | PORT_START("IN.0") // R2 |
| 239 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON1 ) |
| 240 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON2 ) |
| 241 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_BUTTON3 ) |
| 242 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_UNUSED ) |
| 206 | 243 | |
| 244 | PORT_START("IN.1") // R3 |
| 245 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON4 ) |
| 246 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON5 ) |
| 247 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_BUTTON6 ) |
| 248 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_UNUSED ) |
| 249 | INPUT_PORTS_END |
| 207 | 250 | |
| 251 | |
| 252 | |
| 208 | 253 | /*************************************************************************** |
| 209 | 254 | |
| 210 | 255 | Machine Config |
| r243443 | r243444 | |
| 218 | 263 | memset(m_leds_cache, 0, sizeof(m_leds_cache)); |
| 219 | 264 | memset(m_leds_decay, 0, sizeof(m_leds_decay)); |
| 220 | 265 | |
| 266 | m_input_mux = 0; |
| 221 | 267 | m_r = 0; |
| 222 | 268 | m_o = 0; |
| 223 | 269 | |
| r243443 | r243444 | |
| 226 | 272 | save_item(NAME(m_leds_cache)); |
| 227 | 273 | save_item(NAME(m_leds_decay)); |
| 228 | 274 | |
| 275 | save_item(NAME(m_input_mux)); |
| 229 | 276 | save_item(NAME(m_r)); |
| 230 | 277 | save_item(NAME(m_o)); |
| 231 | 278 | } |
| r243443 | r243444 | |
| 237 | 284 | MCFG_CPU_ADD("maincpu", TMS1400, MASTER_CLOCK) |
| 238 | 285 | MCFG_TMS1XXX_READ_K_CB(READ8(splitsec_state, read_k)) |
| 239 | 286 | MCFG_TMS1XXX_WRITE_O_CB(WRITE16(splitsec_state, write_o)) |
| 240 | | MCFG_TMS1XXX_WRITE_R_CB(WRITE16(splitsec_state, write_r)) |
| 287 | MCFG_TMS1XXX_WRITE_R_CB(WRITE16(splitsec_state, splitsec_write_r)) |
| 241 | 288 | |
| 242 | 289 | MCFG_TIMER_DRIVER_ADD_PERIODIC("leds_decay", splitsec_state, leds_decay_tick, attotime::from_msec(10)) |
| 243 | 290 | |
| r243443 | r243444 | |
| 251 | 298 | MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.25) |
| 252 | 299 | MACHINE_CONFIG_END |
| 253 | 300 | |
| 301 | static MACHINE_CONFIG_DERIVED( bankshot, splitsec ) |
| 254 | 302 | |
| 303 | /* basic machine hardware */ |
| 304 | MCFG_CPU_MODIFY("maincpu") |
| 305 | MCFG_TMS1XXX_WRITE_R_CB(WRITE16(splitsec_state, bankshot_write_r)) |
| 255 | 306 | |
| 307 | MCFG_DEFAULT_LAYOUT(layout_bankshot) |
| 308 | MACHINE_CONFIG_END |
| 309 | |
| 310 | |
| 311 | |
| 256 | 312 | /*************************************************************************** |
| 257 | 313 | |
| 258 | 314 | Game driver(s) |
| r243443 | r243444 | |
| 269 | 325 | ROM_LOAD( "tms1400_splitsec_opla.pla", 0, 557, CRC(7539283b) SHA1(f791fa98259fc10c393ff1961d4c93040f1a2932) ) |
| 270 | 326 | ROM_END |
| 271 | 327 | |
| 328 | ROM_START( bankshot ) |
| 329 | ROM_REGION( 0x1000, "maincpu", 0 ) |
| 330 | ROM_LOAD( "tms1400nll_mp7313", 0x0000, 0x1000, CRC(7a5016a9) SHA1(a8730dc8a282ffaa3d89e675f371d43eb39f39b4) ) |
| 272 | 331 | |
| 332 | ROM_REGION( 867, "maincpu:mpla", 0 ) |
| 333 | ROM_LOAD( "tms1100_default_mpla.pla", 0, 867, CRC(62445fc9) SHA1(d6297f2a4bc7a870b76cc498d19dbb0ce7d69fec) ) |
| 334 | ROM_REGION( 557, "maincpu:opla", 0 ) |
| 335 | ROM_LOAD( "tms1400_bankshot_opla.pla", 0, 557, CRC(7539283b) SHA1(f791fa98259fc10c393ff1961d4c93040f1a2932) ) |
| 336 | ROM_END |
| 337 | |
| 338 | |
| 273 | 339 | CONS( 1980, splitsec, 0, 0, splitsec, splitsec, driver_device, 0, "Parker Brothers", "Split Second", GAME_SUPPORTS_SAVE ) |
| 340 | CONS( 1980, bankshot, 0, 0, bankshot, bankshot, driver_device, 0, "Parker Brothers", "Bank Shot - Electronic Pool", GAME_SUPPORTS_SAVE | GAME_NOT_WORKING ) |