adjust irq10 and rcnt for pal
[pcsx_rearmed.git] / libpcsxcore / plugins.c
CommitLineData
ef79bbde
P
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
27static char IsoFile[MAXPATHLEN] = "";\r
28static s64 cdOpenCaseTime = 0;\r
29\r
30GPUupdateLace GPU_updateLace;\r
31GPUinit GPU_init;\r
32GPUshutdown GPU_shutdown; \r
33GPUconfigure GPU_configure;\r
34GPUtest GPU_test;\r
35GPUabout GPU_about;\r
36GPUopen GPU_open;\r
37GPUclose GPU_close;\r
38GPUreadStatus GPU_readStatus;\r
39GPUreadData GPU_readData;\r
40GPUreadDataMem GPU_readDataMem;\r
41GPUwriteStatus GPU_writeStatus; \r
42GPUwriteData GPU_writeData;\r
43GPUwriteDataMem GPU_writeDataMem;\r
44GPUdmaChain GPU_dmaChain;\r
45GPUkeypressed GPU_keypressed;\r
46GPUdisplayText GPU_displayText;\r
47GPUmakeSnapshot GPU_makeSnapshot;\r
48GPUfreeze GPU_freeze;\r
49GPUgetScreenPic GPU_getScreenPic;\r
50GPUshowScreenPic GPU_showScreenPic;\r
ef79bbde
P
51GPUvBlank GPU_vBlank;\r
52\r
53CDRinit CDR_init;\r
54CDRshutdown CDR_shutdown;\r
55CDRopen CDR_open;\r
56CDRclose CDR_close; \r
57CDRtest CDR_test;\r
58CDRgetTN CDR_getTN;\r
59CDRgetTD CDR_getTD;\r
60CDRreadTrack CDR_readTrack;\r
61CDRgetBuffer CDR_getBuffer;\r
62CDRplay CDR_play;\r
63CDRstop CDR_stop;\r
64CDRgetStatus CDR_getStatus;\r
65CDRgetDriveLetter CDR_getDriveLetter;\r
66CDRgetBufferSub CDR_getBufferSub;\r
67CDRconfigure CDR_configure;\r
68CDRabout CDR_about;\r
69CDRsetfilename CDR_setfilename;\r
70CDRreadCDDA CDR_readCDDA;\r
71CDRgetTE CDR_getTE;\r
72\r
ef79bbde
P
73SPUinit SPU_init;\r
74SPUshutdown SPU_shutdown;\r
ef79bbde
P
75SPUopen SPU_open;\r
76SPUclose SPU_close;\r
ef79bbde
P
77SPUwriteRegister SPU_writeRegister;\r
78SPUreadRegister SPU_readRegister;\r
ef79bbde
P
79SPUwriteDMAMem SPU_writeDMAMem;\r
80SPUreadDMAMem SPU_readDMAMem;\r
81SPUplayADPCMchannel SPU_playADPCMchannel;\r
82SPUfreeze SPU_freeze;\r
83SPUregisterCallback SPU_registerCallback;\r
2b30c129 84SPUregisterScheduleCb SPU_registerScheduleCb;\r
ef79bbde
P
85SPUasync SPU_async;\r
86SPUplayCDDAchannel SPU_playCDDAchannel;\r
87\r
88PADconfigure PAD1_configure;\r
89PADabout PAD1_about;\r
90PADinit PAD1_init;\r
91PADshutdown PAD1_shutdown;\r
92PADtest PAD1_test;\r
93PADopen PAD1_open;\r
94PADclose PAD1_close;\r
95PADquery PAD1_query;\r
96PADreadPort1 PAD1_readPort1;\r
97PADkeypressed PAD1_keypressed;\r
98PADstartPoll PAD1_startPoll;\r
99PADpoll PAD1_poll;\r
100PADsetSensitive PAD1_setSensitive;\r
101\r
102PADconfigure PAD2_configure;\r
103PADabout PAD2_about;\r
104PADinit PAD2_init;\r
105PADshutdown PAD2_shutdown;\r
106PADtest PAD2_test;\r
107PADopen PAD2_open;\r
108PADclose PAD2_close;\r
109PADquery PAD2_query;\r
110PADreadPort2 PAD2_readPort2;\r
111PADkeypressed PAD2_keypressed;\r
112PADstartPoll PAD2_startPoll;\r
113PADpoll PAD2_poll;\r
114PADsetSensitive PAD2_setSensitive;\r
115\r
116NETinit NET_init;\r
117NETshutdown NET_shutdown;\r
118NETopen NET_open;\r
119NETclose NET_close; \r
120NETtest NET_test;\r
121NETconfigure NET_configure;\r
122NETabout NET_about;\r
123NETpause NET_pause;\r
124NETresume NET_resume;\r
125NETqueryPlayer NET_queryPlayer;\r
126NETsendData NET_sendData;\r
127NETrecvData NET_recvData;\r
128NETsendPadData NET_sendPadData;\r
129NETrecvPadData NET_recvPadData;\r
130NETsetInfo NET_setInfo;\r
131NETkeypressed NET_keypressed;\r
132\r
133#ifdef ENABLE_SIO1API\r
134\r
135SIO1init SIO1_init;\r
136SIO1shutdown SIO1_shutdown;\r
137SIO1open SIO1_open;\r
138SIO1close SIO1_close; \r
139SIO1test SIO1_test;\r
140SIO1configure SIO1_configure;\r
141SIO1about SIO1_about;\r
142SIO1pause SIO1_pause;\r
143SIO1resume SIO1_resume;\r
144SIO1keypressed SIO1_keypressed;\r
145SIO1writeData8 SIO1_writeData8;\r
146SIO1writeData16 SIO1_writeData16;\r
147SIO1writeData32 SIO1_writeData32;\r
148SIO1writeStat16 SIO1_writeStat16;\r
149SIO1writeStat32 SIO1_writeStat32;\r
150SIO1writeMode16 SIO1_writeMode16;\r
151SIO1writeMode32 SIO1_writeMode32;\r
152SIO1writeCtrl16 SIO1_writeCtrl16;\r
153SIO1writeCtrl32 SIO1_writeCtrl32;\r
154SIO1writeBaud16 SIO1_writeBaud16;\r
155SIO1writeBaud32 SIO1_writeBaud32;\r
156SIO1readData8 SIO1_readData8;\r
157SIO1readData16 SIO1_readData16;\r
158SIO1readData32 SIO1_readData32;\r
159SIO1readStat16 SIO1_readStat16;\r
160SIO1readStat32 SIO1_readStat32;\r
161SIO1readMode16 SIO1_readMode16;\r
162SIO1readMode32 SIO1_readMode32;\r
163SIO1readCtrl16 SIO1_readCtrl16;\r
164SIO1readCtrl32 SIO1_readCtrl32;\r
165SIO1readBaud16 SIO1_readBaud16;\r
166SIO1readBaud32 SIO1_readBaud32;\r
167SIO1registerCallback SIO1_registerCallback;\r
168\r
169#endif\r
170\r
171static 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
183void *hGPUDriver = NULL;\r
184\r
185void CALLBACK GPU__displayText(char *pText) {\r
186 SysPrintf("%s\n", pText);\r
187}\r
188\r
189long CALLBACK GPU__configure(void) { return 0; }\r
190long CALLBACK GPU__test(void) { return 0; }\r
191void CALLBACK GPU__about(void) {}\r
192void CALLBACK GPU__makeSnapshot(void) {}\r
193void CALLBACK GPU__keypressed(int key) {}\r
194long CALLBACK GPU__getScreenPic(unsigned char *pMem) { return -1; }\r
195long CALLBACK GPU__showScreenPic(unsigned char *pMem) { return -1; }\r
ef79bbde
P
196void 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
208static 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
ef79bbde
P
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
243void *hCDRDriver = NULL;\r
244\r
245long CALLBACK CDR__play(unsigned char *sector) { return 0; }\r
246long CALLBACK CDR__stop(void) { return 0; }\r
247\r
248long 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
257char* CALLBACK CDR__getDriveLetter(void) { return NULL; }\r
258long CALLBACK CDR__configure(void) { return 0; }\r
259long CALLBACK CDR__test(void) { return 0; }\r
260void CALLBACK CDR__about(void) {}\r
261long 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
273static 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
20a3a441 310static void *hSPUDriver = NULL;\r
311static void CALLBACK SPU__registerScheduleCb(void (CALLBACK *cb)(unsigned int)) {}\r
ef79bbde
P
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
323static int LoadSPUplugin(const char *SPUdll) {\r
324 void *drv;\r
325\r
326 hSPUDriver = SysLoadLibrary(SPUdll);\r
327 if (hSPUDriver == NULL) {\r
ef79bbde
P
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
ef79bbde
P
335 LoadSpuSym1(writeRegister, "SPUwriteRegister");\r
336 LoadSpuSym1(readRegister, "SPUreadRegister"); \r
ef79bbde
P
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
2b30c129 342 LoadSpuSym0(registerScheduleCb, "SPUregisterScheduleCb");\r
ef79bbde
P
343 LoadSpuSymN(async, "SPUasync");\r
344 LoadSpuSymN(playCDDAchannel, "SPUplayCDDAchannel");\r
345\r
346 return 0;\r
347}\r
348\r
349void *hPAD1Driver = NULL;\r
350void *hPAD2Driver = NULL;\r
351\r
352static unsigned char buf[256];\r
353unsigned char stdpar[10] = { 0x00, 0x41, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };\r
354unsigned char mousepar[8] = { 0x00, 0x12, 0x5a, 0xff, 0xff, 0xff, 0xff };\r
355unsigned char analogpar[9] = { 0x00, 0xff, 0x5a, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };\r
356\r
357static int bufcount, bufc;\r
358\r
359PadDataS padd1, padd2;\r
360\r
361unsigned 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
422unsigned char _PADpoll(unsigned char value) {\r
423 if (bufc > bufcount) return 0;\r
424 return buf[bufc++];\r
425}\r
426\r
427unsigned 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
435unsigned char CALLBACK PAD1__poll(unsigned char value) {\r
436 return _PADpoll(value);\r
437}\r
438\r
439long CALLBACK PAD1__configure(void) { return 0; }\r
440void CALLBACK PAD1__about(void) {}\r
441long CALLBACK PAD1__test(void) { return 0; }\r
442long CALLBACK PAD1__query(void) { return 3; }\r
443long 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
455static 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
481unsigned 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
489unsigned char CALLBACK PAD2__poll(unsigned char value) {\r
490 return _PADpoll(value);\r
491}\r
492\r
493long CALLBACK PAD2__configure(void) { return 0; }\r
494void CALLBACK PAD2__about(void) {}\r
495long CALLBACK PAD2__test(void) { return 0; }\r
496long CALLBACK PAD2__query(void) { return PSE_PAD_USE_PORT1 | PSE_PAD_USE_PORT2; }\r
497long 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
509static 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
535void *hNETDriver = NULL;\r
536\r
537void CALLBACK NET__setInfo(netInfo *info) {}\r
538void CALLBACK NET__keypressed(int key) {}\r
539long CALLBACK NET__configure(void) { return 0; }\r
540long CALLBACK NET__test(void) { return 0; }\r
541void 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
553static 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
583void *hSIO1Driver = NULL;\r
584\r
585long CALLBACK SIO1__init(void) { return 0; }\r
586long CALLBACK SIO1__shutdown(void) { return 0; }\r
587long CALLBACK SIO1__open(void) { return 0; }\r
588long CALLBACK SIO1__close(void) { return 0; }\r
589long CALLBACK SIO1__configure(void) { return 0; }\r
590long CALLBACK SIO1__test(void) { return 0; }\r
591void CALLBACK SIO1__about(void) {}\r
592void CALLBACK SIO1__pause(void) {}\r
593void CALLBACK SIO1__resume(void) {}\r
594long CALLBACK SIO1__keypressed(int key) { return 0; }\r
595void CALLBACK SIO1__writeData8(unsigned char val) {}\r
596void CALLBACK SIO1__writeData16(unsigned short val) {}\r
597void CALLBACK SIO1__writeData32(unsigned long val) {}\r
598void CALLBACK SIO1__writeStat16(unsigned short val) {}\r
599void CALLBACK SIO1__writeStat32(unsigned long val) {}\r
600void CALLBACK SIO1__writeMode16(unsigned short val) {}\r
601void CALLBACK SIO1__writeMode32(unsigned long val) {}\r
602void CALLBACK SIO1__writeCtrl16(unsigned short val) {}\r
603void CALLBACK SIO1__writeCtrl32(unsigned long val) {}\r
604void CALLBACK SIO1__writeBaud16(unsigned short val) {}\r
605void CALLBACK SIO1__writeBaud32(unsigned long val) {}\r
606unsigned char CALLBACK SIO1__readData8(void) { return 0; }\r
607unsigned short CALLBACK SIO1__readData16(void) { return 0; }\r
608unsigned long CALLBACK SIO1__readData32(void) { return 0; }\r
609unsigned short CALLBACK SIO1__readStat16(void) { return 0; }\r
610unsigned long CALLBACK SIO1__readStat32(void) { return 0; }\r
611unsigned short CALLBACK SIO1__readMode16(void) { return 0; }\r
612unsigned long CALLBACK SIO1__readMode32(void) { return 0; }\r
613unsigned short CALLBACK SIO1__readCtrl16(void) { return 0; }\r
614unsigned long CALLBACK SIO1__readCtrl32(void) { return 0; }\r
615unsigned short CALLBACK SIO1__readBaud16(void) { return 0; }\r
616unsigned long CALLBACK SIO1__readBaud32(void) { return 0; }\r
617void CALLBACK SIO1__registerCallback(void (CALLBACK *callback)(void)) {};\r
618\r
619void 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
633static 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
ef79bbde
P
680int LoadPlugins() {\r
681 int ret;\r
7a8d521f 682 char Plugin[MAXPATHLEN * 2];\r
ef79bbde
P
683\r
684 ReleasePlugins();\r
b2058a5b 685 SysLibError();\r
ef79bbde
P
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
744void 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
3cf51e08 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
ef79bbde
P
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
1df403c5 778// for CD swap\r
779int ReloadCdromPlugin()\r
780{\r
781 if (hCDRDriver != NULL || cdrIsoActive()) CDR_shutdown();\r
3cf51e08 782 if (hCDRDriver != NULL) { SysCloseLibrary(hCDRDriver); hCDRDriver = NULL; }\r
1df403c5 783\r
784 if (UsingIso()) {\r
785 LoadCDRplugin(NULL);\r
786 } else {\r
7a8d521f 787 char Plugin[MAXPATHLEN * 2];\r
1df403c5 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
ef79bbde
P
795void SetIsoFile(const char *filename) {\r
796 if (filename == NULL) {\r
797 IsoFile[0] = '\0';\r
798 return;\r
799 }\r
7a8d521f 800 strncpy(IsoFile, filename, MAXPATHLEN - 1);\r
ef79bbde
P
801}\r
802\r
803const char *GetIsoFile(void) {\r
804 return IsoFile;\r
805}\r
806\r
807boolean UsingIso(void) {\r
808 return (IsoFile[0] != '\0');\r
809}\r
810\r
811void SetCdOpenCaseTime(s64 time) {\r
812 cdOpenCaseTime = time;\r
813}\r