a77c728c2377db9d84d6cbb451d60abe38ad1a08
[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 GPUvBlank             GPU_vBlank;\r
52 \r
53 CDRinit               CDR_init;\r
54 CDRshutdown           CDR_shutdown;\r
55 CDRopen               CDR_open;\r
56 CDRclose              CDR_close; \r
57 CDRtest               CDR_test;\r
58 CDRgetTN              CDR_getTN;\r
59 CDRgetTD              CDR_getTD;\r
60 CDRreadTrack          CDR_readTrack;\r
61 CDRgetBuffer          CDR_getBuffer;\r
62 CDRplay               CDR_play;\r
63 CDRstop               CDR_stop;\r
64 CDRgetStatus          CDR_getStatus;\r
65 CDRgetDriveLetter     CDR_getDriveLetter;\r
66 CDRgetBufferSub       CDR_getBufferSub;\r
67 CDRconfigure          CDR_configure;\r
68 CDRabout              CDR_about;\r
69 CDRsetfilename        CDR_setfilename;\r
70 CDRreadCDDA           CDR_readCDDA;\r
71 CDRgetTE              CDR_getTE;\r
72 \r
73 SPUinit               SPU_init;\r
74 SPUshutdown           SPU_shutdown;\r
75 SPUopen               SPU_open;\r
76 SPUclose              SPU_close;\r
77 SPUwriteRegister      SPU_writeRegister;\r
78 SPUreadRegister       SPU_readRegister;\r
79 SPUwriteDMAMem        SPU_writeDMAMem;\r
80 SPUreadDMAMem         SPU_readDMAMem;\r
81 SPUplayADPCMchannel   SPU_playADPCMchannel;\r
82 SPUfreeze             SPU_freeze;\r
83 SPUregisterCallback   SPU_registerCallback;\r
84 SPUregisterScheduleCb SPU_registerScheduleCb;\r
85 SPUasync              SPU_async;\r
86 SPUplayCDDAchannel    SPU_playCDDAchannel;\r
87 \r
88 PADconfigure          PAD1_configure;\r
89 PADabout              PAD1_about;\r
90 PADinit               PAD1_init;\r
91 PADshutdown           PAD1_shutdown;\r
92 PADtest               PAD1_test;\r
93 PADopen               PAD1_open;\r
94 PADclose              PAD1_close;\r
95 PADquery              PAD1_query;\r
96 PADreadPort1          PAD1_readPort1;\r
97 PADkeypressed         PAD1_keypressed;\r
98 PADstartPoll          PAD1_startPoll;\r
99 PADpoll               PAD1_poll;\r
100 PADsetSensitive       PAD1_setSensitive;\r
101 \r
102 PADconfigure          PAD2_configure;\r
103 PADabout              PAD2_about;\r
104 PADinit               PAD2_init;\r
105 PADshutdown           PAD2_shutdown;\r
106 PADtest               PAD2_test;\r
107 PADopen               PAD2_open;\r
108 PADclose              PAD2_close;\r
109 PADquery              PAD2_query;\r
110 PADreadPort2          PAD2_readPort2;\r
111 PADkeypressed         PAD2_keypressed;\r
112 PADstartPoll          PAD2_startPoll;\r
113 PADpoll               PAD2_poll;\r
114 PADsetSensitive       PAD2_setSensitive;\r
115 \r
116 NETinit               NET_init;\r
117 NETshutdown           NET_shutdown;\r
118 NETopen               NET_open;\r
119 NETclose              NET_close; \r
120 NETtest               NET_test;\r
121 NETconfigure          NET_configure;\r
122 NETabout              NET_about;\r
123 NETpause              NET_pause;\r
124 NETresume             NET_resume;\r
125 NETqueryPlayer        NET_queryPlayer;\r
126 NETsendData           NET_sendData;\r
127 NETrecvData           NET_recvData;\r
128 NETsendPadData        NET_sendPadData;\r
129 NETrecvPadData        NET_recvPadData;\r
130 NETsetInfo            NET_setInfo;\r
131 NETkeypressed         NET_keypressed;\r
132 \r
133 #ifdef ENABLE_SIO1API\r
134 \r
135 SIO1init              SIO1_init;\r
136 SIO1shutdown          SIO1_shutdown;\r
137 SIO1open              SIO1_open;\r
138 SIO1close             SIO1_close; \r
139 SIO1test              SIO1_test;\r
140 SIO1configure         SIO1_configure;\r
141 SIO1about             SIO1_about;\r
142 SIO1pause             SIO1_pause;\r
143 SIO1resume            SIO1_resume;\r
144 SIO1keypressed        SIO1_keypressed;\r
145 SIO1writeData8        SIO1_writeData8;\r
146 SIO1writeData16       SIO1_writeData16;\r
147 SIO1writeData32       SIO1_writeData32;\r
148 SIO1writeStat16       SIO1_writeStat16;\r
149 SIO1writeStat32       SIO1_writeStat32;\r
150 SIO1writeMode16       SIO1_writeMode16;\r
151 SIO1writeMode32       SIO1_writeMode32;\r
152 SIO1writeCtrl16       SIO1_writeCtrl16;\r
153 SIO1writeCtrl32       SIO1_writeCtrl32;\r
154 SIO1writeBaud16       SIO1_writeBaud16;\r
155 SIO1writeBaud32       SIO1_writeBaud32;\r
156 SIO1readData8         SIO1_readData8;\r
157 SIO1readData16        SIO1_readData16;\r
158 SIO1readData32        SIO1_readData32;\r
159 SIO1readStat16        SIO1_readStat16;\r
160 SIO1readStat32        SIO1_readStat32;\r
161 SIO1readMode16        SIO1_readMode16;\r
162 SIO1readMode32        SIO1_readMode32;\r
163 SIO1readCtrl16        SIO1_readCtrl16;\r
164 SIO1readCtrl32        SIO1_readCtrl32;\r
165 SIO1readBaud16        SIO1_readBaud16;\r
166 SIO1readBaud32        SIO1_readBaud32;\r
167 SIO1registerCallback  SIO1_registerCallback;\r
168 \r
169 #endif\r
170 \r
171 static const char *err;\r
172 \r
173 #define CheckErr(func) { \\r
174         err = SysLibError(); \\r
175         if (err != NULL) { SysMessage(_("Error loading %s: %s"), func, err); return -1; } \\r
176 }\r
177 \r
178 #define LoadSym(dest, src, name, checkerr) { \\r
179         dest = (src)SysLoadSym(drv, name); \\r
180         if (checkerr) { CheckErr(name); } else SysLibError(); \\r
181 }\r
182 \r
183 void *hGPUDriver = NULL;\r
184 \r
185 void CALLBACK GPU__displayText(char *pText) {\r
186         SysPrintf("%s\n", pText);\r
187 }\r
188 \r
189 long CALLBACK GPU__configure(void) { return 0; }\r
190 long CALLBACK GPU__test(void) { return 0; }\r
191 void CALLBACK GPU__about(void) {}\r
192 void CALLBACK GPU__makeSnapshot(void) {}\r
193 void CALLBACK GPU__keypressed(int key) {}\r
194 long CALLBACK GPU__getScreenPic(unsigned char *pMem) { return -1; }\r
195 long CALLBACK GPU__showScreenPic(unsigned char *pMem) { return -1; }\r
196 void CALLBACK GPU__vBlank(int val) {}\r
197 \r
198 #define LoadGpuSym1(dest, name) \\r
199         LoadSym(GPU_##dest, GPU##dest, name, TRUE);\r
200 \r
201 #define LoadGpuSym0(dest, name) \\r
202         LoadSym(GPU_##dest, GPU##dest, name, FALSE); \\r
203         if (GPU_##dest == NULL) GPU_##dest = (GPU##dest) GPU__##dest;\r
204 \r
205 #define LoadGpuSymN(dest, name) \\r
206         LoadSym(GPU_##dest, GPU##dest, name, FALSE);\r
207 \r
208 static int LoadGPUplugin(const char *GPUdll) {\r
209         void *drv;\r
210 \r
211         hGPUDriver = SysLoadLibrary(GPUdll);\r
212         if (hGPUDriver == NULL) { \r
213                 GPU_configure = NULL;\r
214                 SysMessage (_("Could not load GPU plugin %s!"), GPUdll); return -1; \r
215         }\r
216         drv = hGPUDriver;\r
217         LoadGpuSym1(init, "GPUinit");\r
218         LoadGpuSym1(shutdown, "GPUshutdown");\r
219         LoadGpuSym1(open, "GPUopen");\r
220         LoadGpuSym1(close, "GPUclose");\r
221         LoadGpuSym1(readData, "GPUreadData");\r
222         LoadGpuSym1(readDataMem, "GPUreadDataMem");\r
223         LoadGpuSym1(readStatus, "GPUreadStatus");\r
224         LoadGpuSym1(writeData, "GPUwriteData");\r
225         LoadGpuSym1(writeDataMem, "GPUwriteDataMem");\r
226         LoadGpuSym1(writeStatus, "GPUwriteStatus");\r
227         LoadGpuSym1(dmaChain, "GPUdmaChain");\r
228         LoadGpuSym1(updateLace, "GPUupdateLace");\r
229         LoadGpuSym0(keypressed, "GPUkeypressed");\r
230         LoadGpuSym0(displayText, "GPUdisplayText");\r
231         LoadGpuSym0(makeSnapshot, "GPUmakeSnapshot");\r
232         LoadGpuSym1(freeze, "GPUfreeze");\r
233         LoadGpuSym0(getScreenPic, "GPUgetScreenPic");\r
234         LoadGpuSym0(showScreenPic, "GPUshowScreenPic");\r
235     LoadGpuSym0(vBlank, "GPUvBlank");\r
236         LoadGpuSym0(configure, "GPUconfigure");\r
237         LoadGpuSym0(test, "GPUtest");\r
238         LoadGpuSym0(about, "GPUabout");\r
239 \r
240         return 0;\r
241 }\r
242 \r
243 void *hCDRDriver = NULL;\r
244 \r
245 long CALLBACK CDR__play(unsigned char *sector) { return 0; }\r
246 long CALLBACK CDR__stop(void) { return 0; }\r
247 \r
248 long CALLBACK CDR__getStatus(struct CdrStat *stat) {\r
249         if (cdOpenCaseTime < 0 || cdOpenCaseTime > (s64)time(NULL))\r
250                 stat->Status = 0x10;\r
251         else\r
252                 stat->Status = 0;\r
253 \r
254         return 0;\r
255 }\r
256 \r
257 char* CALLBACK CDR__getDriveLetter(void) { return NULL; }\r
258 long CALLBACK CDR__configure(void) { return 0; }\r
259 long CALLBACK CDR__test(void) { return 0; }\r
260 void CALLBACK CDR__about(void) {}\r
261 long CALLBACK CDR__setfilename(char*filename) { return 0; }\r
262 \r
263 #define LoadCdrSym1(dest, name) \\r
264         LoadSym(CDR_##dest, CDR##dest, name, TRUE);\r
265 \r
266 #define LoadCdrSym0(dest, name) \\r
267         LoadSym(CDR_##dest, CDR##dest, name, FALSE); \\r
268         if (CDR_##dest == NULL) CDR_##dest = (CDR##dest) CDR__##dest;\r
269 \r
270 #define LoadCdrSymN(dest, name) \\r
271         LoadSym(CDR_##dest, CDR##dest, name, FALSE);\r
272 \r
273 static int LoadCDRplugin(const char *CDRdll) {\r
274         void *drv;\r
275 \r
276         if (CDRdll == NULL) {\r
277                 cdrIsoInit();\r
278                 return 0;\r
279         }\r
280 \r
281         hCDRDriver = SysLoadLibrary(CDRdll);\r
282         if (hCDRDriver == NULL) {\r
283                 CDR_configure = NULL;\r
284                 SysMessage (_("Could not load CD-ROM plugin %s!"), CDRdll);  return -1;\r
285         }\r
286         drv = hCDRDriver;\r
287         LoadCdrSym1(init, "CDRinit");\r
288         LoadCdrSym1(shutdown, "CDRshutdown");\r
289         LoadCdrSym1(open, "CDRopen");\r
290         LoadCdrSym1(close, "CDRclose");\r
291         LoadCdrSym1(getTN, "CDRgetTN");\r
292         LoadCdrSym1(getTD, "CDRgetTD");\r
293         LoadCdrSym1(readTrack, "CDRreadTrack");\r
294         LoadCdrSym1(getBuffer, "CDRgetBuffer");\r
295         LoadCdrSym1(getBufferSub, "CDRgetBufferSub");\r
296         LoadCdrSym0(play, "CDRplay");\r
297         LoadCdrSym0(stop, "CDRstop");\r
298         LoadCdrSym0(getStatus, "CDRgetStatus");\r
299         LoadCdrSym0(getDriveLetter, "CDRgetDriveLetter");\r
300         LoadCdrSym0(configure, "CDRconfigure");\r
301         LoadCdrSym0(test, "CDRtest");\r
302         LoadCdrSym0(about, "CDRabout");\r
303         LoadCdrSym0(setfilename, "CDRsetfilename");\r
304         LoadCdrSymN(readCDDA, "CDRreadCDDA");\r
305         LoadCdrSymN(getTE, "CDRgetTE");\r
306 \r
307         return 0;\r
308 }\r
309 \r
310 static void *hSPUDriver = NULL;\r
311 static void CALLBACK SPU__registerScheduleCb(void (CALLBACK *cb)(unsigned int)) {}\r
312 \r
313 #define LoadSpuSym1(dest, name) \\r
314         LoadSym(SPU_##dest, SPU##dest, name, TRUE);\r
315 \r
316 #define LoadSpuSym0(dest, name) \\r
317         LoadSym(SPU_##dest, SPU##dest, name, FALSE); \\r
318         if (SPU_##dest == NULL) SPU_##dest = (SPU##dest) SPU__##dest;\r
319 \r
320 #define LoadSpuSymN(dest, name) \\r
321         LoadSym(SPU_##dest, SPU##dest, name, FALSE);\r
322 \r
323 static int LoadSPUplugin(const char *SPUdll) {\r
324         void *drv;\r
325 \r
326         hSPUDriver = SysLoadLibrary(SPUdll);\r
327         if (hSPUDriver == NULL) {\r
328                 SysMessage (_("Could not load SPU plugin %s!"), SPUdll); return -1;\r
329         }\r
330         drv = hSPUDriver;\r
331         LoadSpuSym1(init, "SPUinit");\r
332         LoadSpuSym1(shutdown, "SPUshutdown");\r
333         LoadSpuSym1(open, "SPUopen");\r
334         LoadSpuSym1(close, "SPUclose");\r
335         LoadSpuSym1(writeRegister, "SPUwriteRegister");\r
336         LoadSpuSym1(readRegister, "SPUreadRegister");           \r
337         LoadSpuSym1(writeDMAMem, "SPUwriteDMAMem");\r
338         LoadSpuSym1(readDMAMem, "SPUreadDMAMem");\r
339         LoadSpuSym1(playADPCMchannel, "SPUplayADPCMchannel");\r
340         LoadSpuSym1(freeze, "SPUfreeze");\r
341         LoadSpuSym1(registerCallback, "SPUregisterCallback");\r
342         LoadSpuSym0(registerScheduleCb, "SPUregisterScheduleCb");\r
343         LoadSpuSymN(async, "SPUasync");\r
344         LoadSpuSymN(playCDDAchannel, "SPUplayCDDAchannel");\r
345 \r
346         return 0;\r
347 }\r
348 \r
349 void *hPAD1Driver = NULL;\r
350 void *hPAD2Driver = NULL;\r
351 \r
352 static unsigned char buf[256];\r
353 unsigned char stdpar[10] = { 0x00, 0x41, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };\r
354 unsigned char mousepar[8] = { 0x00, 0x12, 0x5a, 0xff, 0xff, 0xff, 0xff };\r
355 unsigned char analogpar[9] = { 0x00, 0xff, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };\r
356 \r
357 static int bufcount, bufc;\r
358 \r
359 PadDataS padd1, padd2;\r
360 \r
361 unsigned char _PADstartPoll(PadDataS *pad) {\r
362     bufc = 0;\r
363 \r
364     switch (pad->controllerType) {\r
365         case PSE_PAD_TYPE_MOUSE:\r
366             mousepar[3] = pad->buttonStatus & 0xff;\r
367             mousepar[4] = pad->buttonStatus >> 8;\r
368             mousepar[5] = pad->moveX;\r
369             mousepar[6] = pad->moveY;\r
370 \r
371             memcpy(buf, mousepar, 7);\r
372             bufcount = 6;\r
373             break;\r
374         case PSE_PAD_TYPE_NEGCON: // npc101/npc104(slph00001/slph00069)\r
375             analogpar[1] = 0x23;\r
376             analogpar[3] = pad->buttonStatus & 0xff;\r
377             analogpar[4] = pad->buttonStatus >> 8;\r
378             analogpar[5] = pad->rightJoyX;\r
379             analogpar[6] = pad->rightJoyY;\r
380             analogpar[7] = pad->leftJoyX;\r
381             analogpar[8] = pad->leftJoyY;\r
382 \r
383             memcpy(buf, analogpar, 9);\r
384             bufcount = 8;\r
385             break;\r
386         case PSE_PAD_TYPE_ANALOGPAD: // scph1150\r
387             analogpar[1] = 0x73;\r
388             analogpar[3] = pad->buttonStatus & 0xff;\r
389             analogpar[4] = pad->buttonStatus >> 8;\r
390             analogpar[5] = pad->rightJoyX;\r
391             analogpar[6] = pad->rightJoyY;\r
392             analogpar[7] = pad->leftJoyX;\r
393             analogpar[8] = pad->leftJoyY;\r
394 \r
395             memcpy(buf, analogpar, 9);\r
396             bufcount = 8;\r
397             break;\r
398         case PSE_PAD_TYPE_ANALOGJOY: // scph1110\r
399             analogpar[1] = 0x53;\r
400             analogpar[3] = pad->buttonStatus & 0xff;\r
401             analogpar[4] = pad->buttonStatus >> 8;\r
402             analogpar[5] = pad->rightJoyX;\r
403             analogpar[6] = pad->rightJoyY;\r
404             analogpar[7] = pad->leftJoyX;\r
405             analogpar[8] = pad->leftJoyY;\r
406 \r
407             memcpy(buf, analogpar, 9);\r
408             bufcount = 8;\r
409             break;\r
410         case PSE_PAD_TYPE_STANDARD:\r
411         default:\r
412             stdpar[3] = pad->buttonStatus & 0xff;\r
413             stdpar[4] = pad->buttonStatus >> 8;\r
414 \r
415             memcpy(buf, stdpar, 5);\r
416             bufcount = 4;\r
417     }\r
418 \r
419     return buf[bufc++];\r
420 }\r
421 \r
422 unsigned char _PADpoll(unsigned char value) {\r
423     if (bufc > bufcount) return 0;\r
424     return buf[bufc++];\r
425 }\r
426 \r
427 unsigned char CALLBACK PAD1__startPoll(int pad) {\r
428     PadDataS padd;\r
429 \r
430     PAD1_readPort1(&padd);\r
431 \r
432     return _PADstartPoll(&padd);\r
433 }\r
434 \r
435 unsigned char CALLBACK PAD1__poll(unsigned char value) {\r
436     return _PADpoll(value);\r
437 }\r
438 \r
439 long CALLBACK PAD1__configure(void) { return 0; }\r
440 void CALLBACK PAD1__about(void) {}\r
441 long CALLBACK PAD1__test(void) { return 0; }\r
442 long CALLBACK PAD1__query(void) { return 3; }\r
443 long CALLBACK PAD1__keypressed() { return 0; }\r
444 \r
445 #define LoadPad1Sym1(dest, name) \\r
446         LoadSym(PAD1_##dest, PAD##dest, name, TRUE);\r
447 \r
448 #define LoadPad1SymN(dest, name) \\r
449         LoadSym(PAD1_##dest, PAD##dest, name, FALSE);\r
450 \r
451 #define LoadPad1Sym0(dest, name) \\r
452         LoadSym(PAD1_##dest, PAD##dest, name, FALSE); \\r
453         if (PAD1_##dest == NULL) PAD1_##dest = (PAD##dest) PAD1__##dest;\r
454 \r
455 static int LoadPAD1plugin(const char *PAD1dll) {\r
456         void *drv;\r
457 \r
458         hPAD1Driver = SysLoadLibrary(PAD1dll);\r
459         if (hPAD1Driver == NULL) {\r
460                 PAD1_configure = NULL;\r
461                 SysMessage (_("Could not load Controller 1 plugin %s!"), PAD1dll); return -1;\r
462         }\r
463         drv = hPAD1Driver;\r
464         LoadPad1Sym1(init, "PADinit");\r
465         LoadPad1Sym1(shutdown, "PADshutdown");\r
466         LoadPad1Sym1(open, "PADopen");\r
467         LoadPad1Sym1(close, "PADclose");\r
468         LoadPad1Sym0(query, "PADquery");\r
469         LoadPad1Sym1(readPort1, "PADreadPort1");\r
470         LoadPad1Sym0(configure, "PADconfigure");\r
471         LoadPad1Sym0(test, "PADtest");\r
472         LoadPad1Sym0(about, "PADabout");\r
473         LoadPad1Sym0(keypressed, "PADkeypressed");\r
474         LoadPad1Sym0(startPoll, "PADstartPoll");\r
475         LoadPad1Sym0(poll, "PADpoll");\r
476         LoadPad1SymN(setSensitive, "PADsetSensitive");\r
477 \r
478         return 0;\r
479 }\r
480 \r
481 unsigned char CALLBACK PAD2__startPoll(int pad) {\r
482         PadDataS padd;\r
483 \r
484         PAD2_readPort2(&padd);\r
485     \r
486         return _PADstartPoll(&padd);\r
487 }\r
488 \r
489 unsigned char CALLBACK PAD2__poll(unsigned char value) {\r
490         return _PADpoll(value);\r
491 }\r
492 \r
493 long CALLBACK PAD2__configure(void) { return 0; }\r
494 void CALLBACK PAD2__about(void) {}\r
495 long CALLBACK PAD2__test(void) { return 0; }\r
496 long CALLBACK PAD2__query(void) { return PSE_PAD_USE_PORT1 | PSE_PAD_USE_PORT2; }\r
497 long CALLBACK PAD2__keypressed() { return 0; }\r
498 \r
499 #define LoadPad2Sym1(dest, name) \\r
500         LoadSym(PAD2_##dest, PAD##dest, name, TRUE);\r
501 \r
502 #define LoadPad2Sym0(dest, name) \\r
503         LoadSym(PAD2_##dest, PAD##dest, name, FALSE); \\r
504         if (PAD2_##dest == NULL) PAD2_##dest = (PAD##dest) PAD2__##dest;\r
505 \r
506 #define LoadPad2SymN(dest, name) \\r
507         LoadSym(PAD2_##dest, PAD##dest, name, FALSE);\r
508 \r
509 static int LoadPAD2plugin(const char *PAD2dll) {\r
510         void *drv;\r
511 \r
512         hPAD2Driver = SysLoadLibrary(PAD2dll);\r
513         if (hPAD2Driver == NULL) {\r
514                 PAD2_configure = NULL;\r
515                 SysMessage (_("Could not load Controller 2 plugin %s!"), PAD2dll); return -1;\r
516         }\r
517         drv = hPAD2Driver;\r
518         LoadPad2Sym1(init, "PADinit");\r
519         LoadPad2Sym1(shutdown, "PADshutdown");\r
520         LoadPad2Sym1(open, "PADopen");\r
521         LoadPad2Sym1(close, "PADclose");\r
522         LoadPad2Sym0(query, "PADquery");\r
523         LoadPad2Sym1(readPort2, "PADreadPort2");\r
524         LoadPad2Sym0(configure, "PADconfigure");\r
525         LoadPad2Sym0(test, "PADtest");\r
526         LoadPad2Sym0(about, "PADabout");\r
527         LoadPad2Sym0(keypressed, "PADkeypressed");\r
528         LoadPad2Sym0(startPoll, "PADstartPoll");\r
529         LoadPad2Sym0(poll, "PADpoll");\r
530         LoadPad2SymN(setSensitive, "PADsetSensitive");\r
531 \r
532         return 0;\r
533 }\r
534 \r
535 void *hNETDriver = NULL;\r
536 \r
537 void CALLBACK NET__setInfo(netInfo *info) {}\r
538 void CALLBACK NET__keypressed(int key) {}\r
539 long CALLBACK NET__configure(void) { return 0; }\r
540 long CALLBACK NET__test(void) { return 0; }\r
541 void CALLBACK NET__about(void) {}\r
542 \r
543 #define LoadNetSym1(dest, name) \\r
544         LoadSym(NET_##dest, NET##dest, name, TRUE);\r
545 \r
546 #define LoadNetSymN(dest, name) \\r
547         LoadSym(NET_##dest, NET##dest, name, FALSE);\r
548 \r
549 #define LoadNetSym0(dest, name) \\r
550         LoadSym(NET_##dest, NET##dest, name, FALSE); \\r
551         if (NET_##dest == NULL) NET_##dest = (NET##dest) NET__##dest;\r
552 \r
553 static int LoadNETplugin(const char *NETdll) {\r
554         void *drv;\r
555 \r
556         hNETDriver = SysLoadLibrary(NETdll);\r
557         if (hNETDriver == NULL) {\r
558                 SysMessage (_("Could not load NetPlay plugin %s!"), NETdll); return -1;\r
559         }\r
560         drv = hNETDriver;\r
561         LoadNetSym1(init, "NETinit");\r
562         LoadNetSym1(shutdown, "NETshutdown");\r
563         LoadNetSym1(open, "NETopen");\r
564         LoadNetSym1(close, "NETclose");\r
565         LoadNetSymN(sendData, "NETsendData");\r
566         LoadNetSymN(recvData, "NETrecvData");\r
567         LoadNetSym1(sendPadData, "NETsendPadData");\r
568         LoadNetSym1(recvPadData, "NETrecvPadData");\r
569         LoadNetSym1(queryPlayer, "NETqueryPlayer");\r
570         LoadNetSym1(pause, "NETpause");\r
571         LoadNetSym1(resume, "NETresume");\r
572         LoadNetSym0(setInfo, "NETsetInfo");\r
573         LoadNetSym0(keypressed, "NETkeypressed");\r
574         LoadNetSym0(configure, "NETconfigure");\r
575         LoadNetSym0(test, "NETtest");\r
576         LoadNetSym0(about, "NETabout");\r
577 \r
578         return 0;\r
579 }\r
580 \r
581 #ifdef ENABLE_SIO1API\r
582 \r
583 void *hSIO1Driver = NULL;\r
584 \r
585 long CALLBACK SIO1__init(void) { return 0; }\r
586 long CALLBACK SIO1__shutdown(void) { return 0; }\r
587 long CALLBACK SIO1__open(void) { return 0; }\r
588 long CALLBACK SIO1__close(void) { return 0; }\r
589 long CALLBACK SIO1__configure(void) { return 0; }\r
590 long CALLBACK SIO1__test(void) { return 0; }\r
591 void CALLBACK SIO1__about(void) {}\r
592 void CALLBACK SIO1__pause(void) {}\r
593 void CALLBACK SIO1__resume(void) {}\r
594 long CALLBACK SIO1__keypressed(int key) { return 0; }\r
595 void CALLBACK SIO1__writeData8(unsigned char val) {}\r
596 void CALLBACK SIO1__writeData16(unsigned short val) {}\r
597 void CALLBACK SIO1__writeData32(unsigned long val) {}\r
598 void CALLBACK SIO1__writeStat16(unsigned short val) {}\r
599 void CALLBACK SIO1__writeStat32(unsigned long val) {}\r
600 void CALLBACK SIO1__writeMode16(unsigned short val) {}\r
601 void CALLBACK SIO1__writeMode32(unsigned long val) {}\r
602 void CALLBACK SIO1__writeCtrl16(unsigned short val) {}\r
603 void CALLBACK SIO1__writeCtrl32(unsigned long val) {}\r
604 void CALLBACK SIO1__writeBaud16(unsigned short val) {}\r
605 void CALLBACK SIO1__writeBaud32(unsigned long val) {}\r
606 unsigned char CALLBACK SIO1__readData8(void) { return 0; }\r
607 unsigned short CALLBACK SIO1__readData16(void) { return 0; }\r
608 unsigned long CALLBACK SIO1__readData32(void) { return 0; }\r
609 unsigned short CALLBACK SIO1__readStat16(void) { return 0; }\r
610 unsigned long CALLBACK SIO1__readStat32(void) { return 0; }\r
611 unsigned short CALLBACK SIO1__readMode16(void) { return 0; }\r
612 unsigned long CALLBACK SIO1__readMode32(void) { return 0; }\r
613 unsigned short CALLBACK SIO1__readCtrl16(void) { return 0; }\r
614 unsigned long CALLBACK SIO1__readCtrl32(void) { return 0; }\r
615 unsigned short CALLBACK SIO1__readBaud16(void) { return 0; }\r
616 unsigned long CALLBACK SIO1__readBaud32(void) { return 0; }\r
617 void CALLBACK SIO1__registerCallback(void (CALLBACK *callback)(void)) {};\r
618 \r
619 void CALLBACK SIO1irq(void) {\r
620     psxHu32ref(0x1070) |= SWAPu32(0x100);\r
621 }\r
622 \r
623 #define LoadSio1Sym1(dest, name) \\r
624     LoadSym(SIO1_##dest, SIO1##dest, name, TRUE);\r
625 \r
626 #define LoadSio1SymN(dest, name) \\r
627     LoadSym(SIO1_##dest, SIO1##dest, name, FALSE);\r
628 \r
629 #define LoadSio1Sym0(dest, name) \\r
630     LoadSym(SIO1_##dest, SIO1##dest, name, FALSE); \\r
631     if (SIO1_##dest == NULL) SIO1_##dest = (SIO1##dest) SIO1__##dest;\r
632 \r
633 static int LoadSIO1plugin(const char *SIO1dll) {\r
634     void *drv;\r
635 \r
636     hSIO1Driver = SysLoadLibrary(SIO1dll);\r
637     if (hSIO1Driver == NULL) {\r
638         SysMessage (_("Could not load SIO1 plugin %s!"), SIO1dll); return -1;\r
639     }\r
640     drv = hSIO1Driver;\r
641 \r
642     LoadSio1Sym0(init, "SIO1init");\r
643     LoadSio1Sym0(shutdown, "SIO1shutdown");\r
644     LoadSio1Sym0(open, "SIO1open");\r
645     LoadSio1Sym0(close, "SIO1close");\r
646     LoadSio1Sym0(pause, "SIO1pause");\r
647     LoadSio1Sym0(resume, "SIO1resume");\r
648     LoadSio1Sym0(keypressed, "SIO1keypressed");\r
649     LoadSio1Sym0(configure, "SIO1configure");\r
650     LoadSio1Sym0(test, "SIO1test");\r
651     LoadSio1Sym0(about, "SIO1about");\r
652     LoadSio1Sym0(writeData8, "SIO1writeData8");\r
653     LoadSio1Sym0(writeData16, "SIO1writeData16");\r
654     LoadSio1Sym0(writeData32, "SIO1writeData32");\r
655     LoadSio1Sym0(writeStat16, "SIO1writeStat16");\r
656     LoadSio1Sym0(writeStat32, "SIO1writeStat32");\r
657     LoadSio1Sym0(writeMode16, "SIO1writeMode16");\r
658     LoadSio1Sym0(writeMode32, "SIO1writeMode32");\r
659     LoadSio1Sym0(writeCtrl16, "SIO1writeCtrl16");\r
660     LoadSio1Sym0(writeCtrl32, "SIO1writeCtrl32");\r
661     LoadSio1Sym0(writeBaud16, "SIO1writeBaud16");\r
662     LoadSio1Sym0(writeBaud32, "SIO1writeBaud32");\r
663     LoadSio1Sym0(readData16, "SIO1readData16");\r
664     LoadSio1Sym0(readData32, "SIO1readData32");\r
665     LoadSio1Sym0(readStat16, "SIO1readStat16");\r
666     LoadSio1Sym0(readStat32, "SIO1readStat32");\r
667     LoadSio1Sym0(readMode16, "SIO1readMode16");\r
668     LoadSio1Sym0(readMode32, "SIO1readMode32");\r
669     LoadSio1Sym0(readCtrl16, "SIO1readCtrl16");\r
670     LoadSio1Sym0(readCtrl32, "SIO1readCtrl32");\r
671     LoadSio1Sym0(readBaud16, "SIO1readBaud16");\r
672     LoadSio1Sym0(readBaud32, "SIO1readBaud32");\r
673     LoadSio1Sym0(registerCallback, "SIO1registerCallback");\r
674 \r
675     return 0;\r
676 }\r
677 \r
678 #endif\r
679 \r
680 int LoadPlugins() {\r
681         int ret;\r
682         char Plugin[MAXPATHLEN * 2];\r
683 \r
684         ReleasePlugins();\r
685         SysLibError();\r
686 \r
687         if (UsingIso()) {\r
688                 LoadCDRplugin(NULL);\r
689         } else {\r
690                 sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Cdr);\r
691                 if (LoadCDRplugin(Plugin) == -1) return -1;\r
692         }\r
693 \r
694         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Gpu);\r
695         if (LoadGPUplugin(Plugin) == -1) return -1;\r
696 \r
697         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Spu);\r
698         if (LoadSPUplugin(Plugin) == -1) return -1;\r
699 \r
700         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Pad1);\r
701         if (LoadPAD1plugin(Plugin) == -1) return -1;\r
702 \r
703         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Pad2);\r
704         if (LoadPAD2plugin(Plugin) == -1) return -1;\r
705 \r
706         if (strcmp("Disabled", Config.Net) == 0 || strcmp("", Config.Net) == 0)\r
707                 Config.UseNet = FALSE;\r
708         else {\r
709                 Config.UseNet = TRUE;\r
710                 sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Net);\r
711                 if (LoadNETplugin(Plugin) == -1) Config.UseNet = FALSE;\r
712         }\r
713 \r
714 #ifdef ENABLE_SIO1API\r
715         sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Sio1);\r
716         if (LoadSIO1plugin(Plugin) == -1) return -1;\r
717 #endif\r
718 \r
719         ret = CDR_init();\r
720         if (ret < 0) { SysMessage (_("Error initializing CD-ROM plugin: %d"), ret); return -1; }\r
721         ret = GPU_init();\r
722         if (ret < 0) { SysMessage (_("Error initializing GPU plugin: %d"), ret); return -1; }\r
723         ret = SPU_init();\r
724         if (ret < 0) { SysMessage (_("Error initializing SPU plugin: %d"), ret); return -1; }\r
725         ret = PAD1_init(1);\r
726         if (ret < 0) { SysMessage (_("Error initializing Controller 1 plugin: %d"), ret); return -1; }\r
727         ret = PAD2_init(2);\r
728         if (ret < 0) { SysMessage (_("Error initializing Controller 2 plugin: %d"), ret); return -1; }\r
729 \r
730         if (Config.UseNet) {\r
731                 ret = NET_init();\r
732                 if (ret < 0) { SysMessage (_("Error initializing NetPlay plugin: %d"), ret); return -1; }\r
733         }\r
734 \r
735 #ifdef ENABLE_SIO1API\r
736         ret = SIO1_init();\r
737         if (ret < 0) { SysMessage (_("Error initializing SIO1 plugin: %d"), ret); return -1; }\r
738 #endif\r
739 \r
740         SysPrintf(_("Plugins loaded.\n"));\r
741         return 0;\r
742 }\r
743 \r
744 void ReleasePlugins() {\r
745         if (Config.UseNet) {\r
746                 int ret = NET_close();\r
747                 if (ret < 0) Config.UseNet = FALSE;\r
748         }\r
749         NetOpened = FALSE;\r
750 \r
751         if (hCDRDriver != NULL || cdrIsoActive()) CDR_shutdown();\r
752         if (hGPUDriver != NULL) GPU_shutdown();\r
753         if (hSPUDriver != NULL) SPU_shutdown();\r
754         if (hPAD1Driver != NULL) PAD1_shutdown();\r
755         if (hPAD2Driver != NULL) PAD2_shutdown();\r
756 \r
757         if (Config.UseNet && hNETDriver != NULL) NET_shutdown(); \r
758 \r
759         if (hCDRDriver != NULL) { SysCloseLibrary(hCDRDriver); hCDRDriver = NULL; }\r
760         if (hGPUDriver != NULL) { SysCloseLibrary(hGPUDriver); hGPUDriver = NULL; }\r
761         if (hSPUDriver != NULL) { SysCloseLibrary(hSPUDriver); hSPUDriver = NULL; }\r
762         if (hPAD1Driver != NULL) { SysCloseLibrary(hPAD1Driver); hPAD1Driver = NULL; }\r
763         if (hPAD2Driver != NULL) { SysCloseLibrary(hPAD2Driver); hPAD2Driver = NULL; }\r
764 \r
765         if (Config.UseNet && hNETDriver != NULL) {\r
766                 SysCloseLibrary(hNETDriver); hNETDriver = NULL;\r
767         }\r
768 \r
769 #ifdef ENABLE_SIO1API\r
770         if (hSIO1Driver != NULL) {\r
771                 SIO1_shutdown();\r
772                 SysCloseLibrary(hSIO1Driver);\r
773                 hSIO1Driver = NULL;\r
774         }\r
775 #endif\r
776 }\r
777 \r
778 // for CD swap\r
779 int ReloadCdromPlugin()\r
780 {\r
781         if (hCDRDriver != NULL || cdrIsoActive()) CDR_shutdown();\r
782         if (hCDRDriver != NULL) { SysCloseLibrary(hCDRDriver); hCDRDriver = NULL; }\r
783 \r
784         if (UsingIso()) {\r
785                 LoadCDRplugin(NULL);\r
786         } else {\r
787                 char Plugin[MAXPATHLEN * 2];\r
788                 sprintf(Plugin, "%s/%s", Config.PluginsDir, Config.Cdr);\r
789                 if (LoadCDRplugin(Plugin) == -1) return -1;\r
790         }\r
791 \r
792         return CDR_init();\r
793 }\r
794 \r
795 void SetIsoFile(const char *filename) {\r
796         if (filename == NULL) {\r
797                 IsoFile[0] = '\0';\r
798                 return;\r
799         }\r
800         strncpy(IsoFile, filename, MAXPATHLEN - 1);\r
801 }\r
802 \r
803 const char *GetIsoFile(void) {\r
804         return IsoFile;\r
805 }\r
806 \r
807 boolean UsingIso(void) {\r
808         return (IsoFile[0] != '\0');\r
809 }\r
810 \r
811 void SetCdOpenCaseTime(s64 time) {\r
812         cdOpenCaseTime = time;\r
813 }\r