trunk/src/mess/drivers/nes.c
| r243148 | r243149 | |
| 48 | 48 | // 0x8000-0xffff -> HIGH HANDLER defined on a pcb base |
| 49 | 49 | ADDRESS_MAP_END |
| 50 | 50 | |
| 51 | |
| 52 | static INPUT_PORTS_START( nes_pads12 ) |
| 53 | PORT_START("PAD1") |
| 54 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_NAME("P1 A") PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 55 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_NAME("P1 B") PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 56 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 57 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 58 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 59 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 60 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 61 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 62 | |
| 63 | PORT_START("PAD2") |
| 64 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_NAME("P2 A") PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 65 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_NAME("P2 B") PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 66 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 67 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 68 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 69 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 70 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 71 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 72 | INPUT_PORTS_END |
| 73 | |
| 74 | static INPUT_PORTS_START( nes_pads34 ) |
| 75 | PORT_START("PAD3") |
| 76 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_NAME("P3 A") PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 77 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_NAME("P3 B") PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 78 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 79 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 80 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 81 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 82 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 83 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 84 | |
| 85 | PORT_START("PAD4") |
| 86 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_NAME("P4 A") PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 87 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_NAME("P4 B") PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 88 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 89 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 90 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 91 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 92 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 93 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 94 | INPUT_PORTS_END |
| 95 | |
| 96 | |
| 97 | static INPUT_PORTS_START( nes_powerpad ) |
| 98 | // difference between the two sides is that we mirror the key mapping to match the real pad layout! |
| 99 | PORT_START("POWERPAD1") |
| 100 | // side A layout |
| 101 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad Top1") PORT_CODE(KEYCODE_Y) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 102 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 103 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad Mid1") PORT_CODE(KEYCODE_J) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 104 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 105 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad Mid2") PORT_CODE(KEYCODE_H) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 106 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad Low1") PORT_CODE(KEYCODE_N) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 107 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad Low2") PORT_CODE(KEYCODE_B) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 108 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad Mid3") PORT_CODE(KEYCODE_G) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 109 | // side B layout |
| 110 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 2") PORT_CODE(KEYCODE_T) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 111 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 1") PORT_CODE(KEYCODE_R) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 112 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 5") PORT_CODE(KEYCODE_F) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 113 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 9") PORT_CODE(KEYCODE_V) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 114 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 6") PORT_CODE(KEYCODE_G) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 115 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 10") PORT_CODE(KEYCODE_B) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 116 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 11") PORT_CODE(KEYCODE_N) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 117 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 7") PORT_CODE(KEYCODE_H) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 118 | PORT_START("POWERPAD2") |
| 119 | // side A layout |
| 120 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 121 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad Top2") PORT_CODE(KEYCODE_T) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 122 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 123 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad Mid4") PORT_CODE(KEYCODE_F) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 124 | PORT_BIT( 0xf0, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0050) |
| 125 | // side B layout |
| 126 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 4") PORT_CODE(KEYCODE_U) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 127 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 3") PORT_CODE(KEYCODE_Y) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 128 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 12") PORT_CODE(KEYCODE_M) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 129 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("PowerPad 8") PORT_CODE(KEYCODE_J) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 130 | PORT_BIT( 0xf0, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0060) |
| 131 | INPUT_PORTS_END |
| 132 | |
| 133 | static INPUT_PORTS_START( nes_zapper1 ) |
| 134 | PORT_START("ZAPPER1_X") |
| 135 | PORT_BIT( 0xff, 0x80, IPT_LIGHTGUN_X) PORT_CROSSHAIR(X, 1.0, 0.0, 0) PORT_SENSITIVITY(70) PORT_KEYDELTA(30) PORT_MINMAX(0,255) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 136 | PORT_START("ZAPPER1_Y") |
| 137 | PORT_BIT( 0xff, 0x80, IPT_LIGHTGUN_Y) PORT_CROSSHAIR(Y, 1.0, 0.0, 0) PORT_SENSITIVITY(50) PORT_KEYDELTA(30) PORT_MINMAX(0,255) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 138 | PORT_START("ZAPPER1_T") |
| 139 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON1) PORT_NAME("P1 Lightgun Trigger") PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 140 | INPUT_PORTS_END |
| 141 | |
| 142 | static INPUT_PORTS_START( nes_zapper2 ) |
| 143 | PORT_START("ZAPPER2_X") |
| 144 | PORT_BIT( 0xff, 0x80, IPT_LIGHTGUN_X) PORT_CROSSHAIR(X, 1.0, 0.0, 0) PORT_SENSITIVITY(70) PORT_KEYDELTA(30) PORT_MINMAX(0,255 ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 145 | PORT_START("ZAPPER2_Y") |
| 146 | PORT_BIT( 0xff, 0x80, IPT_LIGHTGUN_Y) PORT_CROSSHAIR(Y, 1.0, 0.0, 0) PORT_SENSITIVITY(50) PORT_KEYDELTA(30) PORT_MINMAX(0,255 ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 147 | PORT_START("ZAPPER2_T") |
| 148 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON1) PORT_NAME("P2 Lightgun Trigger") PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 149 | INPUT_PORTS_END |
| 150 | |
| 151 | static INPUT_PORTS_START( nes_paddle ) |
| 152 | PORT_START("PADDLE") |
| 153 | PORT_BIT( 0xff, 0x7f, IPT_PADDLE) PORT_SENSITIVITY(25) PORT_KEYDELTA(25) PORT_CENTERDELTA(0) PORT_MINMAX(0x62,0xf2) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0040) |
| 154 | PORT_START("PADDLE_BUTTON") |
| 155 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON1) PORT_NAME("Paddle button") PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0040) |
| 156 | INPUT_PORTS_END |
| 157 | |
| 51 | 158 | static INPUT_PORTS_START( nes ) |
| 52 | | // input devices go through slot options |
| 159 | PORT_INCLUDE( nes_pads12 ) |
| 160 | PORT_INCLUDE( nes_pads34 ) |
| 161 | PORT_INCLUDE( nes_powerpad ) |
| 162 | PORT_INCLUDE( nes_zapper1 ) |
| 163 | PORT_INCLUDE( nes_zapper2 ) |
| 164 | PORT_INCLUDE( nes_paddle ) |
| 165 | |
| 166 | PORT_START("CTRLSEL") |
| 167 | PORT_CONFNAME( 0x000f, 0x0001, "P1 Controller") |
| 168 | PORT_CONFSETTING( 0x0000, "Unconnected" ) |
| 169 | PORT_CONFSETTING( 0x0001, "Gamepad" ) |
| 170 | PORT_CONFSETTING( 0x0002, "Zapper" ) |
| 171 | PORT_CONFNAME( 0x00f0, 0x0010, "P2 Controller") |
| 172 | PORT_CONFSETTING( 0x0000, "Unconnected" ) |
| 173 | PORT_CONFSETTING( 0x0010, "Gamepad" ) |
| 174 | PORT_CONFSETTING( 0x0020, "Zapper" ) |
| 175 | PORT_CONFSETTING( 0x0040, "Arkanoid paddle" ) |
| 176 | PORT_CONFSETTING( 0x0050, "Power Pad (Side A layout)" ) |
| 177 | PORT_CONFSETTING( 0x0060, "Power Pad (Side B layout)" ) |
| 178 | PORT_CONFNAME( 0x0f00, 0x0000, "P3 Controller") |
| 179 | PORT_CONFSETTING( 0x0000, "Unconnected" ) |
| 180 | PORT_CONFSETTING( 0x0100, "Gamepad" ) |
| 181 | PORT_CONFNAME( 0xf000, 0x0000, "P4 Controller") |
| 182 | PORT_CONFSETTING( 0x0000, "Unconnected" ) |
| 183 | PORT_CONFSETTING( 0x1000, "Gamepad" ) |
| 184 | |
| 53 | 185 | PORT_START("CONFIG") |
| 54 | 186 | PORT_CONFNAME( 0x01, 0x00, "Draw Top/Bottom 8 Lines") |
| 55 | 187 | PORT_CONFSETTING( 0x01, DEF_STR(No) ) |
| r243148 | r243149 | |
| 59 | 191 | PORT_CONFSETTING( 0x00, DEF_STR(Yes) ) |
| 60 | 192 | INPUT_PORTS_END |
| 61 | 193 | |
| 194 | |
| 195 | static INPUT_PORTS_START( fc_pads12 ) |
| 196 | PORT_START("PAD1") |
| 197 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_NAME("P1 A") PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 198 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_NAME("P1 B") PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 199 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 200 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 201 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 202 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 203 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 204 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0001) |
| 205 | |
| 206 | PORT_START("PAD2") |
| 207 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_NAME("P2 A") PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 208 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_NAME("P2 B") PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 209 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 210 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 211 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 212 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 213 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 214 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0010) |
| 215 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_NAME("P2 A") PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x00f0) |
| 216 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_NAME("P2 B") PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x00f0) |
| 217 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_NAME("Microphone") PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x00f0) |
| 218 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x00f0) |
| 219 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x00f0) |
| 220 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x00f0) |
| 221 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x00f0) |
| 222 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(2) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x00f0) |
| 223 | INPUT_PORTS_END |
| 224 | |
| 225 | static INPUT_PORTS_START( fc_pads34 ) |
| 226 | PORT_START("PAD3") |
| 227 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_NAME("P3 A") PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 228 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_NAME("P3 B") PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 229 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 230 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 231 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 232 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 233 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 234 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(3) PORT_CONDITION("CTRLSEL", 0x0f00, EQUALS, 0x0100) |
| 235 | |
| 236 | PORT_START("PAD4") |
| 237 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON2 ) PORT_NAME("P4 A") PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 238 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON1 ) PORT_NAME("P4 B") PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 239 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 240 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 241 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICK_UP ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 242 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICK_DOWN ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 243 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 244 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT ) PORT_PLAYER(4) PORT_CONDITION("CTRLSEL", 0xf000, EQUALS, 0x1000) |
| 245 | INPUT_PORTS_END |
| 246 | |
| 247 | static INPUT_PORTS_START( fc_lightgun ) |
| 248 | PORT_START("ZAPPER2_X") |
| 249 | PORT_BIT( 0xff, 0x80, IPT_LIGHTGUN_X) PORT_CROSSHAIR(X, 1.0, 0.0, 0) PORT_SENSITIVITY(70) PORT_KEYDELTA(30) PORT_MINMAX(0,255) PORT_PLAYER(2) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x01) |
| 250 | PORT_START("ZAPPER2_Y") |
| 251 | PORT_BIT( 0xff, 0x80, IPT_LIGHTGUN_Y) PORT_CROSSHAIR(Y, 1.0, 0.0, 0) PORT_SENSITIVITY(50) PORT_KEYDELTA(30) PORT_MINMAX(0,255) PORT_PLAYER(2) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x01) |
| 252 | PORT_START("ZAPPER2_T") |
| 253 | PORT_BIT( 0x03, IP_ACTIVE_HIGH, IPT_BUTTON1) PORT_NAME("Lightgun Trigger") PORT_PLAYER(2) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x01) |
| 254 | INPUT_PORTS_END |
| 255 | |
| 256 | static INPUT_PORTS_START( fc_paddle ) |
| 257 | PORT_START("PADDLE") |
| 258 | PORT_BIT( 0xff, 0x7f, IPT_PADDLE) PORT_SENSITIVITY(25) PORT_KEYDELTA(25) PORT_CENTERDELTA(0) PORT_MINMAX(0x62,0xf2) PORT_PLAYER(2) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x04) |
| 259 | PORT_START("PADDLE_BUTTON") |
| 260 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON1) PORT_NAME("Paddle button") PORT_PLAYER(2) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x04) |
| 261 | INPUT_PORTS_END |
| 262 | |
| 263 | static INPUT_PORTS_START( fc_cclimb ) |
| 264 | PORT_START("CC_LEFT") |
| 265 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 266 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 267 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 268 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_START ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 269 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICKLEFT_UP ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 270 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICKLEFT_DOWN ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 271 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICKLEFT_LEFT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 272 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICKLEFT_RIGHT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x000f, EQUALS, 0x0002) |
| 273 | |
| 274 | PORT_START("CC_RIGHT") |
| 275 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 276 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 277 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 278 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 279 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_JOYSTICKRIGHT_UP ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 280 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_JOYSTICKRIGHT_DOWN ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 281 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICKRIGHT_LEFT ) PORT_PLAYER(1) PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 282 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICKRIGHT_RIGHT ) PORT_PLAYER(1)PORT_CONDITION("CTRLSEL", 0x00f0, EQUALS, 0x0020) |
| 283 | INPUT_PORTS_END |
| 284 | |
| 285 | static INPUT_PORTS_START( fc_keyboard ) |
| 286 | PORT_START("FCKEY0") |
| 287 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F8) PORT_CHAR(UCHAR_MAMEKEY(F8)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 288 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_ENTER) PORT_CHAR(13) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 289 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_CLOSEBRACE) PORT_CHAR('[') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 290 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_BACKSLASH) PORT_CHAR(']') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 291 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Kana") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 292 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_RSHIFT) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 293 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_BACKSLASH2) PORT_CHAR('\\') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 294 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Stop") PORT_CODE(KEYCODE_BACKSPACE) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 295 | |
| 296 | PORT_START("FCKEY1") |
| 297 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F7) PORT_CHAR(UCHAR_MAMEKEY(F7)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 298 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_OPENBRACE) PORT_CHAR('@') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 299 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_COLON) PORT_CHAR(':') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 300 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_QUOTE) PORT_CHAR(';') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 301 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CHAR('_') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 302 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CHAR('/') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 303 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_MINUS) PORT_CHAR('-') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 304 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_EQUALS) PORT_CHAR('^') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 305 | |
| 306 | PORT_START("FCKEY2") |
| 307 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F6) PORT_CHAR(UCHAR_MAMEKEY(F6)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 308 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_O) PORT_CHAR('O') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 309 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_L) PORT_CHAR('L') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 310 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_K) PORT_CHAR('K') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 311 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_STOP) PORT_CHAR('.') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 312 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_COMMA) PORT_CHAR(',') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 313 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_P) PORT_CHAR('P') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 314 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_0) PORT_CHAR('0') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 315 | |
| 316 | PORT_START("FCKEY3") |
| 317 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F5) PORT_CHAR(UCHAR_MAMEKEY(F5)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 318 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_I) PORT_CHAR('I') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 319 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_U) PORT_CHAR('U') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 320 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_J) PORT_CHAR('J') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 321 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_M) PORT_CHAR('M') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 322 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_N) PORT_CHAR('N') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 323 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_9) PORT_CHAR('9') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 324 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_8) PORT_CHAR('8') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 325 | |
| 326 | PORT_START("FCKEY4") |
| 327 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F4) PORT_CHAR(UCHAR_MAMEKEY(F4)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 328 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_Y) PORT_CHAR('Y') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 329 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_G) PORT_CHAR('G') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 330 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_H) PORT_CHAR('H') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 331 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_B) PORT_CHAR('B') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 332 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_V) PORT_CHAR('V') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 333 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_7) PORT_CHAR('7') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 334 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_6) PORT_CHAR('6') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 335 | |
| 336 | PORT_START("FCKEY5") |
| 337 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F3) PORT_CHAR(UCHAR_MAMEKEY(F3)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 338 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_T) PORT_CHAR('T') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 339 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_R) PORT_CHAR('R') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 340 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_D) PORT_CHAR('D') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 341 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F) PORT_CHAR('F') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 342 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_C) PORT_CHAR('C') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 343 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_5) PORT_CHAR('5') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 344 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_4) PORT_CHAR('4') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 345 | |
| 346 | PORT_START("FCKEY6") |
| 347 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F2) PORT_CHAR(UCHAR_MAMEKEY(F2)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 348 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_W) PORT_CHAR('W') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 349 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_S) PORT_CHAR('S') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 350 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_A) PORT_CHAR('A') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 351 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_X) PORT_CHAR('X') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 352 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_Z) PORT_CHAR('Z') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 353 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_E) PORT_CHAR('E') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 354 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_3) PORT_CHAR('3') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 355 | |
| 356 | PORT_START("FCKEY7") |
| 357 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F1) PORT_CHAR(UCHAR_MAMEKEY(F1)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 358 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_TAB) PORT_CHAR(UCHAR_MAMEKEY(ESC)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 359 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_Q) PORT_CHAR('Q') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 360 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_LCONTROL) PORT_CHAR(UCHAR_SHIFT_2) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 361 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_LSHIFT) PORT_CHAR(UCHAR_SHIFT_1) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 362 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Grph") PORT_CODE(KEYCODE_LALT) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 363 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_1) PORT_CHAR('1') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 364 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_2) PORT_CHAR('2') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 365 | |
| 366 | PORT_START("FCKEY8") |
| 367 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Clr") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 368 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_UP) PORT_CHAR(UCHAR_MAMEKEY(UP)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 369 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_RIGHT) PORT_CHAR(UCHAR_MAMEKEY(RIGHT)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 370 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_LEFT) PORT_CHAR(UCHAR_MAMEKEY(LEFT)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 371 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_DOWN) PORT_CHAR(UCHAR_MAMEKEY(DOWN)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 372 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_SPACE) PORT_CHAR(' ') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 373 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Del") PORT_CODE(KEYCODE_DEL) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 374 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Ins") PORT_CODE(KEYCODE_INSERT) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x02) |
| 375 | |
| 376 | INPUT_PORTS_END |
| 377 | |
| 378 | static INPUT_PORTS_START( subor_keyboard ) |
| 379 | PORT_START("SUBKEY0") |
| 380 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_4) PORT_CHAR('4') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 381 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_G) PORT_CHAR('G') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 382 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F) PORT_CHAR('F') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 383 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_C) PORT_CHAR('C') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 384 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F2) PORT_CHAR(UCHAR_MAMEKEY(F2)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 385 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_E) PORT_CHAR('E') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 386 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_5) PORT_CHAR('5') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 387 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_V) PORT_CHAR('V') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 388 | |
| 389 | PORT_START("SUBKEY1") |
| 390 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_2) PORT_CHAR('2') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 391 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_D) PORT_CHAR('D') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 392 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_S) PORT_CHAR('S') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 393 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_END) PORT_CHAR(UCHAR_MAMEKEY(END)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 394 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F1) PORT_CHAR(UCHAR_MAMEKEY(F1)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 395 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_W) PORT_CHAR('W') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 396 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_3) PORT_CHAR('3') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 397 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_X) PORT_CHAR('X') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 398 | |
| 399 | PORT_START("SUBKEY2") |
| 400 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_INSERT) PORT_CHAR(UCHAR_MAMEKEY(INSERT)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 401 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_BACKSPACE) PORT_CHAR(8) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 402 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("NEXT") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 403 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_RIGHT) PORT_CHAR(UCHAR_MAMEKEY(RIGHT)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 404 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F8) PORT_CHAR(UCHAR_MAMEKEY(F8)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 405 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("PRIOR") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 406 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_DEL) PORT_CHAR(UCHAR_MAMEKEY(DEL)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 407 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_HOME) PORT_CHAR(UCHAR_MAMEKEY(HOME)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 408 | |
| 409 | PORT_START("SUBKEY3") |
| 410 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_9) PORT_CHAR('9') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 411 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_I) PORT_CHAR('I') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 412 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_L) PORT_CHAR('L') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 413 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_COMMA) PORT_CHAR(',') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 414 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F5) PORT_CHAR(UCHAR_MAMEKEY(F5)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 415 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_O) PORT_CHAR('O') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 416 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_0) PORT_CHAR('0') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 417 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_STOP) PORT_CHAR('.') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 418 | |
| 419 | PORT_START("SUBKEY4") |
| 420 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_CLOSEBRACE) PORT_CHAR(']') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 421 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_ENTER) PORT_CHAR(13) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 422 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_UP) PORT_CHAR(UCHAR_MAMEKEY(UP)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 423 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_LEFT) PORT_CHAR(UCHAR_MAMEKEY(LEFT)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 424 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F7) PORT_CHAR(UCHAR_MAMEKEY(F7)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 425 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_OPENBRACE) PORT_CHAR('[') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 426 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_BACKSLASH) PORT_CHAR('\\') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 427 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_DOWN) PORT_CHAR(UCHAR_MAMEKEY(DOWN)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 428 | |
| 429 | PORT_START("SUBKEY5") |
| 430 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_Q) PORT_CHAR('Q') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 431 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_CAPSLOCK) PORT_CHAR(UCHAR_MAMEKEY(CAPSLOCK)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 432 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_Z) PORT_CHAR('Z') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 433 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_TAB) PORT_CHAR('\t') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 434 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_ESC) PORT_CHAR(UCHAR_MAMEKEY(ESC)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 435 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_A) PORT_CHAR('A') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 436 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_1) PORT_CHAR('1') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 437 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_LCONTROL) PORT_CHAR(UCHAR_SHIFT_2) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 438 | |
| 439 | PORT_START("SUBKEY6") |
| 440 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_7) PORT_CHAR('7') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 441 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_Y) PORT_CHAR('Y') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 442 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_K) PORT_CHAR('K') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 443 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_M) PORT_CHAR('M') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 444 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F4) PORT_CHAR(UCHAR_MAMEKEY(F4)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 445 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_U) PORT_CHAR('U') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 446 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_8) PORT_CHAR('8') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 447 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_J) PORT_CHAR('J') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 448 | |
| 449 | PORT_START("SUBKEY7") |
| 450 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_MINUS) PORT_CHAR('-') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 451 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_COLON) PORT_CHAR(':') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 452 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_QUOTE) PORT_CHAR('\'') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 453 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_SLASH) PORT_CHAR('/') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 454 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F6) PORT_CHAR(UCHAR_MAMEKEY(F6)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 455 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_P) PORT_CHAR('P') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 456 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_EQUALS) PORT_CHAR('=') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 457 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_LSHIFT) PORT_CHAR(UCHAR_SHIFT_1) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 458 | |
| 459 | PORT_START("SUBKEY8") |
| 460 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_T) PORT_CHAR('T') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 461 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_H) PORT_CHAR('H') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 462 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_N) PORT_CHAR('N') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 463 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_SPACE) PORT_CHAR(' ') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 464 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F3) PORT_CHAR(UCHAR_MAMEKEY(F3)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 465 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_R) PORT_CHAR('R') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 466 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_6) PORT_CHAR('6') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 467 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_B) PORT_CHAR('B') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 468 | |
| 469 | PORT_START("SUBKEY9") |
| 470 | PORT_BIT( 0xff, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 471 | |
| 472 | PORT_START("SUBKEY10") |
| 473 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("LMENU") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 474 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_4_PAD) PORT_CHAR(UCHAR_MAMEKEY(4_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 475 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_7_PAD) PORT_CHAR(UCHAR_MAMEKEY(7_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 476 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F11) PORT_CHAR(UCHAR_MAMEKEY(F11)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 477 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F12) PORT_CHAR(UCHAR_MAMEKEY(F12)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 478 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_1_PAD) PORT_CHAR(UCHAR_MAMEKEY(1_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 479 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_2_PAD) PORT_CHAR(UCHAR_MAMEKEY(2_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 480 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_8_PAD) PORT_CHAR(UCHAR_MAMEKEY(8_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 481 | |
| 482 | PORT_START("SUBKEY11") |
| 483 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_MINUS_PAD)PORT_CHAR(UCHAR_MAMEKEY(MINUS_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 484 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_PLUS_PAD) PORT_CHAR(UCHAR_MAMEKEY(PLUS_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 485 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_ASTERISK) PORT_CHAR(UCHAR_MAMEKEY(ASTERISK)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 486 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_9_PAD) PORT_CHAR(UCHAR_MAMEKEY(9_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 487 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F10) PORT_CHAR(UCHAR_MAMEKEY(F10)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 488 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_5_PAD) PORT_CHAR(UCHAR_MAMEKEY(5_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 489 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_SLASH_PAD)PORT_CHAR(UCHAR_MAMEKEY(SLASH_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 490 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_NUMLOCK) PORT_CHAR(UCHAR_MAMEKEY(NUMLOCK)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 491 | |
| 492 | PORT_START("SUBKEY12") |
| 493 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_TILDE) PORT_CHAR('`') PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 494 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_6_PAD) PORT_CHAR(UCHAR_MAMEKEY(6_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 495 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("PAUSE") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 496 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("SPACE2") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 497 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_F9) PORT_CHAR(UCHAR_MAMEKEY(F9)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 498 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_3_PAD) PORT_CHAR(UCHAR_MAMEKEY(3_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 499 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_NAME("Keypad .") PORT_CODE(KEYCODE_DEL_PAD) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 500 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_KEYBOARD ) PORT_CODE(KEYCODE_0_PAD) PORT_CHAR(UCHAR_MAMEKEY(0_PAD)) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x03) |
| 501 | |
| 502 | INPUT_PORTS_END |
| 503 | |
| 504 | static INPUT_PORTS_START( mahjong_panel ) |
| 505 | PORT_START("MAH0") |
| 506 | PORT_BIT( 0xff, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 507 | |
| 508 | PORT_START("MAH1") |
| 509 | PORT_BIT( 0x03, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 510 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_MAHJONG_N ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 511 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_MAHJONG_M ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 512 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_MAHJONG_L ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 513 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_MAHJONG_K ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 514 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_MAHJONG_J ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 515 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_MAHJONG_I ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 516 | |
| 517 | PORT_START("MAH2") |
| 518 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_MAHJONG_H ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 519 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_MAHJONG_G ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 520 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_MAHJONG_F ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 521 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_MAHJONG_E ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 522 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_MAHJONG_D ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 523 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_MAHJONG_C ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 524 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_MAHJONG_B ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 525 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_MAHJONG_A ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 526 | |
| 527 | PORT_START("MAH3") |
| 528 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 529 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_MAHJONG_RON ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 530 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_MAHJONG_REACH ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 531 | PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_MAHJONG_CHI ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 532 | PORT_BIT( 0x10, IP_ACTIVE_HIGH, IPT_MAHJONG_PON ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 533 | PORT_BIT( 0x20, IP_ACTIVE_HIGH, IPT_MAHJONG_KAN ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 534 | PORT_BIT( 0x40, IP_ACTIVE_HIGH, IPT_SELECT ) PORT_NAME("P1 Mahjong Select") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 535 | PORT_BIT( 0x80, IP_ACTIVE_HIGH, IPT_START ) PORT_NAME("P1 Mahjong Start") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x07) |
| 536 | INPUT_PORTS_END |
| 537 | |
| 538 | // these are read differently than the powerpad inputs, but we share the tags, to reduce |
| 539 | static INPUT_PORTS_START( fc_ftrainer ) |
| 540 | // difference between the two sides is that we mirror the key mapping to match the real pad layout! |
| 541 | PORT_START("FT_COL0") |
| 542 | // side A layout |
| 543 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 544 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer Mid1") PORT_CODE(KEYCODE_J) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 545 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 546 | // side B layout |
| 547 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 12") PORT_CODE(KEYCODE_M) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 548 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 8") PORT_CODE(KEYCODE_J) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 549 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 4") PORT_CODE(KEYCODE_U) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 550 | |
| 551 | PORT_START("FT_COL1") |
| 552 | // side A layout |
| 553 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer Low1") PORT_CODE(KEYCODE_N) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 554 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer Mid2") PORT_CODE(KEYCODE_H) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 555 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer Top1") PORT_CODE(KEYCODE_Y) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 556 | // side B layout |
| 557 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 11") PORT_CODE(KEYCODE_N) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 558 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 7") PORT_CODE(KEYCODE_H) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 559 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 3") PORT_CODE(KEYCODE_Y) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 560 | |
| 561 | PORT_START("FT_COL2") |
| 562 | // side A layout |
| 563 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer Low2") PORT_CODE(KEYCODE_B) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 564 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer Mid3") PORT_CODE(KEYCODE_G) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 565 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer Top2") PORT_CODE(KEYCODE_T) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 566 | // side B layout |
| 567 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 10") PORT_CODE(KEYCODE_B) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 568 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 6") PORT_CODE(KEYCODE_G) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 569 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 2") PORT_CODE(KEYCODE_T) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 570 | |
| 571 | PORT_START("FT_COL3") |
| 572 | // side A layout |
| 573 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 574 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer Mid4") PORT_CODE(KEYCODE_F) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 575 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_UNUSED ) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x05) |
| 576 | // side B layout |
| 577 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 9") PORT_CODE(KEYCODE_V) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 578 | PORT_BIT( 0x02, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 5") PORT_CODE(KEYCODE_F) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 579 | PORT_BIT( 0x04, IP_ACTIVE_HIGH, IPT_KEYPAD ) PORT_NAME("Family Trainer 1") PORT_CODE(KEYCODE_R) PORT_CONDITION("EXP", 0x0f, EQUALS, 0x06) |
| 580 | INPUT_PORTS_END |
| 581 | |
| 582 | |
| 583 | |
| 62 | 584 | static INPUT_PORTS_START( famicom ) |
| 63 | | // input devices go through slot options |
| 585 | PORT_INCLUDE( fc_pads12 ) |
| 586 | PORT_INCLUDE( fc_pads34 ) |
| 587 | PORT_INCLUDE( fc_lightgun ) |
| 588 | // FIXME: was it possible to attache two paddles in a Famicom (as the Arkanoid 2 box suggests)?!? investigate... |
| 589 | PORT_INCLUDE( fc_paddle ) |
| 590 | // Crazy Climber is not really a separate controller, but a couple of small sticks to be |
| 591 | // put on top of d-pads of the regular controllers. Users should then control the game |
| 592 | // by using both controllers, turned 90 degrees, as a couple of dual sticks as in the arcade |
| 593 | PORT_INCLUDE( fc_cclimb ) |
| 594 | PORT_INCLUDE( fc_keyboard ) |
| 595 | PORT_INCLUDE( subor_keyboard ) |
| 596 | PORT_INCLUDE( mahjong_panel ) |
| 597 | PORT_INCLUDE( fc_ftrainer ) |
| 598 | |
| 599 | PORT_START("CTRLSEL") |
| 600 | PORT_CONFNAME( 0x000f, 0x0001, "P1 Controller") |
| 601 | PORT_CONFSETTING( 0x0000, "Unconnected" ) |
| 602 | PORT_CONFSETTING( 0x0001, "Gamepad" ) |
| 603 | PORT_CONFSETTING( 0x0002, "Crazy Climber pad (Left)" ) |
| 604 | PORT_CONFNAME( 0x00f0, 0x0010, "P2 Controller") |
| 605 | PORT_CONFSETTING( 0x0000, "Unconnected" ) |
| 606 | PORT_CONFSETTING( 0x0010, "Gamepad" ) |
| 607 | PORT_CONFSETTING( 0x0020, "Crazy Climber pad (Right)" ) |
| 608 | PORT_CONFSETTING( 0x00f0, "Gamepad (Older Version)" ) |
| 609 | PORT_CONFNAME( 0x0f00, 0x0000, "P3 Controller") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x08) |
| 610 | PORT_CONFSETTING( 0x0000, "Unconnected" ) |
| 611 | PORT_CONFSETTING( 0x0100, "Gamepad" ) |
| 612 | PORT_CONFNAME( 0xf000, 0x0000, "P4 Controller") PORT_CONDITION("EXP", 0x0f, EQUALS, 0x08) |
| 613 | PORT_CONFSETTING( 0x0000, "Unconnected" ) |
| 614 | PORT_CONFSETTING( 0x1000, "Gamepad" ) |
| 615 | |
| 616 | PORT_START("EXP") |
| 617 | PORT_CONFNAME( 0x0f, 0x00, "Expansion Port") |
| 618 | PORT_CONFSETTING( 0x00, "(Empty)" ) |
| 619 | PORT_CONFSETTING( 0x01, "Light Gun" ) |
| 620 | PORT_CONFSETTING( 0x02, "FC Keyboard" ) |
| 621 | PORT_CONFSETTING( 0x03, "Subor Keyboard" ) |
| 622 | PORT_CONFSETTING( 0x04, "Arkanoid paddle" ) |
| 623 | PORT_CONFSETTING( 0x05, "Family Trainer (Side A)" ) |
| 624 | PORT_CONFSETTING( 0x06, "Family Trainer (Side B)" ) |
| 625 | PORT_CONFSETTING( 0x07, "Mahjong Panel" ) |
| 626 | PORT_CONFSETTING( 0x08, "Hori Twin Adapter" ) |
| 627 | |
| 64 | 628 | PORT_START("CONFIG") |
| 65 | 629 | PORT_CONFNAME( 0x01, 0x00, "Draw Top/Bottom 8 Lines") |
| 66 | 630 | PORT_CONFSETTING( 0x01, DEF_STR(No) ) |
| r243148 | r243149 | |
| 70 | 634 | PORT_CONFSETTING( 0x00, DEF_STR(Yes) ) |
| 71 | 635 | |
| 72 | 636 | PORT_START("FLIPDISK") /* fake key */ |
| 73 | | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_OTHER) PORT_NAME("Change Disk Side") PORT_CODE(KEYCODE_SPACE) |
| 637 | PORT_BIT( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON3) PORT_NAME("Change Disk Side") |
| 74 | 638 | INPUT_PORTS_END |
| 75 | 639 | |
| 76 | 640 | |
| r243148 | r243149 | |
| 110 | 674 | MCFG_NES_APU_CPU("maincpu") |
| 111 | 675 | MCFG_SOUND_ROUTE(ALL_OUTPUTS, "mono", 0.90) |
| 112 | 676 | |
| 113 | | MCFG_NES_CONTROL_PORT_ADD("ctrl1", nes_control_port1_devices, "joypad") |
| 114 | | MCFG_NESCTRL_BRIGHTPIXEL_CB(nes_state, bright_pixel) |
| 115 | | MCFG_NES_CONTROL_PORT_ADD("ctrl2", nes_control_port2_devices, "joypad") |
| 116 | | MCFG_NESCTRL_BRIGHTPIXEL_CB(nes_state, bright_pixel) |
| 117 | | |
| 118 | 677 | MCFG_NES_CARTRIDGE_ADD("nes_slot", nes_cart, NULL) |
| 119 | 678 | MCFG_SOFTWARE_LIST_ADD("cart_list", "nes") |
| 120 | 679 | MCFG_SOFTWARE_LIST_ADD("ade_list", "nes_ade") // Camerica/Codemasters Aladdin Deck Enhancer mini-carts |
| r243148 | r243149 | |
| 170 | 729 | MACHINE_CONFIG_END |
| 171 | 730 | |
| 172 | 731 | static MACHINE_CONFIG_DERIVED( famicom, nes ) |
| 173 | | MCFG_DEVICE_REMOVE("ctrl1") |
| 174 | | MCFG_DEVICE_REMOVE("ctrl2") |
| 175 | | MCFG_NES_CONTROL_PORT_ADD("ctrl1", fc_control_port1_devices, "joypad") |
| 176 | | MCFG_NES_CONTROL_PORT_ADD("ctrl2", fc_control_port2_devices, "joypad") |
| 177 | | MCFG_FC_EXPANSION_PORT_ADD("exp", fc_expansion_devices, NULL) |
| 178 | | MCFG_NESCTRL_BRIGHTPIXEL_CB(nes_state, bright_pixel) |
| 732 | MCFG_CASSETTE_ADD( "tape" ) |
| 733 | MCFG_CASSETTE_DEFAULT_STATE(CASSETTE_STOPPED | CASSETTE_MOTOR_ENABLED | CASSETTE_SPEAKER_ENABLED) |
| 734 | MCFG_CASSETTE_INTERFACE("fc_cass") |
| 179 | 735 | |
| 180 | 736 | MCFG_SOFTWARE_LIST_ADD("flop_list", "famicom_flop") |
| 181 | 737 | MCFG_SOFTWARE_LIST_ADD("cass_list", "famicom_cass") |
| r243148 | r243149 | |
| 213 | 769 | MACHINE_START_MEMBER( nes_state, fds ) |
| 214 | 770 | { |
| 215 | 771 | m_ciram = auto_alloc_array(machine(), UINT8, 0x800); |
| 772 | setup_ioports(); |
| 216 | 773 | setup_disk(m_disk); |
| 217 | | |
| 218 | | // register saves |
| 219 | | save_item(NAME(m_last_frame_flip)); |
| 220 | | save_pointer(NAME(m_ciram), 0x800); |
| 774 | state_register(); |
| 221 | 775 | } |
| 222 | 776 | |
| 223 | 777 | MACHINE_RESET_MEMBER( nes_state, fds ) |
| r243148 | r243149 | |
| 227 | 781 | |
| 228 | 782 | // the rest is the same as for nes/famicom/dendy |
| 229 | 783 | m_maincpu->reset(); |
| 784 | |
| 785 | memset(m_pad_latch, 0, sizeof(m_pad_latch)); |
| 786 | memset(m_zapper_latch, 0, sizeof(m_zapper_latch)); |
| 787 | m_paddle_latch = 0; |
| 788 | m_paddle_btn_latch = 0; |
| 230 | 789 | } |
| 231 | 790 | |
| 232 | 791 | static MACHINE_CONFIG_DERIVED( fds, famicom ) |
| 233 | 792 | MCFG_MACHINE_START_OVERRIDE( nes_state, fds ) |
| 234 | 793 | MCFG_MACHINE_RESET_OVERRIDE( nes_state, fds ) |
| 794 | MCFG_DEVICE_REMOVE("tape") |
| 235 | 795 | |
| 236 | 796 | MCFG_DEVICE_REMOVE("nes_slot") |
| 237 | 797 | MCFG_DEVICE_ADD("disk", NES_DISKSYS, 0) |
| r243148 | r243149 | |
| 267 | 827 | |
| 268 | 828 | // the rest is the same as for nes/famicom/dendy |
| 269 | 829 | m_maincpu->reset(); |
| 830 | |
| 831 | memset(m_pad_latch, 0, sizeof(m_pad_latch)); |
| 832 | memset(m_zapper_latch, 0, sizeof(m_zapper_latch)); |
| 833 | m_paddle_latch = 0; |
| 834 | m_paddle_btn_latch = 0; |
| 270 | 835 | } |
| 271 | 836 | |
| 272 | 837 | static MACHINE_CONFIG_DERIVED( famitwin, famicom ) |
trunk/src/mess/machine/nes.c
| r243148 | r243149 | |
| 7 | 7 | ****************************************************************************/ |
| 8 | 8 | |
| 9 | 9 | #include "emu.h" |
| 10 | #include "crsshair.h" |
| 10 | 11 | #include "cpu/m6502/m6502.h" |
| 11 | 12 | #include "includes/nes.h" |
| 13 | #include "imagedev/flopdrv.h" |
| 12 | 14 | |
| 13 | 15 | /*************************************************************************** |
| 16 | CONSTANTS |
| 17 | ***************************************************************************/ |
| 18 | |
| 19 | /* Set to dump info about the inputs to the errorlog */ |
| 20 | #define LOG_JOY 0 |
| 21 | |
| 22 | /* Set to generate prg & chr files when the cart is loaded */ |
| 23 | #define SPLIT_PRG 0 |
| 24 | #define SPLIT_CHR 0 |
| 25 | |
| 26 | /*************************************************************************** |
| 14 | 27 | FUNCTIONS |
| 15 | 28 | ***************************************************************************/ |
| 16 | 29 | |
| r243148 | r243149 | |
| 31 | 44 | m_cartslot->pcb_reset(); |
| 32 | 45 | |
| 33 | 46 | m_maincpu->reset(); |
| 47 | |
| 48 | memset(m_pad_latch, 0, sizeof(m_pad_latch)); |
| 49 | memset(m_zapper_latch, 0, sizeof(m_zapper_latch)); |
| 50 | m_paddle_latch = 0; |
| 51 | m_paddle_btn_latch = 0; |
| 34 | 52 | } |
| 35 | 53 | |
| 36 | 54 | //------------------------------------------------- |
| 37 | 55 | // machine_start |
| 38 | 56 | //------------------------------------------------- |
| 39 | 57 | |
| 58 | void nes_state::state_register() |
| 59 | { |
| 60 | save_item(NAME(m_last_frame_flip)); |
| 61 | |
| 62 | save_pointer(NAME(m_ciram), 0x800); |
| 63 | |
| 64 | save_item(NAME(m_pad_latch)); |
| 65 | save_item(NAME(m_zapper_latch)); |
| 66 | save_item(NAME(m_paddle_latch)); |
| 67 | save_item(NAME(m_paddle_btn_latch)); |
| 68 | save_item(NAME(m_mjpanel_latch)); |
| 69 | save_item(NAME(m_fck_scan)); |
| 70 | save_item(NAME(m_fck_mode)); |
| 71 | save_item(NAME(m_mic_obstruct)); |
| 72 | save_item(NAME(m_powerpad_latch)); |
| 73 | save_item(NAME(m_ftrainer_scan)); |
| 74 | } |
| 75 | |
| 76 | void nes_state::setup_ioports() |
| 77 | { |
| 78 | for (int i = 0; i < 9; i++) |
| 79 | { |
| 80 | char str[7]; |
| 81 | sprintf(str, "FCKEY%i", i); |
| 82 | m_io_fckey[i] = ioport(str); |
| 83 | } |
| 84 | for (int i = 0; i < 13; i++) |
| 85 | { |
| 86 | char str[9]; |
| 87 | sprintf(str, "SUBKEY%i", i); |
| 88 | m_io_subkey[i] = ioport(str); |
| 89 | } |
| 90 | for (int i = 0; i < 4; i++) |
| 91 | { |
| 92 | char str[8]; |
| 93 | sprintf(str, "PAD%i", i + 1); |
| 94 | m_io_pad[i] = ioport(str); |
| 95 | sprintf(str, "MAH%i", i); |
| 96 | m_io_mahjong[i] = ioport(str); |
| 97 | sprintf(str, "FT_COL%i", i); |
| 98 | m_io_ftrainer[i] = ioport(str); |
| 99 | } |
| 100 | |
| 101 | m_io_ctrlsel = ioport("CTRLSEL"); |
| 102 | m_io_exp = ioport("EXP"); |
| 103 | m_io_paddle = ioport("PADDLE"); |
| 104 | m_io_paddle_btn = ioport("PADDLE_BUTTON"); |
| 105 | m_io_cc_left = ioport("CC_LEFT"); |
| 106 | m_io_cc_right = ioport("CC_RIGHT"); |
| 107 | m_io_zapper1_t = ioport("ZAPPER1_T"); |
| 108 | m_io_zapper1_x = ioport("ZAPPER1_X"); |
| 109 | m_io_zapper1_y = ioport("ZAPPER1_Y"); |
| 110 | m_io_zapper2_t = ioport("ZAPPER2_T"); |
| 111 | m_io_zapper2_x = ioport("ZAPPER2_X"); |
| 112 | m_io_zapper2_y = ioport("ZAPPER2_Y"); |
| 113 | m_io_powerpad[0] = ioport("POWERPAD1"); |
| 114 | m_io_powerpad[1] = ioport("POWERPAD2"); |
| 115 | m_io_disksel = ioport("FLIPDISK"); |
| 116 | } |
| 117 | |
| 40 | 118 | void nes_state::machine_start() |
| 41 | 119 | { |
| 42 | 120 | address_space &space = m_maincpu->space(AS_PROGRAM); |
| r243148 | r243149 | |
| 48 | 126 | m_ciram = auto_alloc_array(machine(), UINT8, 0x800); |
| 49 | 127 | // other pointers got set in the loading routine, because they 'belong' to the cart itself |
| 50 | 128 | |
| 51 | | m_io_disksel = ioport("FLIPDISK"); |
| 129 | setup_ioports(); |
| 52 | 130 | |
| 53 | 131 | if (m_cartslot && m_cartslot->m_cart) |
| 54 | 132 | { |
| r243148 | r243149 | |
| 100 | 178 | m_cartslot->m_cart->pcb_reg_postload(machine()); |
| 101 | 179 | } |
| 102 | 180 | |
| 103 | | // register saves |
| 104 | | save_item(NAME(m_last_frame_flip)); |
| 105 | | save_pointer(NAME(m_ciram), 0x800); |
| 181 | state_register(); |
| 106 | 182 | } |
| 107 | 183 | |
| 108 | 184 | |
| r243148 | r243149 | |
| 112 | 188 | |
| 113 | 189 | READ8_MEMBER(nes_state::nes_in0_r) |
| 114 | 190 | { |
| 191 | int cfg = m_io_ctrlsel->read(); |
| 192 | |
| 193 | // Some games expect bit 6 to be set because the last entry on the data bus shows up |
| 194 | // in the unused upper 3 bits, so typically a read from $4016 leaves 0x40 there. |
| 115 | 195 | UINT8 ret = 0x40; |
| 116 | | ret |= m_ctrl1->read_bit0(); |
| 117 | | ret |= m_ctrl1->read_bit34(); |
| 196 | ret |= (m_pad_latch[0] & 0x01); |
| 197 | |
| 198 | // shift |
| 199 | m_pad_latch[0] >>= 1; |
| 200 | |
| 201 | // zapper |
| 202 | if ((cfg & 0x000f) == 0x0002) |
| 203 | { |
| 204 | int x = m_zapper_latch[0][1]; // x-position |
| 205 | int y = m_zapper_latch[0][2]; // y-position |
| 206 | UINT32 pix, color_base; |
| 207 | |
| 208 | // get the pixel at the gun position |
| 209 | pix = m_ppu->get_pixel(x, y); |
| 210 | |
| 211 | // get the color base from the ppu |
| 212 | color_base = m_ppu->get_colorbase(); |
| 213 | |
| 214 | // check if the cursor is over a bright pixel |
| 215 | if ((pix == color_base + 0x20) || (pix == color_base + 0x30) || |
| 216 | (pix == color_base + 0x33) || (pix == color_base + 0x34)) |
| 217 | ret &= ~0x08; // sprite hit |
| 218 | else |
| 219 | ret |= 0x08; // no sprite hit |
| 220 | |
| 221 | // light gun trigger |
| 222 | ret |= (m_zapper_latch[0][0] << 4); |
| 223 | } |
| 224 | |
| 225 | if (LOG_JOY) |
| 226 | logerror("joy 0 read, val: %02x, pc: %04x\n", ret, space.device().safe_pc()); |
| 227 | |
| 118 | 228 | return ret; |
| 119 | 229 | } |
| 120 | 230 | |
| 121 | 231 | READ8_MEMBER(nes_state::nes_in1_r) |
| 122 | 232 | { |
| 233 | int cfg = m_io_ctrlsel->read(); |
| 234 | |
| 235 | // Some games expect bit 6 to be set because the last entry on the data bus shows up |
| 236 | // in the unused upper 3 bits, so typically a read from $4017 leaves 0x40 there. |
| 123 | 237 | UINT8 ret = 0x40; |
| 124 | | ret |= m_ctrl2->read_bit0(); |
| 125 | | ret |= m_ctrl2->read_bit34(); |
| 238 | ret |= (m_pad_latch[1] & 0x01); |
| 239 | |
| 240 | // shift |
| 241 | m_pad_latch[1] >>= 1; |
| 242 | |
| 243 | // zapper |
| 244 | if ((cfg & 0x00f0) == 0x0020) |
| 245 | { |
| 246 | int x = m_zapper_latch[1][1]; // x-position |
| 247 | int y = m_zapper_latch[1][2]; // y-position |
| 248 | UINT32 pix, color_base; |
| 249 | |
| 250 | // get the pixel at the gun position |
| 251 | pix = m_ppu->get_pixel(x, y); |
| 252 | |
| 253 | // get the color base from the ppu |
| 254 | color_base = m_ppu->get_colorbase(); |
| 255 | |
| 256 | // check if the cursor is over a bright pixel |
| 257 | if ((pix == color_base + 0x20) || (pix == color_base + 0x30) || |
| 258 | (pix == color_base + 0x33) || (pix == color_base + 0x34)) |
| 259 | ret &= ~0x08; // sprite hit |
| 260 | else |
| 261 | ret |= 0x08; // no sprite hit |
| 262 | |
| 263 | // light gun trigger |
| 264 | ret |= (m_zapper_latch[1][0] << 4); |
| 265 | } |
| 266 | |
| 267 | // arkanoid paddle |
| 268 | if ((cfg & 0x00f0) == 0x0040) |
| 269 | { |
| 270 | ret |= (m_paddle_btn_latch << 3); // button |
| 271 | ret |= ((m_paddle_latch & 0x80) >> 3); // paddle data |
| 272 | m_paddle_latch <<= 1; |
| 273 | m_paddle_latch &= 0xff; |
| 274 | } |
| 275 | |
| 276 | // powerpad |
| 277 | if ((cfg & 0x00f0) == 0x0050 || (cfg & 0x00f0) == 0x0060) |
| 278 | { |
| 279 | ret |= ((m_powerpad_latch[0] & 0x01) << 3); |
| 280 | ret |= ((m_powerpad_latch[1] & 0x01) << 4); |
| 281 | m_powerpad_latch[0] >>= 1; |
| 282 | m_powerpad_latch[1] >>= 1; |
| 283 | } |
| 284 | |
| 285 | if (LOG_JOY) |
| 286 | logerror("joy 1 read, val: %02x, pc: %04x\n", ret, space.device().safe_pc()); |
| 287 | |
| 126 | 288 | return ret; |
| 127 | 289 | } |
| 128 | 290 | |
| 129 | 291 | WRITE8_MEMBER(nes_state::nes_in0_w) |
| 130 | 292 | { |
| 131 | | m_ctrl1->write(data); |
| 132 | | m_ctrl2->write(data); |
| 293 | int cfg = m_io_ctrlsel->read(); |
| 294 | |
| 295 | if (LOG_JOY) |
| 296 | logerror("joy write, val: %02x, pc: %04x\n", data, space.device().safe_pc()); |
| 297 | |
| 298 | // Check if lightgun has been chosen as input: if so, enable crosshair |
| 299 | timer_set(attotime::zero, TIMER_ZAPPER_TICK); |
| 300 | |
| 301 | if (data & 0x01) |
| 302 | return; |
| 303 | |
| 304 | // Toggling bit 0 high then low resets controllers |
| 305 | m_pad_latch[0] = 0; |
| 306 | m_pad_latch[1] = 0; |
| 307 | m_zapper_latch[0][0] = 0; |
| 308 | m_zapper_latch[0][1] = 0; |
| 309 | m_zapper_latch[0][2] = 0; |
| 310 | m_zapper_latch[1][0] = 0; |
| 311 | m_zapper_latch[1][1] = 0; |
| 312 | m_zapper_latch[1][2] = 0; |
| 313 | m_paddle_btn_latch = 0; |
| 314 | m_paddle_latch = 0; |
| 315 | m_powerpad_latch[0] = 0; |
| 316 | m_powerpad_latch[1] = 0; |
| 317 | |
| 318 | // P1 inputs |
| 319 | switch (cfg & 0x000f) |
| 320 | { |
| 321 | case 0x01: // pad 1 |
| 322 | m_pad_latch[0] = m_io_pad[0]->read(); |
| 323 | break; |
| 324 | |
| 325 | case 0x02: // zapper (secondary) |
| 326 | m_zapper_latch[0][0] = m_io_zapper1_t->read(); |
| 327 | m_zapper_latch[0][1] = m_io_zapper1_x->read(); |
| 328 | m_zapper_latch[0][2] = m_io_zapper1_y->read(); |
| 329 | break; |
| 330 | } |
| 331 | |
| 332 | // P2 inputs |
| 333 | switch ((cfg & 0x00f0) >> 4) |
| 334 | { |
| 335 | case 0x01: // pad 2 |
| 336 | m_pad_latch[1] = m_io_pad[1]->read(); |
| 337 | break; |
| 338 | |
| 339 | case 0x02: // zapper (primary) - most games expect pad in port1 & zapper in port2 |
| 340 | m_zapper_latch[1][0] = m_io_zapper2_t->read(); |
| 341 | m_zapper_latch[1][1] = m_io_zapper2_x->read(); |
| 342 | m_zapper_latch[1][2] = m_io_zapper2_y->read(); |
| 343 | break; |
| 344 | |
| 345 | case 0x04: // arkanoid paddle |
| 346 | m_paddle_btn_latch = m_io_paddle_btn->read(); |
| 347 | m_paddle_latch = (UINT8) (m_io_paddle->read() ^ 0xff); |
| 348 | break; |
| 349 | |
| 350 | case 0x05: // power pad |
| 351 | case 0x06: // power pad |
| 352 | m_powerpad_latch[0] = m_io_powerpad[0]->read(); |
| 353 | m_powerpad_latch[1] = m_io_powerpad[1]->read() | 0xf0; |
| 354 | break; |
| 355 | } |
| 356 | |
| 357 | // P3 & P4 inputs in NES Four Score are read serially with P1 & P2 |
| 358 | // P3 inputs |
| 359 | if ((cfg & 0x0f00)) |
| 360 | m_pad_latch[0] |= ((m_io_pad[2]->read() << 8) | (0x08 << 16)); // pad 3 + signature |
| 361 | |
| 362 | // P4 inputs |
| 363 | if ((cfg & 0xf000)) |
| 364 | m_pad_latch[1] |= ((m_io_pad[3]->read() << 8) | (0x04 << 16)); // pad 4 + signature |
| 133 | 365 | } |
| 134 | 366 | |
| 135 | 367 | |
| 368 | WRITE8_MEMBER(nes_state::nes_in1_w) |
| 369 | { |
| 370 | } |
| 371 | |
| 372 | |
| 136 | 373 | READ8_MEMBER(nes_state::fc_in0_r) |
| 137 | 374 | { |
| 375 | int cfg = m_io_ctrlsel->read(); |
| 376 | int exp = m_io_exp->read(); |
| 377 | |
| 378 | // Some games expect bit 6 to be set because the last entry on the data bus shows up |
| 379 | // in the unused upper 3 bits, so typically a read from $4016 leaves 0x40 there. |
| 138 | 380 | UINT8 ret = 0x40; |
| 139 | | // bit 0 to controller port |
| 140 | | ret |= m_ctrl1->read_bit0(); |
| 381 | ret |= (m_pad_latch[0] & 0x01); |
| 141 | 382 | |
| 142 | | // expansion port bits (in the original FC, P2 controller was hooked to these lines |
| 143 | | // too, so in principle some homebrew hardware modification could use the same |
| 144 | | // connection with P1 controller too) |
| 145 | | ret |= m_ctrl1->read_exp(0); |
| 146 | | ret |= m_ctrl2->read_exp(0); |
| 383 | // shift |
| 384 | m_pad_latch[0] >>= 1; |
| 147 | 385 | |
| 148 | | // at the same time, we might have a standard joypad connected to the expansion port which |
| 149 | | // shall be read as P3 (this is needed here to avoid implementing the expansion port as a |
| 150 | | // different device compared to the standard control port... it might be changed later) |
| 151 | | ret |= (m_exp->read_bit0() << 1); |
| 152 | | // finally, read the expansion port as expected |
| 153 | | ret |= m_exp->read_exp(0); |
| 386 | // microphone bit |
| 387 | if ((cfg & 0x00f0) == 0x00f0) |
| 388 | ret |= m_mic_obstruct; //bit2! |
| 389 | |
| 390 | // EXP input |
| 391 | switch (exp & 0x0f) |
| 392 | { |
| 393 | case 0x02: // FC Keyboard: tape input |
| 394 | if ((m_cassette->get_state() & CASSETTE_MASK_UISTATE) == CASSETTE_PLAY) |
| 395 | { |
| 396 | double level = m_cassette->input(); |
| 397 | if (level < 0) |
| 398 | ret |= 0x00; |
| 399 | else |
| 400 | ret |= 0x02; |
| 401 | } |
| 402 | break; |
| 403 | |
| 404 | case 0x04: // Arkanoid paddle |
| 405 | ret |= (m_paddle_btn_latch << 1); // button |
| 406 | break; |
| 407 | |
| 408 | case 0x07: // Mahjong Panel |
| 409 | ret |= ((m_mjpanel_latch & 0x01) << 1); |
| 410 | m_mjpanel_latch >>= 1; |
| 411 | break; |
| 412 | |
| 413 | case 0x08: // 'multitap' p3 |
| 414 | ret |= ((m_pad_latch[2] & 0x01) << 1); |
| 415 | m_pad_latch[2] >>= 1; |
| 416 | break; |
| 417 | } |
| 418 | |
| 419 | if (LOG_JOY) |
| 420 | logerror("joy 0 read, val: %02x, pc: %04x\n", ret, space.device().safe_pc()); |
| 421 | |
| 154 | 422 | return ret; |
| 155 | 423 | } |
| 156 | 424 | |
| 157 | 425 | READ8_MEMBER(nes_state::fc_in1_r) |
| 158 | 426 | { |
| 427 | int exp = m_io_exp->read(); |
| 428 | |
| 429 | // Some games expect bit 6 to be set because the last entry on the data bus shows up |
| 430 | // in the unused upper 3 bits, so typically a read from $4017 leaves 0x40 there. |
| 159 | 431 | UINT8 ret = 0x40; |
| 160 | | // bit 0 to controller port |
| 161 | | ret |= m_ctrl2->read_bit0(); |
| 432 | ret |= (m_pad_latch[1] & 0x01); |
| 162 | 433 | |
| 163 | | // expansion port bits (in the original FC, P2 controller was hooked to these lines |
| 164 | | // too, so in principle some homebrew hardware modification could use the same |
| 165 | | // connection with P1 controller too) |
| 166 | | ret |= m_ctrl1->read_exp(1); |
| 167 | | ret |= m_ctrl2->read_exp(1); |
| 434 | // shift |
| 435 | m_pad_latch[1] >>= 1; |
| 168 | 436 | |
| 169 | | // finally, read the expansion port as expected (standard pad cannot be hooked as P4, so |
| 170 | | // no read_bit0 here) |
| 171 | | ret |= m_exp->read_exp(1); |
| 437 | |
| 438 | // EXP input |
| 439 | switch (exp & 0x0f) |
| 440 | { |
| 441 | case 0x01: // Lightgun |
| 442 | { |
| 443 | int x = m_zapper_latch[0][1]; // x-position |
| 444 | int y = m_zapper_latch[0][2]; // y-position |
| 445 | UINT32 pix, color_base; |
| 446 | |
| 447 | // get the pixel at the gun position |
| 448 | pix = m_ppu->get_pixel(x, y); |
| 449 | |
| 450 | // get the color base from the ppu |
| 451 | color_base = m_ppu->get_colorbase(); |
| 452 | |
| 453 | // check if the cursor is over a bright pixel |
| 454 | if ((pix == color_base + 0x20) || (pix == color_base + 0x30) || |
| 455 | (pix == color_base + 0x33) || (pix == color_base + 0x34)) |
| 456 | ret &= ~0x08; // sprite hit |
| 457 | else |
| 458 | ret |= 0x08; // no sprite hit |
| 459 | |
| 460 | // light gun trigger |
| 461 | ret |= (m_zapper_latch[0][0] << 4); |
| 462 | } |
| 463 | break; |
| 464 | |
| 465 | case 0x02: // FC Keyboard: rows of the keyboard matrix are read 4-bits at time and returned as bit1->bit4 |
| 466 | if (m_fck_scan < 9) |
| 467 | ret |= ~(((m_io_fckey[m_fck_scan]->read() >> (m_fck_mode * 4)) & 0x0f) << 1) & 0x1e; |
| 468 | else |
| 469 | ret |= 0x1e; |
| 470 | break; |
| 471 | |
| 472 | case 0x03: // Subor Keyboard: rows of the keyboard matrix are read 4-bits at time and returned as bit1->bit4 |
| 473 | if (m_fck_scan < 12) |
| 474 | ret |= ~(((m_io_subkey[m_fck_scan]->read() >> (m_fck_mode * 4)) & 0x0f) << 1) & 0x1e; |
| 475 | else |
| 476 | ret |= 0x1e; |
| 477 | break; |
| 478 | |
| 479 | case 0x04: // Arkanoid paddle |
| 480 | ret |= ((m_paddle_latch & 0x80) >> 6); // paddle data |
| 481 | m_paddle_latch <<= 1; |
| 482 | m_paddle_latch &= 0xff; |
| 483 | break; |
| 484 | |
| 485 | case 0x05: // family trainer |
| 486 | case 0x06: // family trainer |
| 487 | if (!BIT(m_ftrainer_scan, 0)) |
| 488 | { |
| 489 | // read low line: buttons 9,10,11,12 |
| 490 | for (int i = 0; i < 4; i++) |
| 491 | ret |= ((m_io_ftrainer[i]->read() & 0x01) << (1 + i)); |
| 492 | } |
| 493 | else if (!BIT(m_ftrainer_scan, 1)) |
| 494 | { |
| 495 | // read mid line: buttons 5,6,7,8 |
| 496 | for (int i = 0; i < 4; i++) |
| 497 | ret |= ((m_io_ftrainer[i]->read() & 0x02) << (1 + i)); |
| 498 | } |
| 499 | else if (!BIT(m_ftrainer_scan, 2)) |
| 500 | { |
| 501 | // read high line: buttons 1,2,3,4 |
| 502 | for (int i = 0; i < 4; i++) |
| 503 | ret |= ((m_io_ftrainer[i]->read() & 0x04) << (1 + i)); |
| 504 | } |
| 505 | break; |
| 506 | |
| 507 | case 0x07: // Mahjong Panel |
| 508 | ret |= ((m_mjpanel_latch & 0x01) << 1); |
| 509 | m_mjpanel_latch >>= 1; |
| 510 | break; |
| 511 | |
| 512 | case 0x08: // 'multitap' p4 |
| 513 | ret |= ((m_pad_latch[3] & 0x01) << 1); |
| 514 | m_pad_latch[3] >>= 1; |
| 515 | break; |
| 516 | } |
| 517 | |
| 518 | if (LOG_JOY) |
| 519 | logerror("joy 1 read, val: %02x, pc: %04x\n", ret, space.device().safe_pc()); |
| 520 | |
| 172 | 521 | return ret; |
| 173 | 522 | } |
| 174 | 523 | |
| 175 | 524 | WRITE8_MEMBER(nes_state::fc_in0_w) |
| 176 | 525 | { |
| 177 | | m_ctrl1->write(data); |
| 178 | | m_ctrl2->write(data); |
| 179 | | m_exp->write(data); |
| 526 | int cfg = m_io_ctrlsel->read(); |
| 527 | int exp = m_io_exp->read(); |
| 528 | |
| 529 | if (LOG_JOY) |
| 530 | logerror("joy write, val: %02x, pc: %04x\n", data, space.device().safe_pc()); |
| 531 | |
| 532 | // Check if lightgun has been chosen as input: if so, enable crosshair |
| 533 | timer_set(attotime::zero, TIMER_LIGHTGUN_TICK); |
| 534 | |
| 535 | // keyboards |
| 536 | if ((exp & 0x0f) == 0x02 || (exp & 0x0f) == 0x03) |
| 537 | { |
| 538 | // tape output (not fully tested) |
| 539 | if ((m_cassette->get_state() & CASSETTE_MASK_UISTATE) == CASSETTE_RECORD) |
| 540 | m_cassette->output(((data & 0x07) == 0x07) ? +1.0 : -1.0); |
| 541 | |
| 542 | if (BIT(data, 2)) // keyboard active |
| 543 | { |
| 544 | int lines = ((exp & 0x0f) == 0x02) ? 9 : 12; |
| 545 | UINT8 out = BIT(data, 1); // scan |
| 546 | |
| 547 | if (m_fck_mode && !out && ++m_fck_scan > lines) |
| 548 | m_fck_scan = 0; |
| 549 | |
| 550 | m_fck_mode = out; // access lower or upper 4 bits |
| 551 | |
| 552 | if (BIT(data, 0)) // reset |
| 553 | m_fck_scan = 0; |
| 554 | } |
| 555 | } |
| 556 | |
| 557 | // family trainer |
| 558 | if ((exp & 0x0f) == 0x05 || (exp & 0x0f) == 0x06) |
| 559 | { |
| 560 | // select raw to scan |
| 561 | m_ftrainer_scan = data & 0x07; |
| 562 | } |
| 563 | |
| 564 | if (data & 0x01) |
| 565 | return; |
| 566 | |
| 567 | // Toggling bit 0 high then low resets controllers |
| 568 | m_pad_latch[0] = 0; |
| 569 | m_pad_latch[1] = 0; |
| 570 | m_pad_latch[2] = 0; |
| 571 | m_pad_latch[3] = 0; |
| 572 | m_zapper_latch[0][0] = 0; |
| 573 | m_zapper_latch[0][1] = 0; |
| 574 | m_zapper_latch[0][2] = 0; |
| 575 | m_paddle_btn_latch = 0; |
| 576 | m_paddle_latch = 0; |
| 577 | m_mjpanel_latch = 0; |
| 578 | m_mic_obstruct = 0; |
| 579 | |
| 580 | // P1 inputs |
| 581 | switch (cfg & 0x000f) |
| 582 | { |
| 583 | case 0x01: // pad 1 |
| 584 | m_pad_latch[0] = m_io_pad[0]->read(); |
| 585 | break; |
| 586 | |
| 587 | case 0x02: // crazy climber (left stick) |
| 588 | m_pad_latch[0] = m_io_cc_left->read(); |
| 589 | break; |
| 590 | } |
| 591 | |
| 592 | // P2 inputs |
| 593 | switch ((cfg & 0x00f0) >> 4) |
| 594 | { |
| 595 | case 0x01: // pad 2 |
| 596 | m_pad_latch[1] = m_io_pad[1]->read(); |
| 597 | break; |
| 598 | |
| 599 | case 0x02: // crazy climber (right stick) |
| 600 | m_pad_latch[1] = m_io_cc_right->read(); |
| 601 | break; |
| 602 | |
| 603 | case 0x0f: // pad 2 old style with microphone instead of START/SELECT keys |
| 604 | // we only emulate obstruction of mic (when you blow or talk into it) |
| 605 | m_mic_obstruct = m_io_pad[1]->read() & 0x04; |
| 606 | m_pad_latch[1] = (m_io_pad[1]->read() & ~0x04); |
| 607 | break; |
| 608 | } |
| 609 | |
| 610 | // P3 & P4 inputs in Famicom (e.g. through Hori Twin Adapter or Hori 4 Players Adapter) |
| 611 | // are read in parallel with P1 & P2 (just using diff bits) |
| 612 | // P3 inputs |
| 613 | if ((exp & 0x0f) == 8 && (cfg & 0x0f00) == 0x0100) |
| 614 | m_pad_latch[2] = m_io_pad[2]->read(); // pad 3 |
| 615 | |
| 616 | // P4 inputs |
| 617 | if ((exp & 0x0f) == 8 && (cfg & 0xf000) == 0x1000) |
| 618 | m_pad_latch[3] = m_io_pad[3]->read(); // pad 4 |
| 619 | |
| 620 | |
| 621 | // EXP input |
| 622 | switch (exp & 0x0f) |
| 623 | { |
| 624 | case 0x01: // Lightgun |
| 625 | m_zapper_latch[0][0] = m_io_zapper2_t->read(); |
| 626 | m_zapper_latch[0][1] = m_io_zapper2_x->read(); |
| 627 | m_zapper_latch[0][2] = m_io_zapper2_y->read(); |
| 628 | break; |
| 629 | |
| 630 | case 0x02: // FC Keyboard |
| 631 | case 0x03: // Subor Keyboard |
| 632 | // these are scanned differently than other devices: |
| 633 | // writes to $4016 with bit2 set always update the |
| 634 | // line counter and writing bit0 set resets the counter |
| 635 | break; |
| 636 | |
| 637 | case 0x04: // Arkanoid paddle |
| 638 | m_paddle_btn_latch = m_io_paddle_btn->read(); |
| 639 | m_paddle_latch = (UINT8) (m_io_paddle->read() ^ 0xff); |
| 640 | break; |
| 641 | |
| 642 | case 0x05: // family trainer |
| 643 | case 0x06: // family trainer |
| 644 | // these are scanned differently than other devices: |
| 645 | // bit0-bit2 of writes to $4016 select the row to read |
| 646 | // from from the mat input "columns" |
| 647 | break; |
| 648 | |
| 649 | |
| 650 | case 0x07: // Mahjong Panel |
| 651 | if (data & 0xf8) |
| 652 | logerror("Error: Mahjong panel read with mux data %02x\n", (data & 0xfe)); |
| 653 | else |
| 654 | m_mjpanel_latch = m_io_mahjong[(data & 0xfe) >> 1]->read(); |
| 655 | break; |
| 656 | } |
| 657 | |
| 180 | 658 | } |
| 181 | 659 | |
| 182 | 660 | |
| 661 | void nes_state::device_timer(emu_timer &timer, device_timer_id id, int param, void *ptr) |
| 662 | { |
| 663 | switch (id) |
| 664 | { |
| 665 | case TIMER_ZAPPER_TICK: |
| 666 | if ((m_io_ctrlsel->read() & 0x000f) == 0x0002) |
| 667 | { |
| 668 | /* enable lightpen crosshair */ |
| 669 | crosshair_set_screen(machine(), 0, CROSSHAIR_SCREEN_ALL); |
| 670 | } |
| 671 | else |
| 672 | { |
| 673 | /* disable lightpen crosshair */ |
| 674 | crosshair_set_screen(machine(), 0, CROSSHAIR_SCREEN_NONE); |
| 675 | } |
| 676 | |
| 677 | if ((m_io_ctrlsel->read() & 0x00f0) == 0x0020) |
| 678 | { |
| 679 | /* enable lightpen crosshair */ |
| 680 | crosshair_set_screen(machine(), 1, CROSSHAIR_SCREEN_ALL); |
| 681 | } |
| 682 | else |
| 683 | { |
| 684 | /* disable lightpen crosshair */ |
| 685 | crosshair_set_screen(machine(), 1, CROSSHAIR_SCREEN_NONE); |
| 686 | } |
| 687 | break; |
| 688 | case TIMER_LIGHTGUN_TICK: |
| 689 | if ((m_io_exp->read() & 0x0f) == 0x01) |
| 690 | { |
| 691 | /* enable lightpen crosshair */ |
| 692 | crosshair_set_screen(machine(), 0, CROSSHAIR_SCREEN_ALL); |
| 693 | } |
| 694 | else |
| 695 | { |
| 696 | /* disable lightpen crosshair */ |
| 697 | crosshair_set_screen(machine(), 0, CROSSHAIR_SCREEN_NONE); |
| 698 | } |
| 699 | break; |
| 700 | default: |
| 701 | assert_always(FALSE, "Unknown id in nes_state::device_timer"); |
| 702 | } |
| 703 | } |
| 704 | |
| 705 | |
| 183 | 706 | DRIVER_INIT_MEMBER(nes_state,famicom) |
| 184 | 707 | { |
| 185 | 708 | // setup alt input handlers for additional FC input devices |
| r243148 | r243149 | |
| 188 | 711 | space.install_write_handler(0x4016, 0x4016, write8_delegate(FUNC(nes_state::fc_in0_w), this)); |
| 189 | 712 | space.install_read_handler(0x4017, 0x4017, read8_delegate(FUNC(nes_state::fc_in1_r), this)); |
| 190 | 713 | } |
| 191 | | |
| 192 | | NESCTRL_BRIGHTPIXEL_CB(nes_state::bright_pixel) |
| 193 | | { |
| 194 | | // get the pixel at the gun position |
| 195 | | UINT32 pix = m_ppu->get_pixel(x, y); |
| 196 | | |
| 197 | | // get the color base from the ppu |
| 198 | | UINT32 color_base = m_ppu->get_colorbase(); |
| 199 | | |
| 200 | | // check if the cursor is over a bright pixel |
| 201 | | if ((pix == color_base + 0x20) || (pix == color_base + 0x30) || |
| 202 | | (pix == color_base + 0x33) || (pix == color_base + 0x34)) |
| 203 | | return true; |
| 204 | | else |
| 205 | | return false; |
| 206 | | } |