Mercurial > sdl-ios-xcode
comparison src/joystick/mint/SDL_sysjoystick.c @ 1662:782fd950bd46 SDL-1.3
Revamp of the video system in progress - adding support for multiple displays, multiple windows, and a full video mode selection API.
WARNING: None of the video drivers have been updated for the new API yet! The API is still under design and very fluid.
The code is now run through a consistent indent format:
indent -i4 -nut -nsc -br -ce
The headers are being converted to automatically generate doxygen documentation.
author | Sam Lantinga <slouken@libsdl.org> |
---|---|
date | Sun, 28 May 2006 13:04:16 +0000 |
parents | 92947e3a18db |
children | 4da1ee79c9af |
comparison
equal
deleted
inserted
replaced
1661:281d3f4870e5 | 1662:782fd950bd46 |
---|---|
50 or 1 lightpen on joypad port A | 50 or 1 lightpen on joypad port A |
51 or 2 analog paddles on joypads ports A,B | 51 or 2 analog paddles on joypads ports A,B |
52 2 joysticks on parallel port | 52 2 joysticks on parallel port |
53 */ | 53 */ |
54 | 54 |
55 enum { | 55 enum |
56 IKBD_JOY1=0, | 56 { |
57 XBIOS_JOY1, | 57 IKBD_JOY1 = 0, |
58 PORTA_PAD, | 58 XBIOS_JOY1, |
59 PORTB_PAD, | 59 PORTA_PAD, |
60 PORTA_JOY0, | 60 PORTB_PAD, |
61 PORTA_JOY1, | 61 PORTA_JOY0, |
62 PORTB_JOY0, | 62 PORTA_JOY1, |
63 PORTB_JOY1, | 63 PORTB_JOY0, |
64 PORTA_LP, | 64 PORTB_JOY1, |
65 PORTA_ANPAD, | 65 PORTA_LP, |
66 PORTB_ANPAD, | 66 PORTA_ANPAD, |
67 PORTB_ANPAD, | |
67 #if 0 | 68 #if 0 |
68 PARA_JOY0, | 69 PARA_JOY0, |
69 PARA_JOY1, | 70 PARA_JOY1, |
70 #endif | 71 #endif |
71 MAX_JOYSTICKS | 72 MAX_JOYSTICKS |
72 }; | 73 }; |
73 | 74 |
74 enum { | 75 enum |
75 MCH_ST=0, | 76 { |
76 MCH_STE, | 77 MCH_ST = 0, |
77 MCH_TT, | 78 MCH_STE, |
78 MCH_F30, | 79 MCH_TT, |
79 MCH_CLONE, | 80 MCH_F30, |
80 MCH_ARANYM | 81 MCH_CLONE, |
82 MCH_ARANYM | |
81 }; | 83 }; |
82 | 84 |
83 /* Joypad buttons | 85 /* Joypad buttons |
84 * Procontroller note: | 86 * Procontroller note: |
85 * L,R are connected to 4,6 | 87 * L,R are connected to 4,6 |
86 * X,Y,Z are connected to 7,8,9 | 88 * X,Y,Z are connected to 7,8,9 |
87 */ | 89 */ |
88 | 90 |
89 enum { | 91 enum |
90 JP_UP=0, JP_DOWN, JP_LEFT, JP_RIGHT, | 92 { |
91 JP_KPMULT, JP_KP7, JP_KP4, JP_KP1, | 93 JP_UP = 0, JP_DOWN, JP_LEFT, JP_RIGHT, |
92 JP_KP0, JP_KP8, JP_KP5, JP_KP2, | 94 JP_KPMULT, JP_KP7, JP_KP4, JP_KP1, |
93 JP_KPNUM, JP_KP9, JP_KP6, JP_KP3, | 95 JP_KP0, JP_KP8, JP_KP5, JP_KP2, |
94 JP_PAUSE, JP_FIRE0, JP_UNDEF0, JP_FIRE1, | 96 JP_KPNUM, JP_KP9, JP_KP6, JP_KP3, |
95 JP_UNDEF1, JP_FIRE2, JP_UNDEF2, JP_OPTION | 97 JP_PAUSE, JP_FIRE0, JP_UNDEF0, JP_FIRE1, |
98 JP_UNDEF1, JP_FIRE2, JP_UNDEF2, JP_OPTION | |
96 }; | 99 }; |
97 | 100 |
98 #define JP_NUM_BUTTONS 17 | 101 #define JP_NUM_BUTTONS 17 |
99 | 102 |
100 #define PORT_JS_RIGHT (1<<0) | 103 #define PORT_JS_RIGHT (1<<0) |
103 #define PORT_JS_UP (1<<3) | 106 #define PORT_JS_UP (1<<3) |
104 #define PORT_JS_FIRE (1<<4) | 107 #define PORT_JS_FIRE (1<<4) |
105 | 108 |
106 /*--- Types ---*/ | 109 /*--- Types ---*/ |
107 | 110 |
108 typedef struct { | 111 typedef struct |
109 SDL_bool enabled; | 112 { |
110 unsigned char *name; | 113 SDL_bool enabled; |
111 Uint32 prevstate; | 114 unsigned char *name; |
115 Uint32 prevstate; | |
112 } atarijoy_t; | 116 } atarijoy_t; |
113 | 117 |
114 /*--- Variables ---*/ | 118 /*--- Variables ---*/ |
115 | 119 |
116 static atarijoy_t atarijoysticks[MAX_JOYSTICKS]={ | 120 static atarijoy_t atarijoysticks[MAX_JOYSTICKS] = { |
117 {SDL_FALSE,"IKBD joystick port 1",0}, | 121 {SDL_FALSE, "IKBD joystick port 1", 0}, |
118 {SDL_FALSE,"Xbios joystick port 1",0}, | 122 {SDL_FALSE, "Xbios joystick port 1", 0}, |
119 {SDL_FALSE,"Joypad port A",0}, | 123 {SDL_FALSE, "Joypad port A", 0}, |
120 {SDL_FALSE,"Joypad port B",0}, | 124 {SDL_FALSE, "Joypad port B", 0}, |
121 {SDL_FALSE,"Joystick 0 port A",0}, | 125 {SDL_FALSE, "Joystick 0 port A", 0}, |
122 {SDL_FALSE,"Joystick 1 port A",0}, | 126 {SDL_FALSE, "Joystick 1 port A", 0}, |
123 {SDL_FALSE,"Joystick 0 port B",0}, | 127 {SDL_FALSE, "Joystick 0 port B", 0}, |
124 {SDL_FALSE,"Joystick 1 port B",0}, | 128 {SDL_FALSE, "Joystick 1 port B", 0}, |
125 {SDL_FALSE,"Lightpen port A",0}, | 129 {SDL_FALSE, "Lightpen port A", 0}, |
126 {SDL_FALSE,"Analog paddle port A",0}, | 130 {SDL_FALSE, "Analog paddle port A", 0}, |
127 {SDL_FALSE,"Analog paddle port B",0} | 131 {SDL_FALSE, "Analog paddle port B", 0} |
128 #if 0 | 132 #if 0 |
129 ,{SDL_FALSE,"Joystick 0 parallel port",0}, | 133 , {SDL_FALSE, "Joystick 0 parallel port", 0}, |
130 {SDL_FALSE,"Joystick 1 parallel port",0} | 134 {SDL_FALSE, "Joystick 1 parallel port", 0} |
131 #endif | 135 #endif |
132 }; | 136 }; |
133 | 137 |
134 static const int jp_buttons[JP_NUM_BUTTONS]={ | 138 static const int jp_buttons[JP_NUM_BUTTONS] = { |
135 JP_FIRE0, JP_FIRE1, JP_FIRE2, JP_PAUSE, | 139 JP_FIRE0, JP_FIRE1, JP_FIRE2, JP_PAUSE, |
136 JP_OPTION, JP_KPMULT, JP_KPNUM, JP_KP0, | 140 JP_OPTION, JP_KPMULT, JP_KPNUM, JP_KP0, |
137 JP_KP1, JP_KP2, JP_KP3, JP_KP4, | 141 JP_KP1, JP_KP2, JP_KP3, JP_KP4, |
138 JP_KP5, JP_KP6, JP_KP7, JP_KP8, | 142 JP_KP5, JP_KP6, JP_KP7, JP_KP8, |
139 JP_KP9 | 143 JP_KP9 |
140 }; | 144 }; |
141 | 145 |
142 static SDL_bool joypad_ports_enabled=SDL_FALSE; | 146 static SDL_bool joypad_ports_enabled = SDL_FALSE; |
143 | 147 |
144 /* Updated joypad ports */ | 148 /* Updated joypad ports */ |
145 static Uint16 jp_paddles[4]; | 149 static Uint16 jp_paddles[4]; |
146 static Uint16 jp_lightpens[2]; | 150 static Uint16 jp_lightpens[2]; |
147 static Uint16 jp_directions; | 151 static Uint16 jp_directions; |
148 static Uint16 jp_fires; | 152 static Uint16 jp_fires; |
149 static Uint32 jp_joypads[2]; | 153 static Uint32 jp_joypads[2]; |
150 | 154 |
151 /*--- Functions prototypes ---*/ | 155 /*--- Functions prototypes ---*/ |
152 | 156 |
153 static int GetEnabledAtariJoystick(int index); | 157 static int GetEnabledAtariJoystick (int index); |
154 static void UpdateJoypads(void); | 158 static void UpdateJoypads (void); |
155 | 159 |
156 /*--- Functions ---*/ | 160 /*--- Functions ---*/ |
157 | 161 |
158 int SDL_SYS_JoystickInit(void) | 162 int |
159 { | 163 SDL_SYS_JoystickInit (void) |
160 int i; | 164 { |
161 unsigned long cookie_mch; | 165 int i; |
162 const char *envr=SDL_getenv("SDL_JOYSTICK_ATARI"); | 166 unsigned long cookie_mch; |
163 | 167 const char *envr = SDL_getenv ("SDL_JOYSTICK_ATARI"); |
168 | |
164 #define TEST_JOY_ENABLED(env,idstring,num) \ | 169 #define TEST_JOY_ENABLED(env,idstring,num) \ |
165 if (SDL_strstr(env,idstring"-off")) { \ | 170 if (SDL_strstr(env,idstring"-off")) { \ |
166 atarijoysticks[num].enabled=SDL_FALSE; \ | 171 atarijoysticks[num].enabled=SDL_FALSE; \ |
167 } \ | 172 } \ |
168 if (SDL_strstr(env,idstring"-on")) { \ | 173 if (SDL_strstr(env,idstring"-on")) { \ |
169 atarijoysticks[num].enabled=SDL_TRUE; \ | 174 atarijoysticks[num].enabled=SDL_TRUE; \ |
170 } | 175 } |
171 | 176 |
172 /* Cookie _MCH present ? if not, assume ST machine */ | 177 /* Cookie _MCH present ? if not, assume ST machine */ |
173 if (Getcookie(C__MCH, &cookie_mch) != C_FOUND) { | 178 if (Getcookie (C__MCH, &cookie_mch) != C_FOUND) { |
174 cookie_mch = MCH_ST << 16; | 179 cookie_mch = MCH_ST << 16; |
175 } | 180 } |
176 | 181 |
177 /* Enable some default joysticks */ | 182 /* Enable some default joysticks */ |
178 if ((cookie_mch == MCH_ST<<16) || ((cookie_mch>>16) == MCH_STE) || | 183 if ((cookie_mch == MCH_ST << 16) || ((cookie_mch >> 16) == MCH_STE) || |
179 (cookie_mch == MCH_TT<<16) || (cookie_mch == MCH_F30<<16) || | 184 (cookie_mch == MCH_TT << 16) || (cookie_mch == MCH_F30 << 16) || |
180 (cookie_mch == MCH_ARANYM<<16)) { | 185 (cookie_mch == MCH_ARANYM << 16)) { |
181 atarijoysticks[IKBD_JOY1].enabled=(SDL_AtariIkbd_enabled!=0); | 186 atarijoysticks[IKBD_JOY1].enabled = (SDL_AtariIkbd_enabled != 0); |
182 } | 187 } |
183 if ((cookie_mch == MCH_STE<<16) || (cookie_mch == MCH_F30<<16)) { | 188 if ((cookie_mch == MCH_STE << 16) || (cookie_mch == MCH_F30 << 16)) { |
184 atarijoysticks[PORTA_PAD].enabled=SDL_TRUE; | 189 atarijoysticks[PORTA_PAD].enabled = SDL_TRUE; |
185 atarijoysticks[PORTB_PAD].enabled=SDL_TRUE; | 190 atarijoysticks[PORTB_PAD].enabled = SDL_TRUE; |
186 } | 191 } |
187 if (!atarijoysticks[IKBD_JOY1].enabled) { | 192 if (!atarijoysticks[IKBD_JOY1].enabled) { |
188 atarijoysticks[XBIOS_JOY1].enabled=(SDL_AtariXbios_enabled!=0); | 193 atarijoysticks[XBIOS_JOY1].enabled = (SDL_AtariXbios_enabled != 0); |
189 } | 194 } |
190 | 195 |
191 /* Read environment for joysticks to enable */ | 196 /* Read environment for joysticks to enable */ |
192 if (envr) { | 197 if (envr) { |
193 /* IKBD on any Atari, maybe clones */ | 198 /* IKBD on any Atari, maybe clones */ |
194 if ((cookie_mch == MCH_ST<<16) || ((cookie_mch>>16) == MCH_STE) || | 199 if ((cookie_mch == MCH_ST << 16) || ((cookie_mch >> 16) == MCH_STE) |
195 (cookie_mch == MCH_TT<<16) || (cookie_mch == MCH_F30<<16) || | 200 || (cookie_mch == MCH_TT << 16) || (cookie_mch == MCH_F30 << 16) |
196 (cookie_mch == MCH_ARANYM<<16)) { | 201 || (cookie_mch == MCH_ARANYM << 16)) { |
197 if (SDL_AtariIkbd_enabled!=0) { | 202 if (SDL_AtariIkbd_enabled != 0) { |
198 TEST_JOY_ENABLED(envr, "ikbd-joy1", IKBD_JOY1); | 203 TEST_JOY_ENABLED (envr, "ikbd-joy1", IKBD_JOY1); |
199 } | 204 } |
200 } | 205 } |
201 /* Joypads ports only on STE and Falcon */ | 206 /* Joypads ports only on STE and Falcon */ |
202 if ((cookie_mch == MCH_STE<<16) || (cookie_mch == MCH_F30<<16)) { | 207 if ((cookie_mch == MCH_STE << 16) || (cookie_mch == MCH_F30 << 16)) { |
203 TEST_JOY_ENABLED(envr, "porta-pad", PORTA_PAD); | 208 TEST_JOY_ENABLED (envr, "porta-pad", PORTA_PAD); |
204 if (!atarijoysticks[PORTA_PAD].enabled) { | 209 if (!atarijoysticks[PORTA_PAD].enabled) { |
205 TEST_JOY_ENABLED(envr, "porta-joy0", PORTA_JOY0); | 210 TEST_JOY_ENABLED (envr, "porta-joy0", PORTA_JOY0); |
206 TEST_JOY_ENABLED(envr, "porta-joy1", PORTA_JOY1); | 211 TEST_JOY_ENABLED (envr, "porta-joy1", PORTA_JOY1); |
207 if (!(atarijoysticks[PORTA_JOY0].enabled) && !(atarijoysticks[PORTA_JOY1].enabled)) { | 212 if (!(atarijoysticks[PORTA_JOY0].enabled) |
208 TEST_JOY_ENABLED(envr, "porta-lp", PORTA_LP); | 213 && !(atarijoysticks[PORTA_JOY1].enabled)) { |
209 if (!atarijoysticks[PORTA_LP].enabled) { | 214 TEST_JOY_ENABLED (envr, "porta-lp", PORTA_LP); |
210 TEST_JOY_ENABLED(envr, "porta-anpad", PORTA_ANPAD); | 215 if (!atarijoysticks[PORTA_LP].enabled) { |
211 } | 216 TEST_JOY_ENABLED (envr, "porta-anpad", PORTA_ANPAD); |
212 } | 217 } |
213 } | 218 } |
214 | 219 } |
215 TEST_JOY_ENABLED(envr, "portb-pad", PORTB_PAD); | 220 |
216 if (!atarijoysticks[PORTB_PAD].enabled) { | 221 TEST_JOY_ENABLED (envr, "portb-pad", PORTB_PAD); |
217 TEST_JOY_ENABLED(envr, "portb-joy0", PORTB_JOY0); | 222 if (!atarijoysticks[PORTB_PAD].enabled) { |
218 TEST_JOY_ENABLED(envr, "portb-joy1", PORTB_JOY1); | 223 TEST_JOY_ENABLED (envr, "portb-joy0", PORTB_JOY0); |
219 if (!(atarijoysticks[PORTB_JOY0].enabled) && !(atarijoysticks[PORTB_JOY1].enabled)) { | 224 TEST_JOY_ENABLED (envr, "portb-joy1", PORTB_JOY1); |
220 TEST_JOY_ENABLED(envr, "portb-anpad", PORTB_ANPAD); | 225 if (!(atarijoysticks[PORTB_JOY0].enabled) |
221 } | 226 && !(atarijoysticks[PORTB_JOY1].enabled)) { |
222 } | 227 TEST_JOY_ENABLED (envr, "portb-anpad", PORTB_ANPAD); |
223 } | 228 } |
224 | 229 } |
225 if (!atarijoysticks[IKBD_JOY1].enabled) { | 230 } |
226 if (SDL_AtariXbios_enabled!=0) { | 231 |
227 TEST_JOY_ENABLED(envr, "xbios-joy1", XBIOS_JOY1); | 232 if (!atarijoysticks[IKBD_JOY1].enabled) { |
228 } | 233 if (SDL_AtariXbios_enabled != 0) { |
229 } | 234 TEST_JOY_ENABLED (envr, "xbios-joy1", XBIOS_JOY1); |
235 } | |
236 } | |
230 #if 0 | 237 #if 0 |
231 /* Parallel port on any Atari, maybe clones */ | 238 /* Parallel port on any Atari, maybe clones */ |
232 if ((cookie_mch == MCH_ST<<16) || ((cookie_mch>>16) == MCH_STE) || | 239 if ((cookie_mch == MCH_ST << 16) || ((cookie_mch >> 16) == MCH_STE) |
233 (cookie_mch == MCH_TT<<16) || (cookie_mch == MCH_F30<<16)) { | 240 || (cookie_mch == MCH_TT << 16) |
234 TEST_JOY_ENABLED(envr, "para-joy0", PARA_JOY0); | 241 || (cookie_mch == MCH_F30 << 16)) { |
235 TEST_JOY_ENABLED(envr, "para-joy1", PARA_JOY1); | 242 TEST_JOY_ENABLED (envr, "para-joy0", PARA_JOY0); |
236 } | 243 TEST_JOY_ENABLED (envr, "para-joy1", PARA_JOY1); |
244 } | |
237 #endif | 245 #endif |
238 } | 246 } |
239 | 247 |
240 /* Need to update joypad ports ? */ | 248 /* Need to update joypad ports ? */ |
241 joypad_ports_enabled=SDL_FALSE; | 249 joypad_ports_enabled = SDL_FALSE; |
242 for (i=PORTA_PAD;i<=PORTB_ANPAD;i++) { | 250 for (i = PORTA_PAD; i <= PORTB_ANPAD; i++) { |
243 if (atarijoysticks[i].enabled) { | 251 if (atarijoysticks[i].enabled) { |
244 joypad_ports_enabled=SDL_TRUE; | 252 joypad_ports_enabled = SDL_TRUE; |
245 break; | 253 break; |
246 } | 254 } |
247 } | 255 } |
248 | 256 |
249 SDL_numjoysticks = 0; | 257 SDL_numjoysticks = 0; |
250 for (i=0;i<MAX_JOYSTICKS;i++) { | 258 for (i = 0; i < MAX_JOYSTICKS; i++) { |
251 if (atarijoysticks[i].enabled) { | 259 if (atarijoysticks[i].enabled) { |
252 ++SDL_numjoysticks; | 260 ++SDL_numjoysticks; |
253 } | 261 } |
254 } | 262 } |
255 | 263 |
256 return(SDL_numjoysticks); | 264 return (SDL_numjoysticks); |
257 } | 265 } |
258 | 266 |
259 static int GetEnabledAtariJoystick(int index) | 267 static int |
260 { | 268 GetEnabledAtariJoystick (int index) |
261 int i,j; | 269 { |
262 | 270 int i, j; |
263 /* Return the nth'index' enabled atari joystick */ | 271 |
264 j=0; | 272 /* Return the nth'index' enabled atari joystick */ |
265 for (i=0;i<MAX_JOYSTICKS;i++) { | 273 j = 0; |
266 if (!atarijoysticks[i].enabled) { | 274 for (i = 0; i < MAX_JOYSTICKS; i++) { |
267 continue; | 275 if (!atarijoysticks[i].enabled) { |
268 } | 276 continue; |
269 | 277 } |
270 if (j==index) { | 278 |
271 break; | 279 if (j == index) { |
272 } | 280 break; |
273 | 281 } |
274 ++j; | 282 |
275 } | 283 ++j; |
276 if (i==MAX_JOYSTICKS) | 284 } |
277 return -1; | 285 if (i == MAX_JOYSTICKS) |
278 | 286 return -1; |
279 return i; | 287 |
280 } | 288 return i; |
281 | 289 } |
282 const char *SDL_SYS_JoystickName(int index) | 290 |
283 { | 291 const char * |
284 int numjoystick; | 292 SDL_SYS_JoystickName (int index) |
285 | 293 { |
286 numjoystick=GetEnabledAtariJoystick(index); | 294 int numjoystick; |
287 if (numjoystick==-1) | 295 |
288 return NULL; | 296 numjoystick = GetEnabledAtariJoystick (index); |
289 | 297 if (numjoystick == -1) |
290 return(atarijoysticks[numjoystick].name); | 298 return NULL; |
291 } | 299 |
292 | 300 return (atarijoysticks[numjoystick].name); |
293 int SDL_SYS_JoystickOpen(SDL_Joystick *joystick) | 301 } |
294 { | 302 |
295 int numjoystick; | 303 int |
296 | 304 SDL_SYS_JoystickOpen (SDL_Joystick * joystick) |
297 numjoystick=GetEnabledAtariJoystick(joystick->index); | 305 { |
298 if (numjoystick==-1) | 306 int numjoystick; |
299 return -1; | 307 |
300 | 308 numjoystick = GetEnabledAtariJoystick (joystick->index); |
301 joystick->naxes=0; | 309 if (numjoystick == -1) |
302 joystick->nhats=0; | 310 return -1; |
303 joystick->nballs=0; | 311 |
304 | 312 joystick->naxes = 0; |
305 switch(numjoystick) { | 313 joystick->nhats = 0; |
306 case PORTA_PAD: | 314 joystick->nballs = 0; |
307 case PORTB_PAD: | 315 |
308 joystick->nhats=1; | 316 switch (numjoystick) { |
309 joystick->nbuttons=JP_NUM_BUTTONS; | 317 case PORTA_PAD: |
310 break; | 318 case PORTB_PAD: |
311 case PORTA_LP: | 319 joystick->nhats = 1; |
312 case PORTA_ANPAD: | 320 joystick->nbuttons = JP_NUM_BUTTONS; |
313 case PORTB_ANPAD: | 321 break; |
314 joystick->naxes=2; | 322 case PORTA_LP: |
315 joystick->nbuttons=2; | 323 case PORTA_ANPAD: |
316 break; | 324 case PORTB_ANPAD: |
317 default: | 325 joystick->naxes = 2; |
318 joystick->nhats=1; | 326 joystick->nbuttons = 2; |
319 joystick->nbuttons=1; | 327 break; |
320 break; | 328 default: |
321 } | 329 joystick->nhats = 1; |
322 | 330 joystick->nbuttons = 1; |
323 return(0); | 331 break; |
324 } | 332 } |
325 | 333 |
326 void SDL_SYS_JoystickUpdate(SDL_Joystick *joystick) | 334 return (0); |
327 { | 335 } |
328 int numjoystick; | 336 |
329 Uint8 hatstate; | 337 void |
330 Uint32 curstate,prevstate; | 338 SDL_SYS_JoystickUpdate (SDL_Joystick * joystick) |
331 | 339 { |
332 numjoystick=GetEnabledAtariJoystick(joystick->index); | 340 int numjoystick; |
333 if (numjoystick==-1) | 341 Uint8 hatstate; |
334 return; | 342 Uint32 curstate, prevstate; |
335 | 343 |
336 prevstate = atarijoysticks[numjoystick].prevstate; | 344 numjoystick = GetEnabledAtariJoystick (joystick->index); |
337 | 345 if (numjoystick == -1) |
338 if (joypad_ports_enabled) { | 346 return; |
339 Supexec(UpdateJoypads); | 347 |
340 } | 348 prevstate = atarijoysticks[numjoystick].prevstate; |
341 | 349 |
342 switch (numjoystick) { | 350 if (joypad_ports_enabled) { |
343 case IKBD_JOY1: | 351 Supexec (UpdateJoypads); |
344 case XBIOS_JOY1: | 352 } |
345 { | 353 |
346 curstate = 0; | 354 switch (numjoystick) { |
347 | 355 case IKBD_JOY1: |
348 if (numjoystick==IKBD_JOY1) { | 356 case XBIOS_JOY1: |
349 curstate = SDL_AtariIkbd_joystick & 0xff; | 357 { |
350 } | 358 curstate = 0; |
351 if (numjoystick==XBIOS_JOY1) { | 359 |
352 curstate = SDL_AtariXbios_joystick & 0xff; | 360 if (numjoystick == IKBD_JOY1) { |
353 } | 361 curstate = SDL_AtariIkbd_joystick & 0xff; |
354 | 362 } |
355 if (curstate != prevstate) { | 363 if (numjoystick == XBIOS_JOY1) { |
356 hatstate = SDL_HAT_CENTERED; | 364 curstate = SDL_AtariXbios_joystick & 0xff; |
357 if (curstate & IKBD_JOY_LEFT) { | 365 } |
358 hatstate |= SDL_HAT_LEFT; | 366 |
359 } | 367 if (curstate != prevstate) { |
360 if (curstate & IKBD_JOY_RIGHT) { | 368 hatstate = SDL_HAT_CENTERED; |
361 hatstate |= SDL_HAT_RIGHT; | 369 if (curstate & IKBD_JOY_LEFT) { |
362 } | 370 hatstate |= SDL_HAT_LEFT; |
363 if (curstate & IKBD_JOY_UP) { | 371 } |
364 hatstate |= SDL_HAT_UP; | 372 if (curstate & IKBD_JOY_RIGHT) { |
365 } | 373 hatstate |= SDL_HAT_RIGHT; |
366 if (curstate & IKBD_JOY_DOWN) { | 374 } |
367 hatstate |= SDL_HAT_DOWN; | 375 if (curstate & IKBD_JOY_UP) { |
368 } | 376 hatstate |= SDL_HAT_UP; |
369 SDL_PrivateJoystickHat(joystick, 0, hatstate); | 377 } |
370 | 378 if (curstate & IKBD_JOY_DOWN) { |
371 /* Button */ | 379 hatstate |= SDL_HAT_DOWN; |
372 if ((curstate & IKBD_JOY_FIRE) && !(prevstate & IKBD_JOY_FIRE)) { | 380 } |
373 SDL_PrivateJoystickButton(joystick,0,SDL_PRESSED); | 381 SDL_PrivateJoystickHat (joystick, 0, hatstate); |
374 } | 382 |
375 if (!(curstate & IKBD_JOY_FIRE) && (prevstate & IKBD_JOY_FIRE)) { | 383 /* Button */ |
376 SDL_PrivateJoystickButton(joystick,0,SDL_RELEASED); | 384 if ((curstate & IKBD_JOY_FIRE) |
377 } | 385 && !(prevstate & IKBD_JOY_FIRE)) { |
378 } | 386 SDL_PrivateJoystickButton (joystick, 0, SDL_PRESSED); |
379 atarijoysticks[numjoystick].prevstate = curstate; | 387 } |
380 } | 388 if (!(curstate & IKBD_JOY_FIRE) |
381 break; | 389 && (prevstate & IKBD_JOY_FIRE)) { |
382 case PORTA_PAD: | 390 SDL_PrivateJoystickButton (joystick, 0, SDL_RELEASED); |
383 case PORTB_PAD: | 391 } |
384 { | 392 } |
385 int numjoypad,i; | 393 atarijoysticks[numjoystick].prevstate = curstate; |
386 | 394 } |
387 numjoypad=0; | 395 break; |
388 if (numjoystick==PORTB_PAD) numjoypad=1; | 396 case PORTA_PAD: |
389 | 397 case PORTB_PAD: |
390 curstate=jp_joypads[numjoypad]; | 398 { |
391 if (curstate!=prevstate) { | 399 int numjoypad, i; |
392 hatstate = SDL_HAT_CENTERED; | 400 |
393 if (curstate & (1<<JP_LEFT)) { | 401 numjoypad = 0; |
394 hatstate |= SDL_HAT_LEFT; | 402 if (numjoystick == PORTB_PAD) |
395 } | 403 numjoypad = 1; |
396 if (curstate & (1<<JP_RIGHT)) { | 404 |
397 hatstate |= SDL_HAT_RIGHT; | 405 curstate = jp_joypads[numjoypad]; |
398 } | 406 if (curstate != prevstate) { |
399 if (curstate & (1<<JP_UP)) { | 407 hatstate = SDL_HAT_CENTERED; |
400 hatstate |= SDL_HAT_UP; | 408 if (curstate & (1 << JP_LEFT)) { |
401 } | 409 hatstate |= SDL_HAT_LEFT; |
402 if (curstate & (1<<JP_DOWN)) { | 410 } |
403 hatstate |= SDL_HAT_DOWN; | 411 if (curstate & (1 << JP_RIGHT)) { |
404 } | 412 hatstate |= SDL_HAT_RIGHT; |
405 SDL_PrivateJoystickHat(joystick, 0, hatstate); | 413 } |
406 | 414 if (curstate & (1 << JP_UP)) { |
407 /* Buttons */ | 415 hatstate |= SDL_HAT_UP; |
408 for (i=0;i<JP_NUM_BUTTONS;i++) { | 416 } |
409 int button; | 417 if (curstate & (1 << JP_DOWN)) { |
410 | 418 hatstate |= SDL_HAT_DOWN; |
411 button=1<<jp_buttons[i]; | 419 } |
412 | 420 SDL_PrivateJoystickHat (joystick, 0, hatstate); |
413 if ((curstate & button) && !(prevstate & button)) { | 421 |
414 SDL_PrivateJoystickButton(joystick,i,SDL_PRESSED); | 422 /* Buttons */ |
415 } | 423 for (i = 0; i < JP_NUM_BUTTONS; i++) { |
416 if (!(curstate & button) && (prevstate & button)) { | 424 int button; |
417 SDL_PrivateJoystickButton(joystick,i,SDL_RELEASED); | 425 |
418 } | 426 button = 1 << jp_buttons[i]; |
419 } | 427 |
420 } | 428 if ((curstate & button) && !(prevstate & button)) { |
421 atarijoysticks[numjoystick].prevstate = curstate; | 429 SDL_PrivateJoystickButton (joystick, i, SDL_PRESSED); |
422 } | 430 } |
423 break; | 431 if (!(curstate & button) && (prevstate & button)) { |
424 case PORTA_JOY0: | 432 SDL_PrivateJoystickButton (joystick, i, SDL_RELEASED); |
425 case PORTA_JOY1: | 433 } |
426 case PORTB_JOY0: | 434 } |
427 case PORTB_JOY1: | 435 } |
428 { | 436 atarijoysticks[numjoystick].prevstate = curstate; |
429 int fire_shift=0,dir_shift=0; | 437 } |
430 | 438 break; |
431 if (numjoystick==PORTA_JOY0) { fire_shift=0; dir_shift=0; } | 439 case PORTA_JOY0: |
432 if (numjoystick==PORTA_JOY1) { fire_shift=1; dir_shift=4; } | 440 case PORTA_JOY1: |
433 if (numjoystick==PORTB_JOY0) { fire_shift=2; dir_shift=8; } | 441 case PORTB_JOY0: |
434 if (numjoystick==PORTB_JOY1) { fire_shift=3; dir_shift=12; } | 442 case PORTB_JOY1: |
435 | 443 { |
436 curstate = (jp_directions>>dir_shift) & 15; | 444 int fire_shift = 0, dir_shift = 0; |
437 curstate |= ((jp_fires>>fire_shift) & 1)<<4; | 445 |
438 | 446 if (numjoystick == PORTA_JOY0) { |
439 if (curstate != prevstate) { | 447 fire_shift = 0; |
440 hatstate = SDL_HAT_CENTERED; | 448 dir_shift = 0; |
441 if (curstate & PORT_JS_LEFT) { | 449 } |
442 hatstate |= SDL_HAT_LEFT; | 450 if (numjoystick == PORTA_JOY1) { |
443 } | 451 fire_shift = 1; |
444 if (curstate & PORT_JS_RIGHT) { | 452 dir_shift = 4; |
445 hatstate |= SDL_HAT_RIGHT; | 453 } |
446 } | 454 if (numjoystick == PORTB_JOY0) { |
447 if (curstate & PORT_JS_UP) { | 455 fire_shift = 2; |
448 hatstate |= SDL_HAT_UP; | 456 dir_shift = 8; |
449 } | 457 } |
450 if (curstate & PORT_JS_DOWN) { | 458 if (numjoystick == PORTB_JOY1) { |
451 hatstate |= SDL_HAT_DOWN; | 459 fire_shift = 3; |
452 } | 460 dir_shift = 12; |
453 SDL_PrivateJoystickHat(joystick, 0, hatstate); | 461 } |
454 | 462 |
455 /* Button */ | 463 curstate = (jp_directions >> dir_shift) & 15; |
456 if ((curstate & PORT_JS_FIRE) && !(prevstate & PORT_JS_FIRE)) { | 464 curstate |= ((jp_fires >> fire_shift) & 1) << 4; |
457 SDL_PrivateJoystickButton(joystick,0,SDL_PRESSED); | 465 |
458 } | 466 if (curstate != prevstate) { |
459 if (!(curstate & PORT_JS_FIRE) && (prevstate & PORT_JS_FIRE)) { | 467 hatstate = SDL_HAT_CENTERED; |
460 SDL_PrivateJoystickButton(joystick,0,SDL_RELEASED); | 468 if (curstate & PORT_JS_LEFT) { |
461 } | 469 hatstate |= SDL_HAT_LEFT; |
462 } | 470 } |
463 atarijoysticks[numjoystick].prevstate = curstate; | 471 if (curstate & PORT_JS_RIGHT) { |
464 } | 472 hatstate |= SDL_HAT_RIGHT; |
465 break; | 473 } |
466 case PORTA_LP: | 474 if (curstate & PORT_JS_UP) { |
467 { | 475 hatstate |= SDL_HAT_UP; |
468 int i; | 476 } |
469 | 477 if (curstate & PORT_JS_DOWN) { |
470 curstate = jp_lightpens[0]>>1; | 478 hatstate |= SDL_HAT_DOWN; |
471 curstate |= (jp_lightpens[1]>>1)<<15; | 479 } |
472 curstate |= (jp_fires & 3)<<30; | 480 SDL_PrivateJoystickHat (joystick, 0, hatstate); |
473 | 481 |
474 if (curstate != prevstate) { | 482 /* Button */ |
475 /* X axis */ | 483 if ((curstate & PORT_JS_FIRE) |
476 SDL_PrivateJoystickAxis(joystick,0,jp_lightpens[0] ^ 0x8000); | 484 && !(prevstate & PORT_JS_FIRE)) { |
477 /* Y axis */ | 485 SDL_PrivateJoystickButton (joystick, 0, SDL_PRESSED); |
478 SDL_PrivateJoystickAxis(joystick,1,jp_lightpens[1] ^ 0x8000); | 486 } |
479 /* Buttons */ | 487 if (!(curstate & PORT_JS_FIRE) |
480 for (i=0;i<2;i++) { | 488 && (prevstate & PORT_JS_FIRE)) { |
481 int button; | 489 SDL_PrivateJoystickButton (joystick, 0, SDL_RELEASED); |
482 | 490 } |
483 button=1<<(30+i); | 491 } |
484 | 492 atarijoysticks[numjoystick].prevstate = curstate; |
485 if ((curstate & button) && !(prevstate & button)) { | 493 } |
486 SDL_PrivateJoystickButton(joystick,i,SDL_PRESSED); | 494 break; |
487 } | 495 case PORTA_LP: |
488 if (!(curstate & button) && (prevstate & button)) { | 496 { |
489 SDL_PrivateJoystickButton(joystick,i,SDL_RELEASED); | 497 int i; |
490 } | 498 |
491 } | 499 curstate = jp_lightpens[0] >> 1; |
492 } | 500 curstate |= (jp_lightpens[1] >> 1) << 15; |
493 atarijoysticks[numjoystick].prevstate = curstate; | 501 curstate |= (jp_fires & 3) << 30; |
494 } | 502 |
495 break; | 503 if (curstate != prevstate) { |
496 case PORTA_ANPAD: | 504 /* X axis */ |
497 case PORTB_ANPAD: | 505 SDL_PrivateJoystickAxis (joystick, 0, |
498 { | 506 jp_lightpens[0] ^ 0x8000); |
499 int numpaddle, i; | 507 /* Y axis */ |
500 | 508 SDL_PrivateJoystickAxis (joystick, 1, |
501 numpaddle=0<<1; | 509 jp_lightpens[1] ^ 0x8000); |
502 if (numjoystick==PORTB_ANPAD) numpaddle=1<<1; | 510 /* Buttons */ |
503 | 511 for (i = 0; i < 2; i++) { |
504 curstate = jp_paddles[numpaddle]>>1; | 512 int button; |
505 curstate |= (jp_paddles[numpaddle+1]>>1)<<15; | 513 |
506 curstate |= ((jp_fires>>numpaddle) & 3)<<30; | 514 button = 1 << (30 + i); |
507 | 515 |
508 if (curstate != prevstate) { | 516 if ((curstate & button) && !(prevstate & button)) { |
509 /* X axis */ | 517 SDL_PrivateJoystickButton (joystick, i, SDL_PRESSED); |
510 SDL_PrivateJoystickAxis(joystick,0,jp_paddles[numpaddle] ^ 0x8000); | 518 } |
511 /* Y axis */ | 519 if (!(curstate & button) && (prevstate & button)) { |
512 SDL_PrivateJoystickAxis(joystick,1,jp_paddles[numpaddle+1] ^ 0x8000); | 520 SDL_PrivateJoystickButton (joystick, i, SDL_RELEASED); |
513 /* Buttons */ | 521 } |
514 for (i=0;i<2;i++) { | 522 } |
515 int button; | 523 } |
516 | 524 atarijoysticks[numjoystick].prevstate = curstate; |
517 button=1<<(30+i); | 525 } |
518 | 526 break; |
519 if ((curstate & button) && !(prevstate & button)) { | 527 case PORTA_ANPAD: |
520 SDL_PrivateJoystickButton(joystick,i,SDL_PRESSED); | 528 case PORTB_ANPAD: |
521 } | 529 { |
522 if (!(curstate & button) && (prevstate & button)) { | 530 int numpaddle, i; |
523 SDL_PrivateJoystickButton(joystick,i,SDL_RELEASED); | 531 |
524 } | 532 numpaddle = 0 << 1; |
525 } | 533 if (numjoystick == PORTB_ANPAD) |
526 } | 534 numpaddle = 1 << 1; |
527 atarijoysticks[numjoystick].prevstate = curstate; | 535 |
528 } | 536 curstate = jp_paddles[numpaddle] >> 1; |
529 break; | 537 curstate |= (jp_paddles[numpaddle + 1] >> 1) << 15; |
538 curstate |= ((jp_fires >> numpaddle) & 3) << 30; | |
539 | |
540 if (curstate != prevstate) { | |
541 /* X axis */ | |
542 SDL_PrivateJoystickAxis (joystick, 0, | |
543 jp_paddles[numpaddle] ^ 0x8000); | |
544 /* Y axis */ | |
545 SDL_PrivateJoystickAxis (joystick, 1, | |
546 jp_paddles[numpaddle + 1] ^ 0x8000); | |
547 /* Buttons */ | |
548 for (i = 0; i < 2; i++) { | |
549 int button; | |
550 | |
551 button = 1 << (30 + i); | |
552 | |
553 if ((curstate & button) && !(prevstate & button)) { | |
554 SDL_PrivateJoystickButton (joystick, i, SDL_PRESSED); | |
555 } | |
556 if (!(curstate & button) && (prevstate & button)) { | |
557 SDL_PrivateJoystickButton (joystick, i, SDL_RELEASED); | |
558 } | |
559 } | |
560 } | |
561 atarijoysticks[numjoystick].prevstate = curstate; | |
562 } | |
563 break; | |
530 #if 0 | 564 #if 0 |
531 case PARA_JOY0: | 565 case PARA_JOY0: |
532 case PARA_JOY1: | 566 case PARA_JOY1: |
533 break; | 567 break; |
534 #endif | 568 #endif |
535 }; | 569 }; |
536 | 570 |
537 return; | 571 return; |
538 } | 572 } |
539 | 573 |
540 void SDL_SYS_JoystickClose(SDL_Joystick *joystick) | 574 void |
541 { | 575 SDL_SYS_JoystickClose (SDL_Joystick * joystick) |
542 return; | 576 { |
543 } | 577 return; |
544 | 578 } |
545 void SDL_SYS_JoystickQuit(void) | 579 |
546 { | 580 void |
547 SDL_numjoysticks=0; | 581 SDL_SYS_JoystickQuit (void) |
548 return; | 582 { |
583 SDL_numjoysticks = 0; | |
584 return; | |
549 } | 585 } |
550 | 586 |
551 /*--- Joypad I/O read/write interface ---*/ | 587 /*--- Joypad I/O read/write interface ---*/ |
552 | 588 |
553 #define JOYPAD_IO_BASE (0xffff9200) | 589 #define JOYPAD_IO_BASE (0xffff9200) |
554 struct JOYPAD_IO_S { | 590 struct JOYPAD_IO_S |
555 Uint16 fires; | 591 { |
556 Uint16 directions; | 592 Uint16 fires; |
557 Uint16 dummy1[6]; | 593 Uint16 directions; |
558 Uint16 paddles[4]; | 594 Uint16 dummy1[6]; |
559 Uint16 dummy2[4]; | 595 Uint16 paddles[4]; |
560 Uint16 lightpens[2]; | 596 Uint16 dummy2[4]; |
597 Uint16 lightpens[2]; | |
561 }; | 598 }; |
562 #define JOYPAD_IO ((*(volatile struct JOYPAD_IO_S *)JOYPAD_IO_BASE)) | 599 #define JOYPAD_IO ((*(volatile struct JOYPAD_IO_S *)JOYPAD_IO_BASE)) |
563 | 600 |
564 static void UpdateJoypads(void) | 601 static void |
565 { | 602 UpdateJoypads (void) |
566 Uint16 tmp; | 603 { |
567 | 604 Uint16 tmp; |
568 /*--- This function is called in supervisor mode ---*/ | 605 |
569 | 606 /*--- This function is called in supervisor mode ---*/ |
570 /* Update joysticks */ | 607 |
571 jp_fires = (~(JOYPAD_IO.fires)) & 15; | 608 /* Update joysticks */ |
572 jp_directions = (~(JOYPAD_IO.directions)); | 609 jp_fires = (~(JOYPAD_IO.fires)) & 15; |
573 | 610 jp_directions = (~(JOYPAD_IO.directions)); |
574 /* Update lightpen */ | 611 |
575 tmp = JOYPAD_IO.lightpens[0] & 1023; | 612 /* Update lightpen */ |
576 jp_lightpens[0] = (tmp<<6) | (tmp>>4); | 613 tmp = JOYPAD_IO.lightpens[0] & 1023; |
577 tmp = JOYPAD_IO.lightpens[1] & 1023; | 614 jp_lightpens[0] = (tmp << 6) | (tmp >> 4); |
578 jp_lightpens[1] = (tmp<<6) | (tmp>>4); | 615 tmp = JOYPAD_IO.lightpens[1] & 1023; |
579 | 616 jp_lightpens[1] = (tmp << 6) | (tmp >> 4); |
580 /* Update paddles */ | 617 |
581 tmp = (JOYPAD_IO.paddles[0] & 255); | 618 /* Update paddles */ |
582 jp_paddles[0] = (tmp<<8) | tmp; | 619 tmp = (JOYPAD_IO.paddles[0] & 255); |
583 tmp = (JOYPAD_IO.paddles[1] & 255); | 620 jp_paddles[0] = (tmp << 8) | tmp; |
584 jp_paddles[1] = (tmp<<8) | tmp; | 621 tmp = (JOYPAD_IO.paddles[1] & 255); |
585 tmp = (JOYPAD_IO.paddles[2] & 255); | 622 jp_paddles[1] = (tmp << 8) | tmp; |
586 jp_paddles[2] = (tmp<<8) | tmp; | 623 tmp = (JOYPAD_IO.paddles[2] & 255); |
587 tmp = (JOYPAD_IO.paddles[3] & 255); | 624 jp_paddles[2] = (tmp << 8) | tmp; |
588 jp_paddles[3] = (tmp<<8) | tmp; | 625 tmp = (JOYPAD_IO.paddles[3] & 255); |
589 | 626 jp_paddles[3] = (tmp << 8) | tmp; |
590 /* Update joypad 0 */ | 627 |
591 JOYPAD_IO.directions=0xfffe; | 628 /* Update joypad 0 */ |
592 jp_joypads[0]=((~(JOYPAD_IO.fires)) & 3)<<(16); | 629 JOYPAD_IO.directions = 0xfffe; |
593 JOYPAD_IO.directions=0xfffe; | 630 jp_joypads[0] = ((~(JOYPAD_IO.fires)) & 3) << (16); |
594 jp_joypads[0] |= ((~(JOYPAD_IO.directions))>>8) & 15; | 631 JOYPAD_IO.directions = 0xfffe; |
595 | 632 jp_joypads[0] |= ((~(JOYPAD_IO.directions)) >> 8) & 15; |
596 JOYPAD_IO.directions=0xfffd; | 633 |
597 jp_joypads[0] |= ((~(JOYPAD_IO.fires)) & 3)<<(16+2); | 634 JOYPAD_IO.directions = 0xfffd; |
598 JOYPAD_IO.directions=0xfffd; | 635 jp_joypads[0] |= ((~(JOYPAD_IO.fires)) & 3) << (16 + 2); |
599 jp_joypads[0] |= (((~(JOYPAD_IO.directions))>>8) & 15)<<4; | 636 JOYPAD_IO.directions = 0xfffd; |
600 | 637 jp_joypads[0] |= (((~(JOYPAD_IO.directions)) >> 8) & 15) << 4; |
601 JOYPAD_IO.directions=0xfffb; | 638 |
602 jp_joypads[0] |= ((~(JOYPAD_IO.fires)) & 3)<<(16+4); | 639 JOYPAD_IO.directions = 0xfffb; |
603 JOYPAD_IO.directions=0xfffb; | 640 jp_joypads[0] |= ((~(JOYPAD_IO.fires)) & 3) << (16 + 4); |
604 jp_joypads[0] |= (((~(JOYPAD_IO.directions))>>8) & 15)<<8; | 641 JOYPAD_IO.directions = 0xfffb; |
605 | 642 jp_joypads[0] |= (((~(JOYPAD_IO.directions)) >> 8) & 15) << 8; |
606 JOYPAD_IO.directions=0xfff7; | 643 |
607 jp_joypads[0] |= ((~(JOYPAD_IO.fires)) & 3)<<(16+6); | 644 JOYPAD_IO.directions = 0xfff7; |
608 JOYPAD_IO.directions=0xfff7; | 645 jp_joypads[0] |= ((~(JOYPAD_IO.fires)) & 3) << (16 + 6); |
609 jp_joypads[0] |= (((~(JOYPAD_IO.directions))>>8) & 15)<<12; | 646 JOYPAD_IO.directions = 0xfff7; |
610 | 647 jp_joypads[0] |= (((~(JOYPAD_IO.directions)) >> 8) & 15) << 12; |
611 /* Update joypad 1 */ | 648 |
612 JOYPAD_IO.directions=0xffef; | 649 /* Update joypad 1 */ |
613 jp_joypads[1]=((~(JOYPAD_IO.fires)) & (3<<2))<<(16-2); | 650 JOYPAD_IO.directions = 0xffef; |
614 JOYPAD_IO.directions=0xffef; | 651 jp_joypads[1] = ((~(JOYPAD_IO.fires)) & (3 << 2)) << (16 - 2); |
615 jp_joypads[1] |= ((~(JOYPAD_IO.directions))>>12) & 15; | 652 JOYPAD_IO.directions = 0xffef; |
616 | 653 jp_joypads[1] |= ((~(JOYPAD_IO.directions)) >> 12) & 15; |
617 JOYPAD_IO.directions=0xffdf; | 654 |
618 jp_joypads[1] |= ((~(JOYPAD_IO.fires)) & (3<<2))<<(16); | 655 JOYPAD_IO.directions = 0xffdf; |
619 JOYPAD_IO.directions=0xffdf; | 656 jp_joypads[1] |= ((~(JOYPAD_IO.fires)) & (3 << 2)) << (16); |
620 jp_joypads[1] |= (((~(JOYPAD_IO.directions))>>12) & 15)<<4; | 657 JOYPAD_IO.directions = 0xffdf; |
621 | 658 jp_joypads[1] |= (((~(JOYPAD_IO.directions)) >> 12) & 15) << 4; |
622 JOYPAD_IO.directions=0xffbf; | 659 |
623 jp_joypads[1] |= ((~(JOYPAD_IO.fires)) & (3<<2))<<(16+2); | 660 JOYPAD_IO.directions = 0xffbf; |
624 JOYPAD_IO.directions=0xffbf; | 661 jp_joypads[1] |= ((~(JOYPAD_IO.fires)) & (3 << 2)) << (16 + 2); |
625 jp_joypads[1] |= (((~(JOYPAD_IO.directions))>>12) & 15)<<8; | 662 JOYPAD_IO.directions = 0xffbf; |
626 | 663 jp_joypads[1] |= (((~(JOYPAD_IO.directions)) >> 12) & 15) << 8; |
627 JOYPAD_IO.directions=0xff7f; | 664 |
628 jp_joypads[1] |= ((~(JOYPAD_IO.fires)) & (3<<2))<<(16+4); | 665 JOYPAD_IO.directions = 0xff7f; |
629 JOYPAD_IO.directions=0xff7f; | 666 jp_joypads[1] |= ((~(JOYPAD_IO.fires)) & (3 << 2)) << (16 + 4); |
630 jp_joypads[1] |= (((~(JOYPAD_IO.directions))>>12) & 15)<<12; | 667 JOYPAD_IO.directions = 0xff7f; |
668 jp_joypads[1] |= (((~(JOYPAD_IO.directions)) >> 12) & 15) << 12; | |
631 } | 669 } |
632 | 670 |
633 #endif /* SDL_JOYSTICK_MINT */ | 671 #endif /* SDL_JOYSTICK_MINT */ |
672 /* vi: set ts=4 sw=4 expandtab: */ |