trunk/src/mess/includes/vc4000.h
| r20654 | r20655 | |
| 72 | 72 | { |
| 73 | 73 | public: |
| 74 | 74 | vc4000_state(const machine_config &mconfig, device_type type, const char *tag) |
| 75 | | : driver_device(mconfig, type, tag), |
| 76 | | m_cass(*this, CASSETTE_TAG) |
| 75 | : driver_device(mconfig, type, tag) |
| 76 | , m_cass(*this, CASSETTE_TAG) |
| 77 | , m_maincpu(*this, "maincpu") |
| 78 | , m_keypad1_1(*this, "KEYPAD1_1") |
| 79 | , m_keypad1_2(*this, "KEYPAD1_2") |
| 80 | , m_keypad1_3(*this, "KEYPAD1_3") |
| 81 | , m_panel(*this, "PANEL") |
| 82 | , m_keypad2_1(*this, "KEYPAD2_1") |
| 83 | , m_keypad2_2(*this, "KEYPAD2_2") |
| 84 | , m_keypad2_3(*this, "KEYPAD2_3") |
| 85 | #ifndef ANALOG_HACK |
| 86 | , m_io_joy1_x(*this, "JOY1_X") |
| 87 | , m_io_joy1_y(*this, "JOY1_Y") |
| 88 | , m_io_joy2_x(*this, "JOY2_X") |
| 89 | , m_io_joy2_y(*this, "JOY2_Y") |
| 90 | #else |
| 91 | , m_joys(*this, "JOYS") |
| 92 | , m_config(*this, "CONFIG") |
| 93 | #endif |
| 77 | 94 | { } |
| 78 | 95 | |
| 79 | 96 | DECLARE_WRITE8_MEMBER(vc4000_sound_ctl); |
| r20654 | r20655 | |
| 98 | 115 | virtual void palette_init(); |
| 99 | 116 | UINT32 screen_update_vc4000(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect); |
| 100 | 117 | INTERRUPT_GEN_MEMBER(vc4000_video_line); |
| 118 | |
| 119 | protected: |
| 120 | required_device<cpu_device> m_maincpu; |
| 121 | required_ioport m_keypad1_1; |
| 122 | required_ioport m_keypad1_2; |
| 123 | required_ioport m_keypad1_3; |
| 124 | required_ioport m_panel; |
| 125 | required_ioport m_keypad2_1; |
| 126 | required_ioport m_keypad2_2; |
| 127 | required_ioport m_keypad2_3; |
| 128 | #ifndef ANALOG_HACK |
| 129 | required_ioport m_io_joy1_x; |
| 130 | required_ioport m_io_joy1_y; |
| 131 | required_ioport m_io_joy2_x; |
| 132 | required_ioport m_io_joy2_y; |
| 133 | #else |
| 134 | required_ioport m_joys; |
| 135 | required_ioport m_config; |
| 136 | #endif |
| 101 | 137 | }; |
| 102 | 138 | |
| 103 | 139 | /*----------- defined in audio/vc4000.c -----------*/ |
trunk/src/mess/video/vc4000.c
| r20654 | r20655 | |
| 115 | 115 | |
| 116 | 116 | #ifndef ANALOG_HACK |
| 117 | 117 | case 0xcc: |
| 118 | | if (!activeS2650_FO)) data=ioport("JOY1_X")->read(); |
| 119 | | else data=ioport("JOY1_Y")->read(); |
| 118 | if (!activeS2650_FO)) data = m_io_joy1_x->read(); |
| 119 | else data = m_io_joy1_y->read(); |
| 120 | 120 | break; |
| 121 | 121 | case 0xcd: |
| 122 | | if (!activecpu_get_reg(S2650_FO)) data=ioport("JOY2_X")->read(); |
| 123 | | else data=ioport("JOY2_Y")->read(); |
| 122 | if (!activecpu_get_reg(S2650_FO)) data = m_io_joy2_x->read(); |
| 123 | else data = m_io_joy2_y->read(); |
| 124 | 124 | break; |
| 125 | 125 | #else |
| 126 | 126 | |
| 127 | 127 | case 0xcc: /* left joystick */ |
| 128 | | if (ioport("CONFIG")->read()&1) |
| 128 | if (m_config->read()&1) |
| 129 | 129 | { /* paddle */ |
| 130 | | if (!machine().device("maincpu")->state().state_int(S2650_FO)) |
| 130 | if (!m_maincpu->state_int(S2650_FO)) |
| 131 | 131 | { |
| 132 | | data = ioport("JOYS")->read() & 0x03; |
| 132 | data = m_joys->read() & 0x03; |
| 133 | 133 | switch (data) |
| 134 | 134 | { |
| 135 | 135 | case 0x01: |
| r20654 | r20655 | |
| 147 | 147 | } |
| 148 | 148 | else |
| 149 | 149 | { |
| 150 | | data = ioport("JOYS")->read() & 0x0c; |
| 150 | data = m_joys->read() & 0x0c; |
| 151 | 151 | switch (data) |
| 152 | 152 | { |
| 153 | 153 | case 0x08: |
| r20654 | r20655 | |
| 166 | 166 | } |
| 167 | 167 | else |
| 168 | 168 | { /* buttons */ |
| 169 | | if (!machine().device("maincpu")->state().state_int(S2650_FO)) |
| 169 | if (!m_maincpu->state_int(S2650_FO)) |
| 170 | 170 | { |
| 171 | | data = ioport("JOYS")->read() & 0x03; |
| 171 | data = m_joys->read() & 0x03; |
| 172 | 172 | switch (data) |
| 173 | 173 | { |
| 174 | 174 | case 0x01: |
| r20654 | r20655 | |
| 184 | 184 | } |
| 185 | 185 | else |
| 186 | 186 | { |
| 187 | | data = ioport("JOYS")->read() & 0x0c; |
| 187 | data = m_joys->read() & 0x0c; |
| 188 | 188 | switch (data) |
| 189 | 189 | { |
| 190 | 190 | case 0x08: |
| r20654 | r20655 | |
| 202 | 202 | break; |
| 203 | 203 | |
| 204 | 204 | case 0xcd: /* right joystick */ |
| 205 | | if (ioport("CONFIG")->read()&1) |
| 205 | if (m_config->read()&1) |
| 206 | 206 | { |
| 207 | | if (!machine().device("maincpu")->state().state_int(S2650_FO)) |
| 207 | if (!m_maincpu->state_int(S2650_FO)) |
| 208 | 208 | { |
| 209 | | data = ioport("JOYS")->read() & 0x30; |
| 209 | data = m_joys->read() & 0x30; |
| 210 | 210 | switch (data) |
| 211 | 211 | { |
| 212 | 212 | case 0x10: |
| r20654 | r20655 | |
| 224 | 224 | } |
| 225 | 225 | else |
| 226 | 226 | { |
| 227 | | data = ioport("JOYS")->read() & 0xc0; |
| 227 | data = m_joys->read() & 0xc0; |
| 228 | 228 | switch (data) |
| 229 | 229 | { |
| 230 | 230 | case 0x80: |
| r20654 | r20655 | |
| 243 | 243 | } |
| 244 | 244 | else |
| 245 | 245 | { |
| 246 | | if (!machine().device("maincpu")->state().state_int(S2650_FO)) |
| 246 | if (!m_maincpu->state_int(S2650_FO)) |
| 247 | 247 | { |
| 248 | | data = ioport("JOYS")->read() & 0x30; |
| 248 | data = m_joys->read() & 0x30; |
| 249 | 249 | switch (data) |
| 250 | 250 | { |
| 251 | 251 | case 0x10: |
| r20654 | r20655 | |
| 261 | 261 | } |
| 262 | 262 | else |
| 263 | 263 | { |
| 264 | | data = ioport("JOYS")->read() & 0xc0; |
| 264 | data = m_joys->read() & 0xc0; |
| 265 | 265 | switch (data) |
| 266 | 266 | { |
| 267 | 267 | case 0x80: |
| r20654 | r20655 | |
| 593 | 593 | |
| 594 | 594 | if (m_irq_pause>10) |
| 595 | 595 | { |
| 596 | | machine().device("maincpu")->execute().set_input_line(0, CLEAR_LINE); |
| 596 | m_maincpu->set_input_line(0, CLEAR_LINE); |
| 597 | 597 | m_irq_pause = 0; |
| 598 | 598 | } |
| 599 | 599 | |
| r20654 | r20655 | |
| 639 | 639 | (m_video.sprites[1].finished_now) | |
| 640 | 640 | (m_video.sprites[0].finished_now)) && (!m_irq_pause)) |
| 641 | 641 | { |
| 642 | | machine().device("maincpu")->execute().set_input_line_and_vector(0, ASSERT_LINE, 3); |
| 642 | m_maincpu->set_input_line_and_vector(0, ASSERT_LINE, 3); |
| 643 | 643 | m_irq_pause=1; |
| 644 | 644 | } |
| 645 | 645 | } |
trunk/src/mess/drivers/vc4000.c
| r20654 | r20655 | |
| 114 | 114 | switch(offset & 0x0f) |
| 115 | 115 | { |
| 116 | 116 | case 0x08: |
| 117 | | data = ioport("KEYPAD1_1")->read(); |
| 117 | data = m_keypad1_1->read(); |
| 118 | 118 | break; |
| 119 | 119 | case 0x09: |
| 120 | | data = ioport("KEYPAD1_2")->read(); |
| 120 | data = m_keypad1_2->read(); |
| 121 | 121 | break; |
| 122 | 122 | case 0x0a: |
| 123 | | data = ioport("KEYPAD1_3")->read(); |
| 123 | data = m_keypad1_3->read(); |
| 124 | 124 | break; |
| 125 | 125 | case 0x0b: |
| 126 | | data = ioport("PANEL")->read(); |
| 126 | data = m_panel->read(); |
| 127 | 127 | break; |
| 128 | 128 | case 0x0c: |
| 129 | | data = ioport("KEYPAD2_1")->read(); |
| 129 | data = m_keypad2_1->read(); |
| 130 | 130 | break; |
| 131 | 131 | case 0x0d: |
| 132 | | data = ioport("KEYPAD2_2")->read(); |
| 132 | data = m_keypad2_2->read(); |
| 133 | 133 | break; |
| 134 | 134 | case 0x0e: |
| 135 | | data = ioport("KEYPAD2_3")->read(); |
| 135 | data = m_keypad2_3->read(); |
| 136 | 136 | break; |
| 137 | 137 | } |
| 138 | 138 | return data; |