second implementation of multitap
[pcsx_rearmed.git] / libpcsxcore / plugins.c
1 /***************************************************************************\r
2  *   Copyright (C) 2007 Ryan Schultz, PCSX-df Team, PCSX team              *\r
3  *                                                                         *\r
4  *   This program is free software; you can redistribute it and/or modify  *\r
5  *   it under the terms of the GNU General Public License as published by  *\r
6  *   the Free Software Foundation; either version 2 of the License, or     *\r
7  *   (at your option) any later version.                                   *\r
8  *                                                                         *\r
9  *   This program is distributed in the hope that it will be useful,       *\r
10  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *\r
11  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *\r
12  *   GNU General Public License for more details.                          *\r
13  *                                                                         *\r
14  *   You should have received a copy of the GNU General Public License     *\r
15  *   along with this program; if not, write to the                         *\r
16  *   Free Software Foundation, Inc.,                                       *\r
17  *   51 Franklin Street, Fifth Floor, Boston, MA 02111-1307 USA.           *\r
18  ***************************************************************************/\r
19 \r
20 /*\r
21 * Plugin library callback/access functions.\r
22 */\r
23 \r
24 #include "plugins.h"\r
25 #include "cdriso.h"\r
26 \r
27 static char IsoFile[MAXPATHLEN] = "";\r
28 static s64 cdOpenCaseTime = 0;\r
29 \r
30 GPUupdateLace         GPU_updateLace;\r
31 GPUinit               GPU_init;\r
32 GPUshutdown           GPU_shutdown; \r
33 GPUconfigure          GPU_configure;\r
34 GPUtest               GPU_test;\r
35 GPUabout              GPU_about;\r
36 GPUopen               GPU_open;\r
37 GPUclose              GPU_close;\r
38 GPUreadStatus         GPU_readStatus;\r
39 GPUreadData           GPU_readData;\r
40 GPUreadDataMem        GPU_readDataMem;\r
41 GPUwriteStatus        GPU_writeStatus; \r
42 GPUwriteData          GPU_writeData;\r
43 GPUwriteDataMem       GPU_writeDataMem;\r
44 GPUdmaChain           GPU_dmaChain;\r
45 GPUkeypressed         GPU_keypressed;\r
46 GPUdisplayText        GPU_displayText;\r
47 GPUmakeSnapshot       GPU_makeSnapshot;\r
48 GPUfreeze             GPU_freeze;\r
49 GPUgetScreenPic       GPU_getScreenPic;\r
50 GPUshowScreenPic      GPU_showScreenPic;\r
51 GPUclearDynarec       GPU_clearDynarec;\r
52 GPUvBlank             GPU_vBlank;\r
53 \r
54 CDRinit               CDR_init;\r
55 CDRshutdown           CDR_shutdown;\r
56 CDRopen               CDR_open;\r
57 CDRclose              CDR_close; \r
58 CDRtest               CDR_test;\r
59 CDRgetTN              CDR_getTN;\r
60 CDRgetTD              CDR_getTD;\r
61 CDRreadTrack          CDR_readTrack;\r
62 CDRgetBuffer          CDR_getBuffer;\r
63 CDRplay               CDR_play;\r
64 CDRstop               CDR_stop;\r
65 CDRgetStatus          CDR_getStatus;\r
66 CDRgetDriveLetter     CDR_getDriveLetter;\r
67 CDRgetBufferSub       CDR_getBufferSub;\r
68 CDRconfigure          CDR_configure;\r
69 CDRabout              CDR_about;\r
70 CDRsetfilename        CDR_setfilename;\r
71 CDRreadCDDA           CDR_readCDDA;\r
72 CDRgetTE              CDR_getTE;\r
73 \r
74 SPUconfigure          SPU_configure;\r
75 SPUabout              SPU_about;\r
76 SPUinit               SPU_init;\r
77 SPUshutdown           SPU_shutdown;\r
78 SPUtest               SPU_test;\r
79 SPUopen               SPU_open;\r
80 SPUclose              SPU_close;\r
81 SPUplaySample         SPU_playSample;\r
82 SPUwriteRegister      SPU_writeRegister;\r
83 SPUreadRegister       SPU_readRegister;\r
84 SPUwriteDMA           SPU_writeDMA;\r
85 SPUreadDMA            SPU_readDMA;\r
86 SPUwriteDMAMem        SPU_writeDMAMem;\r
87 SPUreadDMAMem         SPU_readDMAMem;\r
88 SPUplayADPCMchannel   SPU_playADPCMchannel;\r
89 SPUfreeze             SPU_freeze;\r
90 SPUregisterCallback   SPU_registerCallback;\r
91 SPUregisterScheduleCb SPU_registerScheduleCb;\r
92 SPUasync              SPU_async;\r
93 SPUplayCDDAchannel    SPU_playCDDAchannel;\r
94 \r
95 PADconfigure          PAD1_configure;\r
96 PADabout              PAD1_about;\r
97 PADinit               PAD1_init;\r
98 PADshutdown           PAD1_shutdown;\r
99 PADtest               PAD1_test;\r
100 PADopen               PAD1_open;\r
101 PADclose              PAD1_close;\r
102 PADquery              PAD1_query;\r
103 PADreadPort1          PAD1_readPort1;\r
104 PADkeypressed         PAD1_keypressed;\r
105 PADstartPoll          PAD1_startPoll;\r
106 PADpoll               PAD1_poll;\r
107 PADsetSensitive       PAD1_setSensitive;\r
108 \r
109 PADconfigure          PAD2_configure;\r
110 PADabout              PAD2_about;\r
111 PADinit               PAD2_init;\r
112 PADshutdown           PAD2_shutdown;\r
113 PADtest               PAD2_test;\r
114 PADopen               PAD2_open;\r
115 PADclose              PAD2_close;\r
116 PADquery              PAD2_query;\r
117 PADreadPort2          PAD2_readPort2;\r
118 PADkeypressed         PAD2_keypressed;\r
119 PADstartPoll          PAD2_startPoll;\r
120 PADpoll               PAD2_poll;\r
121 PADsetSensitive       PAD2_setSensitive;\r
122 \r
123 NETinit               NET_init;\r
124 NETshutdown           NET_shutdown;\r
125 NETopen               NET_open;\r
126 NETclose              NET_close; \r
127 NETtest               NET_test;\r
128 NETconfigure          NET_configure;\r
129 NETabout              NET_about;\r
130 NETpause              NET_pause;\r
131 NETresume             NET_resume;\r
132 NETqueryPlayer        NET_queryPlayer;\r
133 NETsendData           NET_sendData;\r
134 NETrecvData           NET_recvData;\r
135 NETsendPadData        NET_sendPadData;\r
136 NETrecvPadData        NET_recvPadData;\r
137 NETsetInfo            NET_setInfo;\r
138 NETkeypressed         NET_keypressed;\r
139 \r
140 #ifdef ENABLE_SIO1API\r
141 \r
142 SIO1init              SIO1_init;\r
143 SIO1shutdown          SIO1_shutdown;\r
144 SIO1open              SIO1_open;\r
145 SIO1close             SIO1_close; \r
146 SIO1test              SIO1_test;\r
147 SIO1configure         SIO1_configure;\r
148 SIO1about             SIO1_about;\r
149 SIO1pause             SIO1_pause;\r
150 SIO1resume            SIO1_resume;\r
151 SIO1keypressed        SIO1_keypressed;\r
152 SIO1writeData8        SIO1_writeData8;\r
153 SIO1writeData16       SIO1_writeData16;\r
154 SIO1writeData32       SIO1_writeData32;\r
155 SIO1writeStat16       SIO1_writeStat16;\r
156 SIO1writeStat32       SIO1_writeStat32;\r
157 SIO1writeMode16       SIO1_writeMode16;\r
158 SIO1writeMode32       SIO1_writeMode32;\r
159 SIO1writeCtrl16       SIO1_writeCtrl16;\r
160 SIO1writeCtrl32       SIO1_writeCtrl32;\r
161 SIO1writeBaud16       SIO1_writeBaud16;\r
162 SIO1writeBaud32       SIO1_writeBaud32;\r
163 SIO1readData8         SIO1_readData8;\r
164 SIO1readData16        SIO1_readData16;\r
165 SIO1readData32        SIO1_readData32;\r
166 SIO1readStat16        SIO1_readStat16;\r
167 SIO1readStat32        SIO1_readStat32;\r
168 SIO1readMode16        SIO1_readMode16;\r
169 SIO1readMode32        SIO1_readMode32;\r
170 SIO1readCtrl16        SIO1_readCtrl16;\r
171 SIO1readCtrl32        SIO1_readCtrl32;\r
172 SIO1readBaud16        SIO1_readBaud16;\r
173 SIO1readBaud32        SIO1_readBaud32;\r
174 SIO1registerCallback  SIO1_registerCallback;\r
175 \r
176 #endif\r
177 \r
178 static const char *err;\r
179 \r
180 #define CheckErr(func) { \\r
181         err = SysLibError(); \\r
182         if (err != NULL) { SysMessage(_("Error loading %s: %s"), func, err); return -1; } \\r
183 }\r
184 \r
185 #define LoadSym(dest, src, name, checkerr) { \\r
186         dest = (src)SysLoadSym(drv, name); \\r
187         if (checkerr) { CheckErr(name); } else SysLibError(); \\r
188 }\r
189 \r
190 void *hGPUDriver = NULL;\r
191 \r
192 void CALLBACK GPU__displayText(char *pText) {\r
193         SysPrintf("%s\n", pText);\r
194 }\r
195 \r
196 long CALLBACK GPU__configure(void) { return 0; }\r
197 long CALLBACK GPU__test(void) { return 0; }\r
198 void CALLBACK GPU__about(void) {}\r
199 void CALLBACK GPU__makeSnapshot(void) {}\r
200 void CALLBACK GPU__keypressed(int key) {}\r
201 long CALLBACK GPU__getScreenPic(unsigned char *pMem) { return -1; }\r
202 long CALLBACK GPU__showScreenPic(unsigned char *pMem) { return -1; }\r
203 void CALLBACK GPU__clearDynarec(void (CALLBACK *callback)(void)) {}\r
204 void CALLBACK GPU__vBlank(int val) {}\r
205 \r
206 #define LoadGpuSym1(dest, name) \\r
207         LoadSym(GPU_##dest, GPU##dest, name, TRUE);\r
208 \r
209 #define LoadGpuSym0(dest, name) \\r
210         LoadSym(GPU_##dest, GPU##dest, name, FALSE); \\r
211         if (GPU_##dest == NULL) GPU_##dest = (GPU##dest) GPU__##dest;\r
212 \r
213 #define LoadGpuSymN(dest, name) \\r
214         LoadSym(GPU_##dest, GPU##dest, name, FALSE);\r
215 \r
216 static int LoadGPUplugin(const char *GPUdll) {\r
217         void *drv;\r
218 \r
219         hGPUDriver = SysLoadLibrary(GPUdll);\r
220         if (hGPUDriver == NULL) { \r
221                 GPU_configure = NULL;\r
222                 SysMessage (_("Could not load GPU plugin %s!"), GPUdll); return -1; \r
223         }\r
224         drv = hGPUDriver;\r
225         LoadGpuSym1(init, "GPUinit");\r
226         LoadGpuSym1(shutdown, "GPUshutdown");\r
227         LoadGpuSym1(open, "GPUopen");\r
228         LoadGpuSym1(close, "GPUclose");\r
229         LoadGpuSym1(readData, "GPUreadData");\r
230         LoadGpuSym1(readDataMem, "GPUreadDataMem");\r
231         LoadGpuSym1(readStatus, "GPUreadStatus");\r
232         LoadGpuSym1(writeData, "GPUwriteData");\r
233         LoadGpuSym1(writeDataMem, "GPUwriteDataMem");\r
234         LoadGpuSym1(writeStatus, "GPUwriteStatus");\r
235         LoadGpuSym1(dmaChain, "GPUdmaChain");\r
236         LoadGpuSym1(updateLace, "GPUupdateLace");\r
237         LoadGpuSym0(keypressed, "GPUkeypressed");\r
238         LoadGpuSym0(displayText, "GPUdisplayText");\r
239         LoadGpuSym0(makeSnapshot, "GPUmakeSnapshot");\r
240         LoadGpuSym1(freeze, "GPUfreeze");\r
241         LoadGpuSym0(getScreenPic, "GPUgetScreenPic");\r
242         LoadGpuSym0(showScreenPic, "GPUshowScreenPic");\r
243         LoadGpuSym0(clearDynarec, "GPUclearDynarec");\r
244     LoadGpuSym0(vBlank, "GPUvBlank");\r
245         LoadGpuSym0(configure, "GPUconfigure");\r
246         LoadGpuSym0(test, "GPUtest");\r
247         LoadGpuSym0(about, "GPUabout");\r
248 \r
249         return 0;\r
250 }\r
251 \r
252 void *hCDRDriver = NULL;\r
253 \r
254 long CALLBACK CDR__play(unsigned char *sector) { return 0; }\r
255 long CALLBACK CDR__stop(void) { return 0; }\r
256 \r
257 long CALLBACK CDR__getStatus(struct CdrStat *stat) {\r
258         if (cdOpenCaseTime < 0 || cdOpenCaseTime > (s64)time(NULL))\r
259                 stat->Status = 0x10;\r
260         else\r
261                 stat->Status = 0;\r
262 \r
263         return 0;\r
264 }\r
265 \r
266 char* CALLBACK CDR__getDriveLetter(void) { return NULL; }\r
267 long CALLBACK CDR__configure(void) { return 0; }\r
268 long CALLBACK CDR__test(void) { return 0; }\r
269 void CALLBACK CDR__about(void) {}\r
270 long CALLBACK CDR__setfilename(char*filename) { return 0; }\r
271 \r
272 #define LoadCdrSym1(dest, name) \\r
273         LoadSym(CDR_##dest, CDR##dest, name, TRUE);\r
274 \r
275 #define LoadCdrSym0(dest, name) \\r
276         LoadSym(CDR_##dest, CDR##dest, name, FALSE); \\r
277         if (CDR_##dest == NULL) CDR_##dest = (CDR##dest) CDR__##dest;\r
278 \r
279 #define LoadCdrSymN(dest, name) \\r
280         LoadSym(CDR_##dest, CDR##dest, name, FALSE);\r
281 \r
282 static int LoadCDRplugin(const char *CDRdll) {\r
283         void *drv;\r
284 \r
285         if (CDRdll == NULL) {\r
286                 cdrIsoInit();\r
287                 return 0;\r
288         }\r
289 \r
290         hCDRDriver = SysLoadLibrary(CDRdll);\r
291         if (hCDRDriver == NULL) {\r
292                 CDR_configure = NULL;\r
293                 SysMessage (_("Could not load CD-ROM plugin %s!"), CDRdll);  return -1;\r
294         }\r
295         drv = hCDRDriver;\r
296         LoadCdrSym1(init, "CDRinit");\r
297         LoadCdrSym1(shutdown, "CDRshutdown");\r
298         LoadCdrSym1(open, "CDRopen");\r
299         LoadCdrSym1(close, "CDRclose");\r
300         LoadCdrSym1(getTN, "CDRgetTN");\r
301         LoadCdrSym1(getTD, "CDRgetTD");\r
302         LoadCdrSym1(readTrack, "CDRreadTrack");\r
303         LoadCdrSym1(getBuffer, "CDRgetBuffer");\r
304         LoadCdrSym1(getBufferSub, "CDRgetBufferSub");\r
305         LoadCdrSym0(play, "CDRplay");\r
306         LoadCdrSym0(stop, "CDRstop");\r
307         LoadCdrSym0(getStatus, "CDRgetStatus");\r
308         LoadCdrSym0(getDriveLetter, "CDRgetDriveLetter");\r
309         LoadCdrSym0(configure, "CDRconfigure");\r
310         LoadCdrSym0(test, "CDRtest");\r
311         LoadCdrSym0(about, "CDRabout");\r
312         LoadCdrSym0(setfilename, "CDRsetfilename");\r
313         LoadCdrSymN(readCDDA, "CDRreadCDDA");\r
314         LoadCdrSymN(getTE, "CDRgetTE");\r
315 \r
316         return 0;\r
317 }\r
318 \r
319 void *hSPUDriver = NULL;\r
320 \r
321 long CALLBACK SPU__configure(void) { return 0; }\r
322 void CALLBACK SPU__about(void) {}\r
323 long CALLBACK SPU__test(void) { return 0; }\r
324 void CALLBACK SPU__registerScheduleCb(void (CALLBACK *cb)(unsigned int)) {}\r
325 \r
326 #define LoadSpuSym1(dest, name) \\r
327         LoadSym(SPU_##dest, SPU##dest, name, TRUE);\r
328 \r
329 #define LoadSpuSym0(dest, name) \\r
330         LoadSym(SPU_##dest, SPU##dest, name, FALSE); \\r
331         if (SPU_##dest == NULL) SPU_##dest = (SPU##dest) SPU__##dest;\r
332 \r
333 #define LoadSpuSymN(dest, name) \\r
334         LoadSym(SPU_##dest, SPU##dest, name, FALSE);\r
335 \r
336 static int LoadSPUplugin(const char *SPUdll) {\r
337         void *drv;\r
338 \r
339         hSPUDriver = SysLoadLibrary(SPUdll);\r
340         if (hSPUDriver == NULL) {\r
341                 SPU_configure = NULL;\r
342                 SysMessage (_("Could not load SPU plugin %s!"), SPUdll); return -1;\r
343         }\r
344         drv = hSPUDriver;\r
345         LoadSpuSym1(init, "SPUinit");\r
346         LoadSpuSym1(shutdown, "SPUshutdown");\r
347         LoadSpuSym1(open, "SPUopen");\r
348         LoadSpuSym1(close, "SPUclose");\r
349         LoadSpuSym0(configure, "SPUconfigure");\r
350         LoadSpuSym0(about, "SPUabout");\r
351         LoadSpuSym0(test, "SPUtest");\r
352         LoadSpuSym1(writeRegister, "SPUwriteRegister");\r
353         LoadSpuSym1(readRegister, "SPUreadRegister");           \r
354         LoadSpuSym1(writeDMA, "SPUwriteDMA");\r
355         LoadSpuSym1(readDMA, "SPUreadDMA");\r
356         LoadSpuSym1(writeDMAMem, "SPUwriteDMAMem");\r
357         LoadSpuSym1(readDMAMem, "SPUreadDMAMem");\r
358         LoadSpuSym1(playADPCMchannel, "SPUplayADPCMchannel");\r
359         LoadSpuSym1(freeze, "SPUfreeze");\r
360         LoadSpuSym1(registerCallback, "SPUregisterCallback");\r
361         LoadSpuSym0(registerScheduleCb, "SPUregisterScheduleCb");\r
362         LoadSpuSymN(async, "SPUasync");\r
363         LoadSpuSymN(playCDDAchannel, "SPUplayCDDAchannel");\r
364 \r
365         return 0;\r
366 }\r
367 \r
368 void *hPAD1Driver = NULL;\r
369 void *hPAD2Driver = NULL;\r
370 \r
371 static int multitap1 = -1;\r
372 static int multitap2 = -1;\r
373 \r
374 static unsigned char buf[512];\r
375 unsigned char stdpar[10] = { 0x00, 0x41, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };\r
376 unsigned char mousepar[8] = { 0x00, 0x12, 0x5a, 0xff, 0xff, 0xff, 0xff };\r
377 unsigned char analogpar[9] = { 0x00, 0xff, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };\r
378 unsigned char multitappar[35] = { 0x00, 0x80, 0x5a, 0x41, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,\r
379                                                                                                         0x41, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,\r
380                                                                                                         0x41, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,\r
381                                                                                                         0x41, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff};\r
382 \r
383 static int bufcount, bufc;\r
384 \r
385 //PadDataS padd1, padd2;\r
386 unsigned char _PADstartPollMultitap(PadDataS padd[4]) {\r
387         int i=0;\r
388         int decallage=2;\r
389     bufc = 0;\r
390     PadDataS pad;\r
391     for(i=0;i<4;i++){\r
392         decallage = 2 + (i*8);\r
393         pad = padd[i];\r
394                 switch (pad.controllerType) {\r
395                         case PSE_PAD_TYPE_MOUSE:\r
396                                 multitappar[decallage+1] = 0x12;\r
397                                 multitappar[decallage+2] = 0x5a;\r
398                                 multitappar[decallage+3] = pad.buttonStatus & 0xff;\r
399                                 multitappar[decallage+4] = pad.buttonStatus >> 8;\r
400                                 multitappar[decallage+5] = pad.moveX;\r
401                                 multitappar[decallage+6] = pad.moveY;\r
402 \r
403                                 break;\r
404                         case PSE_PAD_TYPE_NEGCON: // npc101/npc104(slph00001/slph00069)\r
405                                 multitappar[decallage+1] = 0x23;\r
406                                 multitappar[decallage+2] = 0x5a;\r
407                                 multitappar[decallage+3] = pad.buttonStatus & 0xff;\r
408                                 multitappar[decallage+4] = pad.buttonStatus >> 8;\r
409                                 multitappar[decallage+5] = pad.rightJoyX;\r
410                                 multitappar[decallage+6] = pad.rightJoyY;\r
411                                 multitappar[decallage+7] = pad.leftJoyX;\r
412                                 multitappar[decallage+8] = pad.leftJoyY;\r
413 \r
414                                 break;\r
415                         case PSE_PAD_TYPE_ANALOGPAD: // scph1150\r
416                                 multitappar[decallage+1] = 0x73;\r
417                                 multitappar[decallage+2] = 0x5a;\r
418                                 multitappar[decallage+3] = pad.buttonStatus & 0xff;\r
419                                 multitappar[decallage+4] = pad.buttonStatus >> 8;\r
420                                 multitappar[decallage+5] = pad.rightJoyX;\r
421                                 multitappar[decallage+6] = pad.rightJoyY;\r
422                                 multitappar[decallage+7] = pad.leftJoyX;\r
423                                 multitappar[decallage+8] = pad.leftJoyY;\r
424 \r
425                                 break;\r
426                         case PSE_PAD_TYPE_ANALOGJOY: // scph1110\r
427                                 multitappar[decallage+1] = 0x53;\r
428                                 multitappar[decallage+2] = 0x5a;\r
429                                 multitappar[decallage+3] = pad.buttonStatus & 0xff;\r
430                                 multitappar[decallage+4] = pad.buttonStatus >> 8;\r
431                                 multitappar[decallage+5] = pad.rightJoyX;\r
432                                 multitappar[decallage+6] = pad.rightJoyY;\r
433                                 multitappar[decallage+7] = pad.leftJoyX;\r
434                                 multitappar[decallage+8] = pad.leftJoyY;\r
435 \r
436                                 break;\r
437                         case PSE_PAD_TYPE_STANDARD:\r
438                         default:\r
439                                 multitappar[decallage+1] = 0x41;\r
440                                 multitappar[decallage+2] = 0x5a;\r
441                                 multitappar[decallage+3] = pad.buttonStatus & 0xff;\r
442                                 multitappar[decallage+4] = pad.buttonStatus >> 8;\r
443                 }\r
444     }\r
445 \r
446     memcpy(buf, multitappar, 35);\r
447     bufcount = 34;\r
448 \r
449     return buf[bufc++];\r
450 }\r
451 \r
452 unsigned char _PADstartPoll(PadDataS *pad) {\r
453 \r
454     bufc = 0;\r
455 \r
456     switch (pad->controllerType) {\r
457         case PSE_PAD_TYPE_MOUSE:\r
458             mousepar[3] = pad->buttonStatus & 0xff;\r
459             mousepar[4] = pad->buttonStatus >> 8;\r
460             mousepar[5] = pad->moveX;\r
461             mousepar[6] = pad->moveY;\r
462 \r
463             memcpy(buf, mousepar, 7);\r
464             bufcount = 6;\r
465             break;\r
466         case PSE_PAD_TYPE_NEGCON: // npc101/npc104(slph00001/slph00069)\r
467             analogpar[1] = 0x23;\r
468             analogpar[3] = pad->buttonStatus & 0xff;\r
469             analogpar[4] = pad->buttonStatus >> 8;\r
470             analogpar[5] = pad->rightJoyX;\r
471             analogpar[6] = pad->rightJoyY;\r
472             analogpar[7] = pad->leftJoyX;\r
473             analogpar[8] = pad->leftJoyY;\r
474 \r
475             memcpy(buf, analogpar, 9);\r
476             bufcount = 8;\r
477             break;\r
478         case PSE_PAD_TYPE_ANALOGPAD: // scph1150\r
479             analogpar[1] = 0x73;\r
480             analogpar[3] = pad->buttonStatus & 0xff;\r
481             analogpar[4] = pad->buttonStatus >> 8;\r
482             analogpar[5] = pad->rightJoyX;\r
483             analogpar[6] = pad->rightJoyY;\r
484             analogpar[7] = pad->leftJoyX;\r
485             analogpar[8] = pad->leftJoyY;\r
486 \r
487             memcpy(buf, analogpar, 9);\r
488             bufcount = 8;\r
489             break;\r
490         case PSE_PAD_TYPE_ANALOGJOY: // scph1110\r
491             analogpar[1] = 0x53;\r
492             analogpar[3] = pad->buttonStatus & 0xff;\r
493             analogpar[4] = pad->buttonStatus >> 8;\r
494             analogpar[5] = pad->rightJoyX;\r
495             analogpar[6] = pad->rightJoyY;\r
496             analogpar[7] = pad->leftJoyX;\r
497             analogpar[8] = pad->leftJoyY;\r
498 \r
499             memcpy(buf, analogpar, 9);\r
500             bufcount = 8;\r
501             break;\r
502         case PSE_PAD_TYPE_STANDARD:\r
503         default:\r
504             stdpar[3] = pad->buttonStatus & 0xff;\r
505             stdpar[4] = pad->buttonStatus >> 8;\r
506                 memcpy(buf, stdpar, 5);\r
507                 bufcount = 4;\r
508     }\r
509 \r
510     return buf[bufc++];\r
511 }\r
512 \r
513 unsigned char _PADpoll(unsigned char value) {\r
514         if (bufc > bufcount) return 0;\r
515     return buf[bufc++];\r
516 }\r
517 \r
518 // rafraichissement de l'état des boutons sur port 1,\r
519 // int pad dans le code d'origine ne sert a rien...\r
520 unsigned char CALLBACK PAD1__startPoll(int pad) {\r
521         //first call the pad provide if a multitap is connected between the psx and himself\r
522         if(multitap1 == -1){\r
523                 PadDataS padd;\r
524                 PAD1_readPort1(&padd,0);\r
525                 multitap1 = padd.portMultitap;\r
526         }\r
527         // just one pad is on port 1 : NO MULTITAP\r
528         if (multitap1 == 0){\r
529                 PadDataS padd;\r
530                 PAD1_readPort1(&padd,0);\r
531                 return _PADstartPoll(&padd);\r
532         }else{\r
533                 //a multitap is plugged : refresh all pad.\r
534                 int i=0;\r
535                 PadDataS padd[4];\r
536                 for(i=0;i<4;i++){\r
537                         PAD1_readPort1(&padd[i],i);\r
538                 }\r
539                 return _PADstartPollMultitap(padd);\r
540         }\r
541 }\r
542 \r
543 unsigned char CALLBACK PAD1__poll(unsigned char value) {\r
544 //      if(value !=0){\r
545 //              int i;\r
546 //              printf("%2x  %c\n", value, value);\r
547 //              for (i = 0; i < 35; i++) {\r
548 //                printf("%2x", buf[i]);\r
549 //              }\r
550 //              printf("\n");\r
551 //              }\r
552         if(multitap1==0){\r
553                 return _PADpoll(value);\r
554         }else{\r
555                 if(value==42){\r
556                         unsigned char bufmultitap[256];\r
557                         memcpy(bufmultitap, multitappar, 3);\r
558                         bufcount = 2;\r
559                         return bufmultitap[bufc++];\r
560                 }else{\r
561                         return _PADpoll(value);\r
562                 }\r
563         }\r
564 }\r
565 \r
566 long CALLBACK PAD1__configure(void) { return 0; }\r
567 void CALLBACK PAD1__about(void) {}\r
568 long CALLBACK PAD1__test(void) { return 0; }\r
569 long CALLBACK PAD1__query(void) { return 3; }\r
570 long CALLBACK PAD1__keypressed() { return 0; }\r
571 \r
572 #define LoadPad1Sym1(dest, name) \\r
573         LoadSym(PAD1_##dest, PAD##dest, name, TRUE);\r
574 \r
575 #define LoadPad1SymN(dest, name) \\r
576         LoadSym(PAD1_##dest, PAD##dest, name, FALSE);\r
577 \r
578 #define LoadPad1Sym0(dest, name) \\r
579         LoadSym(PAD1_##dest, PAD##dest, name, FALSE); \\r
580         if (PAD1_##dest == NULL) PAD1_##dest = (PAD##dest) PAD1__##dest;\r
581 \r
582 static int LoadPAD1plugin(const char *PAD1dll) {\r
583         void *drv;\r
584 \r
585         hPAD1Driver = SysLoadLibrary(PAD1dll);\r
586         if (hPAD1Driver == NULL) {\r
587                 PAD1_configure = NULL;\r
588                 SysMessage (_("Could not load Controller 1 plugin %s!"), PAD1dll); return -1;\r
589         }\r
590         drv = hPAD1Driver;\r
591         LoadPad1Sym1(init, "PADinit");\r
592         LoadPad1Sym1(shutdown, "PADshutdown");\r
593         LoadPad1Sym1(open, "PADopen");\r
594         LoadPad1Sym1(close, "PADclose");\r
595         LoadPad1Sym0(query, "PADquery");\r
596         LoadPad1Sym1(readPort1, "PADreadPort1");\r
597         LoadPad1Sym0(configure, "PADconfigure");\r
598         LoadPad1Sym0(test, "PADtest");\r
599         LoadPad1Sym0(about, "PADabout");\r
600         LoadPad1Sym0(keypressed, "PADkeypressed");\r
601         LoadPad1Sym0(startPoll, "PADstartPoll");\r
602         LoadPad1Sym0(poll, "PADpoll");\r
603         LoadPad1SymN(setSensitive, "PADsetSensitive");\r
604 \r
605         return 0;\r
606 }\r
607 \r
608 unsigned char CALLBACK PAD2__startPoll(int pad) {\r
609         int pad_index = 0;\r
610         if(multitap1 == 1){\r
611                 pad_index+=4;\r
612         }else{\r
613                 pad_index=1;\r
614         }\r
615         //first call the pad provide if a multitap is connected between the psx and himself\r
616         if(multitap2 == -1){\r
617                 PadDataS padd;\r
618                 PAD2_readPort2(&padd,pad_index);\r
619                 multitap2 = padd.portMultitap;\r
620         }\r
621 \r
622         // just one pad is on port 2 : NO MULTITAP\r
623         if (multitap2 == 0){\r
624                 PadDataS padd;\r
625                 PAD2_readPort2(&padd,pad_index);\r
626                 return _PADstartPoll(&padd);\r
627         }else{\r
628                 //a multitap is plugged : refresh all pad.\r
629                 int i=pad_index;\r
630                 PadDataS padd[4];\r
631                 for(i=0;i<4;i++){\r
632                         PAD2_readPort2(&padd[i],i+pad_index);\r
633                 }\r
634                 return _PADstartPollMultitap(padd);\r
635         }\r
636 }\r
637 \r
638 unsigned char CALLBACK PAD2__poll(unsigned char value) {\r
639 //      if(value !=0){\r
640 //              int i;\r
641 //              printf("%2x  %c\n", value, value);\r
642 //              for (i = 0; i < 35; i++) {\r
643 //                printf("%2x", buf[i]);\r
644 //              }\r
645 //              printf("\n");\r
646 //              }\r
647         if(multitap2==0){\r
648                 return _PADpoll(value);\r
649         }else {\r
650                 if(value==42){\r
651                         unsigned char bufmultitap[256];\r
652                         memcpy(bufmultitap, multitappar, 3);\r
653                         bufcount = 2;\r
654                         return bufmultitap[bufc++];\r
655                 }else{\r
656                         return _PADpoll(value);\r
657                 }\r
658         }\r
659 }\r
660 \r
661 long CALLBACK PAD2__configure(void) { return 0; }\r
662 void CALLBACK PAD2__about(void) {}\r
663 long CALLBACK PAD2__test(void) { return 0; }\r
664 long CALLBACK PAD2__query(void) { return PSE_PAD_USE_PORT1 | PSE_PAD_USE_PORT2; }\r
665 long CALLBACK PAD2__keypressed() { return 0; }\r
666 \r
667 #define LoadPad2Sym1(dest, name) \\r
668         LoadSym(PAD2_##dest, PAD##dest, name, TRUE);\r
669 \r
670 #define LoadPad2Sym0(dest, name) \\r
671         LoadSym(PAD2_##dest, PAD##dest, name, FALSE); \\r
672         if (PAD2_##dest == NULL) PAD2_##dest = (PAD##dest) PAD2__##dest;\r
673 \r
674 #define LoadPad2SymN(dest, name) \\r
675         LoadSym(PAD2_##dest, PAD##dest, name, FALSE);\r
676 \r
677 static int LoadPAD2plugin(const char *PAD2dll) {\r
678         void *drv;\r
679 \r
680         hPAD2Driver = SysLoadLibrary(PAD2dll);\r
681         if (hPAD2Driver == NULL) {\r
682                 PAD2_configure = NULL;\r
683                 SysMessage (_("Could not load Controller 2 plugin %s!"), PAD2dll); return -1;\r
684         }\r
685         drv = hPAD2Driver;\r
686         LoadPad2Sym1(init, "PADinit");\r
687         LoadPad2Sym1(shutdown, "PADshutdown");\r
688         LoadPad2Sym1(open, "PADopen");\r
689         LoadPad2Sym1(close, "PADclose");\r
690         LoadPad2Sym0(query, "PADquery");\r
691         LoadPad2Sym1(readPort2, "PADreadPort2");\r
692         LoadPad2Sym0(configure, "PADconfigure");\r
693         LoadPad2Sym0(test, "PADtest");\r
694         LoadPad2Sym0(about, "PADabout");\r
695         LoadPad2Sym0(keypressed, "PADkeypressed");\r
696         LoadPad2Sym0(startPoll, "PADstartPoll");\r
697         LoadPad2Sym0(poll, "PADpoll");\r
698         LoadPad2SymN(setSensitive, "PADsetSensitive");\r
699 \r
700         return 0;\r
701 }\r
702 \r
703 void *hNETDriver = NULL;\r
704 \r
705 void CALLBACK NET__setInfo(netInfo *info) {}\r
706 void CALLBACK NET__keypressed(int key) {}\r
707 long CALLBACK NET__configure(void) { return 0; }\r
708 long CALLBACK NET__test(void) { return 0; }\r
709 void CALLBACK NET__about(void) {}\r
710 \r
711 #define LoadNetSym1(dest, name) \\r
712         LoadSym(NET_##dest, NET##dest, name, TRUE);\r
713 \r
714 #define LoadNetSymN(dest, name) \\r
715         LoadSym(NET_##dest, NET##dest, name, FALSE);\r
716 \r
717 #define LoadNetSym0(dest, name) \\r
718         LoadSym(NET_##dest, NET##dest, name, FALSE); \\r
719         if (NET_##dest == NULL) NET_##dest = (NET##dest) NET__##dest;\r
720 \r
721 static int LoadNETplugin(const char *NETdll) {\r
722         void *drv;\r
723 \r
724         hNETDriver = SysLoadLibrary(NETdll);\r
725         if (hNETDriver == NULL) {\r
726                 SysMessage (_("Could not load NetPlay plugin %s!"), NETdll); return -1;\r
727         }\r
728         drv = hNETDriver;\r
729         LoadNetSym1(init, "NETinit");\r
730         LoadNetSym1(shutdown, "NETshutdown");\r
731         LoadNetSym1(open, "NETopen");\r
732         LoadNetSym1(close, "NETclose");\r
733         LoadNetSymN(sendData, "NETsendData");\r
734         LoadNetSymN(recvData, "NETrecvData");\r
735         LoadNetSym1(sendPadData, "NETsendPadData");\r
736         LoadNetSym1(recvPadData, "NETrecvPadData");\r
737         LoadNetSym1(queryPlayer, "NETqueryPlayer");\r
738         LoadNetSym1(pause, "NETpause");\r
739         LoadNetSym1(resume, "NETresume");\r
740         LoadNetSym0(setInfo, "NETsetInfo");\r
741         LoadNetSym0(keypressed, "NETkeypressed");\r
742         LoadNetSym0(configure, "NETconfigure");\r
743         LoadNetSym0(test, "NETtest");\r
744         LoadNetSym0(about, "NETabout");\r
745 \r
746         return 0;\r
747 }\r
748 \r
749 #ifdef ENABLE_SIO1API\r
750 \r
751 void *hSIO1Driver = NULL;\r
752 \r
753 long CALLBACK SIO1__init(void) { return 0; }\r
754 long CALLBACK SIO1__shutdown(void) { return 0; }\r
755 long CALLBACK SIO1__open(void) { return 0; }\r
756 long CALLBACK SIO1__close(void) { return 0; }\r
757 long CALLBACK SIO1__configure(void) { return 0; }\r
758 long CALLBACK SIO1__test(void) { return 0; }\r
759 void CALLBACK SIO1__about(void) {}\r
760 void CALLBACK SIO1__pause(void) {}\r
761 void CALLBACK SIO1__resume(void) {}\r
762 long CALLBACK SIO1__keypressed(int key) { return 0; }\r
763 void CALLBACK SIO1__writeData8(unsigned char val) {}\r
764 void CALLBACK SIO1__writeData16(unsigned short val) {}\r
765 void CALLBACK SIO1__writeData32(unsigned long val) {}\r
766 void CALLBACK SIO1__writeStat16(unsigned short val) {}\r
767 void CALLBACK SIO1__writeStat32(unsigned long val) {}\r
768 void CALLBACK SIO1__writeMode16(unsigned short val) {}\r
769 void CALLBACK SIO1__writeMode32(unsigned long val) {}\r
770 void CALLBACK SIO1__writeCtrl16(unsigned short val) {}\r
771 void CALLBACK SIO1__writeCtrl32(unsigned long val) {}\r
772 void CALLBACK SIO1__writeBaud16(unsigned short val) {}\r
773 void CALLBACK SIO1__writeBaud32(unsigned long val) {}\r
774 unsigned char CALLBACK SIO1__readData8(void) { return 0; }\r
775 unsigned short CALLBACK SIO1__readData16(void) { return 0; }\r
776 unsigned long CALLBACK SIO1__readData32(void) { return 0; }\r
777 unsigned short CALLBACK SIO1__readStat16(void) { return 0; }\r
778 unsigned long CALLBACK SIO1__readStat32(void) { return 0; }\r
779 unsigned short CALLBACK SIO1__readMode16(void) { return 0; }\r
780 unsigned long CALLBACK SIO1__readMode32(void) { return 0; }\r
781 unsigned short CALLBACK SIO1__readCtrl16(void) { return 0; }\r
782 unsigned long CALLBACK SIO1__readCtrl32(void) { return 0; }\r
783 unsigned short CALLBACK SIO1__readBaud16(void) { return 0; }\r
784 unsigned long CALLBACK SIO1__readBaud32(void) { return 0; }\r
785 void CALLBACK SIO1__registerCallback(void (CALLBACK *callback)(void)) {};\r
786 \r
787 void CALLBACK SIO1irq(void) {\r
788     psxHu32ref(0x1070) |= SWAPu32(0x100);\r
789 }\r
790 \r
791 #define LoadSio1Sym1(dest, name) \\r
792     LoadSym(SIO1_##dest, SIO1##dest, name, TRUE);\r
793 \r
794 #define LoadSio1SymN(dest, name) \\r
795     LoadSym(SIO1_##dest, SIO1##dest, name, FALSE);\r
796 \r
797 #define LoadSio1Sym0(dest, name) \\r
798     LoadSym(SIO1_##dest, SIO1##dest, name, FALSE); \\r
799     if (SIO1_##dest == NULL) SIO1_##dest = (SIO1##dest) SIO1__##dest;\r
800 \r
801 static int LoadSIO1plugin(const char *SIO1dll) {\r
802     void *drv;\r
803 \r
804     hSIO1Driver = SysLoadLibrary(SIO1dll);\r
805     if (hSIO1Driver == NULL) {\r
806         SysMessage (_("Could not load SIO1 plugin %s!"), SIO1dll); return -1;\r
807     }\r
808     drv = hSIO1Driver;\r
809 \r
810     LoadSio1Sym0(init, "SIO1init");\r
811     LoadSio1Sym0(shutdown, "SIO1shutdown");\r
812     LoadSio1Sym0(open, "SIO1open");\r
813     LoadSio1Sym0(close, "SIO1close");\r
814     LoadSio1Sym0(pause, "SIO1pause");\r
815     LoadSio1Sym0(resume, "SIO1resume");\r
816     LoadSio1Sym0(keypressed, "SIO1keypressed");\r
817     LoadSio1Sym0(configure, "SIO1configure");\r
818     LoadSio1Sym0(test, "SIO1test");\r
819     LoadSio1Sym0(about, "SIO1about");\r
820     LoadSio1Sym0(writeData8, "SIO1writeData8");\r
821     LoadSio1Sym0(writeData16, "SIO1writeData16");\r
822     LoadSio1Sym0(writeData32, "SIO1writeData32");\r
823     LoadSio1Sym0(writeStat16, "SIO1writeStat16");\r
824     LoadSio1Sym0(writeStat32, "SIO1writeStat32");\r
825     LoadSio1Sym0(writeMode16, "SIO1writeMode16");\r
826     LoadSio1Sym0(writeMode32, "SIO1writeMode32");\r
827     LoadSio1Sym0(writeCtrl16, "SIO1writeCtrl16");\r
828     LoadSio1Sym0(writeCtrl32, "SIO1writeCtrl32");\r
829     LoadSio1Sym0(writeBaud16, "SIO1writeBaud16");\r
830     LoadSio1Sym0(writeBaud32, "SIO1writeBaud32");\r
831     LoadSio1Sym0(readData16, "SIO1readData16");\r
832     LoadSio1Sym0(readData32, "SIO1readData32");\r
833     LoadSio1Sym0(readStat16, "SIO1readStat16");\r
834     LoadSio1Sym0(readStat32, "SIO1readStat32");\r
835     LoadSio1Sym0(readMode16, "SIO1readMode16");\r
836     LoadSio1Sym0(readMode32, "SIO1readMode32");\r
837     LoadSio1Sym0(readCtrl16, "SIO1readCtrl16");\r
838     LoadSio1Sym0(readCtrl32, "SIO1readCtrl32");\r
839     LoadSio1Sym0(readBaud16, "SIO1readBaud16");\r
840     LoadSio1Sym0(readBaud32, "SIO1readBaud32");\r
841     LoadSio1Sym0(registerCallback, "SIO1registerCallback");\r
842 \r
843     return 0;\r
844 }\r
845 \r
846 #endif\r
847 \r
848 void CALLBACK clearDynarec(void) {\r
849         psxCpu->Reset();\r
850 }\r
851 \r
852 int LoadPlugins() {\r
853         int ret;\r
854         char Plugin[MAXPATHLEN];\r
855 \r
856         ReleasePlugins();\r
857         SysLibError();\r
858 \r
859         if (UsingIso()) {\r
860                 LoadCDRplugin(NULL);\r
861         } else {\r
862                 sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Cdr);\r
863                 if (LoadCDRplugin(Plugin) == -1) return -1;\r
864         }\r
865 \r
866         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Gpu);\r
867         if (LoadGPUplugin(Plugin) == -1) return -1;\r
868 \r
869         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Spu);\r
870         if (LoadSPUplugin(Plugin) == -1) return -1;\r
871 \r
872         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Pad1);\r
873         if (LoadPAD1plugin(Plugin) == -1) return -1;\r
874 \r
875         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Pad2);\r
876         if (LoadPAD2plugin(Plugin) == -1) return -1;\r
877 \r
878         if (strcmp("Disabled", Config.Net) == 0 || strcmp("", Config.Net) == 0)\r
879                 Config.UseNet = FALSE;\r
880         else {\r
881                 Config.UseNet = TRUE;\r
882                 sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Net);\r
883                 if (LoadNETplugin(Plugin) == -1) Config.UseNet = FALSE;\r
884         }\r
885 \r
886 #ifdef ENABLE_SIO1API\r
887         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Sio1);\r
888         if (LoadSIO1plugin(Plugin) == -1) return -1;\r
889 #endif\r
890 \r
891         ret = CDR_init();\r
892         if (ret < 0) { SysMessage (_("Error initializing CD-ROM plugin: %d"), ret); return -1; }\r
893         ret = GPU_init();\r
894         if (ret < 0) { SysMessage (_("Error initializing GPU plugin: %d"), ret); return -1; }\r
895         ret = SPU_init();\r
896         if (ret < 0) { SysMessage (_("Error initializing SPU plugin: %d"), ret); return -1; }\r
897         ret = PAD1_init(1);\r
898         if (ret < 0) { SysMessage (_("Error initializing Controller 1 plugin: %d"), ret); return -1; }\r
899         ret = PAD2_init(2);\r
900         if (ret < 0) { SysMessage (_("Error initializing Controller 2 plugin: %d"), ret); return -1; }\r
901 \r
902         if (Config.UseNet) {\r
903                 ret = NET_init();\r
904                 if (ret < 0) { SysMessage (_("Error initializing NetPlay plugin: %d"), ret); return -1; }\r
905         }\r
906 \r
907 #ifdef ENABLE_SIO1API\r
908         ret = SIO1_init();\r
909         if (ret < 0) { SysMessage (_("Error initializing SIO1 plugin: %d"), ret); return -1; }\r
910 #endif\r
911 \r
912         SysPrintf(_("Plugins loaded.\n"));\r
913         return 0;\r
914 }\r
915 \r
916 void ReleasePlugins() {\r
917         if (Config.UseNet) {\r
918                 int ret = NET_close();\r
919                 if (ret < 0) Config.UseNet = FALSE;\r
920         }\r
921         NetOpened = FALSE;\r
922 \r
923         if (hCDRDriver != NULL || cdrIsoActive()) CDR_shutdown();\r
924         if (hGPUDriver != NULL) GPU_shutdown();\r
925         if (hSPUDriver != NULL) SPU_shutdown();\r
926         if (hPAD1Driver != NULL) PAD1_shutdown();\r
927         if (hPAD2Driver != NULL) PAD2_shutdown();\r
928 \r
929         if (Config.UseNet && hNETDriver != NULL) NET_shutdown(); \r
930 \r
931         if (hCDRDriver != NULL) SysCloseLibrary(hCDRDriver); hCDRDriver = NULL;\r
932         if (hGPUDriver != NULL) SysCloseLibrary(hGPUDriver); hGPUDriver = NULL;\r
933         if (hSPUDriver != NULL) SysCloseLibrary(hSPUDriver); hSPUDriver = NULL;\r
934         if (hPAD1Driver != NULL) SysCloseLibrary(hPAD1Driver); hPAD1Driver = NULL;\r
935         if (hPAD2Driver != NULL) SysCloseLibrary(hPAD2Driver); hPAD2Driver = NULL;\r
936 \r
937         if (Config.UseNet && hNETDriver != NULL) {\r
938                 SysCloseLibrary(hNETDriver); hNETDriver = NULL;\r
939         }\r
940 \r
941 #ifdef ENABLE_SIO1API\r
942         if (hSIO1Driver != NULL) {\r
943                 SIO1_shutdown();\r
944                 SysCloseLibrary(hSIO1Driver);\r
945                 hSIO1Driver = NULL;\r
946         }\r
947 #endif\r
948 }\r
949 \r
950 // for CD swap\r
951 int ReloadCdromPlugin()\r
952 {\r
953         if (hCDRDriver != NULL || cdrIsoActive()) CDR_shutdown();\r
954         if (hCDRDriver != NULL) SysCloseLibrary(hCDRDriver); hCDRDriver = NULL;\r
955 \r
956         if (UsingIso()) {\r
957                 LoadCDRplugin(NULL);\r
958         } else {\r
959                 char Plugin[MAXPATHLEN];\r
960                 sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Cdr);\r
961                 if (LoadCDRplugin(Plugin) == -1) return -1;\r
962         }\r
963 \r
964         return CDR_init();\r
965 }\r
966 \r
967 void SetIsoFile(const char *filename) {\r
968         if (filename == NULL) {\r
969                 IsoFile[0] = '\0';\r
970                 return;\r
971         }\r
972         strncpy(IsoFile, filename, MAXPATHLEN);\r
973 }\r
974 \r
975 const char *GetIsoFile(void) {\r
976         return IsoFile;\r
977 }\r
978 \r
979 boolean UsingIso(void) {\r
980         return (IsoFile[0] != '\0');\r
981 }\r
982 \r
983 void SetCdOpenCaseTime(s64 time) {\r
984         cdOpenCaseTime = time;\r
985 }\r