X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;ds=sidebyside;f=include%2Fpsemu_plugin_defs.h;h=40a67605bf9334f16409b937df4d55d6c1e9734f;hb=a11d0b9d6435cd306405d04c416ababb33f182a0;hp=09e950ab960195a7ec163f376348067505b2852e;hpb=10ed51a07184f5235e1c85cd9995aaa1481e0dca;p=pcsx_rearmed.git diff --git a/include/psemu_plugin_defs.h b/include/psemu_plugin_defs.h index 09e950ab..40a67605 100644 --- a/include/psemu_plugin_defs.h +++ b/include/psemu_plugin_defs.h @@ -5,6 +5,10 @@ extern "C" { #endif +// this can't be __stdcall like it was in PSEmu API as too many functions are mixed up +#undef CALLBACK +#define CALLBACK + // header version #define _PPDK_HEADER_VERSION 3 @@ -137,7 +141,7 @@ typedef struct long PADquery(void); unsigned char PADstartPoll(int); - unsigned char PADpoll(unsigned char); + unsigned char PADpoll(unsigned char, int *); */ @@ -153,6 +157,8 @@ typedef struct +// No controller +#define PSE_PAD_TYPE_NONE 0 // MOUSE SCPH-1030 #define PSE_PAD_TYPE_MOUSE 1 // NEGCON - 16 button analog controller SLPH-00001 @@ -194,9 +200,6 @@ typedef struct // controller type - fill it withe predefined values above unsigned char controllerType; - //0 : no multitap between psx and pad - //1 : multitap between psx and pad on port 1 - //2 : multitap between psx and pad on port 2 int portMultitap; int requestPadIndex; @@ -213,8 +216,18 @@ typedef struct unsigned char Vib[2]; unsigned char VibF[2]; - - unsigned char reserved[87]; + + //configuration mode Request 0x43 + int configMode; + + unsigned char txData[34]; + + unsigned char multitapLongModeEnabled; + unsigned char PadMode; // 0 : digital 1: analog + unsigned char reserved[52]; + + //Lightgun values + int absoluteX,absoluteY; } PadDataS;