ps2sdk
1.1
A collection of Open Source libraries used for developing applications on Sony's PlayStation 2® (PS2).
|
Go to the source code of this file.
Data Structures | |
struct | padButtonStatus |
Macros | |
#define | PAD_LEFT 0x0080 |
#define | PAD_DOWN 0x0040 |
#define | PAD_RIGHT 0x0020 |
#define | PAD_UP 0x0010 |
#define | PAD_START 0x0008 |
#define | PAD_R3 0x0004 |
#define | PAD_L3 0x0002 |
#define | PAD_SELECT 0x0001 |
#define | PAD_SQUARE 0x8000 |
#define | PAD_CROSS 0x4000 |
#define | PAD_CIRCLE 0x2000 |
#define | PAD_TRIANGLE 0x1000 |
#define | PAD_R1 0x0800 |
#define | PAD_L1 0x0400 |
#define | PAD_R2 0x0200 |
#define | PAD_L2 0x0100 |
#define | PAD_STATE_DISCONN 0x00 |
#define | PAD_STATE_FINDPAD 0x01 |
#define | PAD_STATE_FINDCTP1 0x02 |
#define | PAD_STATE_EXECCMD 0x05 |
#define | PAD_STATE_STABLE 0x06 |
#define | PAD_STATE_ERROR 0x07 |
#define | PAD_RSTAT_COMPLETE 0x00 |
#define | PAD_RSTAT_FAILED 0x01 |
#define | PAD_RSTAT_BUSY 0x02 |
#define | PAD_TYPE_NEJICON 0x2 |
#define | PAD_TYPE_KONAMIGUN 0x3 |
#define | PAD_TYPE_DIGITAL 0x4 |
#define | PAD_TYPE_ANALOG 0x5 |
#define | PAD_TYPE_NAMCOGUN 0x6 |
#define | PAD_TYPE_DUALSHOCK 0x7 |
#define | PAD_TYPE_JOGCON 0xE |
#define | PAD_TYPE_EX_TSURICON 0x100 |
#define | PAD_TYPE_EX_JOGCON 0x300 |
#define | PAD_MODECURID 1 |
#define | PAD_MODECUREXID 2 |
#define | PAD_MODECUROFFS 3 |
#define | PAD_MODETABLE 4 |
#define | PAD_MMODE_DIGITAL 0 |
#define | PAD_MMODE_DUALSHOCK 1 |
#define | PAD_MMODE_UNLOCK 2 |
#define | PAD_MMODE_LOCK 3 |
#define | PAD_ACTFUNC 1 |
#define | PAD_ACTSUB 2 |
#define | PAD_ACTSIZE 3 |
#define | PAD_ACTCURR 4 |
Functions | |
int | padInit (int mode) |
int | padPortInit (int mode) |
int | padEnd (void) |
int | padPortOpen (int port, int slot, void *padArea) |
int | padPortClose (int port, int slot) |
unsigned char | padRead (int port, int slot, struct padButtonStatus *data) |
int | padGetState (int port, int slot) |
unsigned char | padGetReqState (int port, int slot) |
int | padSetReqState (int port, int slot, int state) |
void | padStateInt2String (int state, char buf[16]) |
void | padReqStateInt2String (int state, char buf[16]) |
int | padGetPortMax (void) |
int | padGetSlotMax (int port) |
int | padGetModVersion () |
int | padInfoMode (int port, int slot, int infoMode, int index) |
int | padSetMainMode (int port, int slot, int mode, int lock) |
int | padInfoPressMode (int port, int slot) |
int | padEnterPressMode (int port, int slot) |
int | padExitPressMode (int port, int slot) |
int | padGetButtonMask (int port, int slot) |
int | padSetButtonInfo (int port, int slot, int buttonInfo) |
unsigned char | padInfoAct (int port, int slot, int word, int byte) |
int | padSetActAlign (int port, int slot, char act_align[6]) |
int | padSetActDirect (int port, int slot, char act_align[6]) |
int | padGetConnection (int port, int slot) |
Pad externals
Definition in file libpad.h.
int padEnd | ( | void | ) |
Ends all pad communication Note: PADMAN from release 1.3.4 does not have padPortInit implemented. As a result, it is impossible to reinitialize libpad after calling padEnd(). This was known as padClose in the really early official SDK releases.
Definition at line 372 of file libpad.c.
References buffer, NULL, PAD_RPCCMD_END, padInitialised, padsif, and SifCallRpc().
int padEnterPressMode | ( | int | port, |
int | slot | ||
) |
Pressure sensitive mode ON
Definition at line 690 of file libpad.c.
References padSetButtonInfo(), port, and slot.
Referenced by initializePad(), main(), and pad_set_sensitivity().
int padExitPressMode | ( | int | port, |
int | slot | ||
) |
Check for newer version Pressure sensitive mode OFF
Definition at line 696 of file libpad.c.
References padSetButtonInfo(), port, and slot.
Referenced by main(), and pad_set_sensitivity().
int padGetButtonMask | ( | int | port, |
int | slot | ||
) |
Definition at line 703 of file libpad.c.
References buffer, NULL, PAD_RPCCMD_GET_BTNMASK, padsif, port, SifCallRpc(), and slot.
Referenced by padInfoPressMode().
int padGetConnection | ( | int | port, |
int | slot | ||
) |
int padGetModVersion | ( | ) |
int padGetPortMax | ( | void | ) |
Returns # slots on the PS2 (usally 2)
Definition at line 548 of file libpad.c.
References buffer, NULL, PAD_RPCCMD_GET_PORTMAX, padsif, and SifCallRpc().
Referenced by main().
unsigned char padGetReqState | ( | int | port, |
int | slot | ||
) |
Get pad request state
Definition at line 511 of file libpad.c.
References padGetDmaStr(), port, pad_data::reqState, and slot.
Referenced by padGetState(), and padWait().
int padGetSlotMax | ( | int | port | ) |
Returns # slots the port has (usually 1) probably 4 if using a multi tap (not tested)
Definition at line 560 of file libpad.c.
References buffer, NULL, PAD_RPCCMD_GET_SLOTMAX, padsif, port, and SifCallRpc().
Referenced by main().
int padGetState | ( | int | port, |
int | slot | ||
) |
Get current pad state Wait until state == 6 (Ready) before trying to access the pad
Definition at line 482 of file libpad.c.
References PAD_RSTAT_BUSY, PAD_STATE_ERROR, PAD_STATE_EXECCMD, PAD_STATE_FINDPAD, PAD_STATE_STABLE, padGetDmaStr(), padGetReqState(), port, slot, and pad_data::state.
Referenced by find_controllers(), main(), pad_get_state(), padWait(), and waitPadReady().
unsigned char padInfoAct | ( | int | port, |
int | slot, | ||
int | word, | ||
int | byte | ||
) |
Get actuator status for this controller If padInfoAct(port, slot, -1, 0) != 0, the controller has actuators (i think ;) )
Definition at line 738 of file libpad.c.
References actuator, buffer, NULL, PAD_RPCCMD_INFO_ACT, PAD_RSTAT_BUSY, padGetDmaStr(), padSetReqState(), padsif, port, SifCallRpc(), and slot.
Referenced by initializePad(), main(), and pad_init_actuators().
int padInfoMode | ( | int | port, |
int | slot, | ||
int | infoMode, | ||
int | index | ||
) |
Get pad info (digital (4), dualshock (7), etc..)
Definition at line 588 of file libpad.c.
References buffer, index, infoMode, NULL, PAD_MODECUREXID, PAD_MODECURID, PAD_MODECUROFFS, PAD_MODETABLE, PAD_RPCCMD_INFO_MODE, PAD_RSTAT_BUSY, padGetDmaStr(), padSetReqState(), padsif, port, pad_data::reqState, SifCallRpc(), and slot.
Referenced by initializePad(), main(), pad_get_num_modes(), pad_get_type(), pad_has_type(), and pad_init_actuators().
int padInfoPressMode | ( | int | port, |
int | slot | ||
) |
Check if the pad has pressure sensitive buttons
Definition at line 675 of file libpad.c.
References padGetButtonMask(), port, and slot.
Referenced by initializePad(), main(), and pad_set_sensitivity().
int padInit | ( | int | mode | ) |
Initialise libpad
mode | Must be set to 0. |
Definition at line 297 of file libpad.c.
References _iop_reboot_count, mode, nopdelay(), NULL, PAD_BIND_RPC_ID1, PAD_BIND_RPC_ID2, padInitialised, padPortInit(), padsif, SifRpcClientData_t::server, and SifBindRpc().
Referenced by main().
int padPortClose | ( | int | port, |
int | slot | ||
) |
Closes an opened port.
port | Port to close |
slot | Slot to close |
Definition at line 449 of file libpad.c.
References buffer, NULL, pad_state::open, PAD_RPCCMD_CLOSE, padsif, PadState, port, SifCallRpc(), and slot.
Referenced by find_controllers(), and pad_close().
int padPortInit | ( | int | mode | ) |
Initialise pad ports. Automatically called by padInit(), there is no need to call this function directly.
mode | Must be set to 0. |
Note: PADMAN from release 1.3.4 does not have this function implemented. As a result, it is impossible to reinitialize libpad after calling padEnd().
Definition at line 338 of file libpad.c.
References buffer, NULL, pad_state::open, PAD_RPCCMD_INIT, padsif, PadState, pad_state::port, SifCallRpc(), and pad_state::slot.
Referenced by padInit().
int padPortOpen | ( | int | port, |
int | slot, | ||
void * | padArea | ||
) |
port | Port to open |
slot | Slot to open |
padArea | The address of the buffer for storing the pad status. Must be a 256-byte region (2xsizeof(struct pad_data). Must be a 64-byte aligned address. For the old libpad, at least 16-bytes alignment. |
Definition at line 392 of file libpad.c.
References buffer, data, pad_data::frame, pad_data::length, NULL, pad_data::ok, pad_state::open, PAD_RPCCMD_OPEN, PAD_RSTAT_BUSY, PAD_STATE_EXECCMD, padArea, pad_state::padBuf, pad_state::padData, padsif, PadState, port, pad_data::reqState, SifCallRpc(), slot, and pad_data::state.
Referenced by find_controllers(), main(), and pad_open().
unsigned char padRead | ( | int | port, |
int | slot, | ||
struct padButtonStatus * | data | ||
) |
Read pad data
port | Port number of the pad to get the status for. |
slot | Slot number of the pad to get the status for. |
data | A pointer to a 32 byte array where the result is stored |
Definition at line 470 of file libpad.c.
References data, pad_data::data, pad_data::length, padGetDmaStr(), port, and slot.
Referenced by main(), and pad_get_buttons().
void padReqStateInt2String | ( | int | state, |
char | buf[16] | ||
) |
int padSetActAlign | ( | int | port, |
int | slot, | ||
char | act_align[6] | ||
) |
Initalise actuators. On dual shock controller: act_align[0] = 0 enables 'small' engine act_align[1] = 1 enables 'big' engine set act_align[2-5] to 0xff (disable)
Definition at line 777 of file libpad.c.
References actAlign, buffer, NULL, PAD_RPCCMD_SET_ACTALIGN, PAD_RSTAT_BUSY, padSetReqState(), padsif, port, SifCallRpc(), and slot.
Referenced by initializePad(), main(), and pad_init_actuators().
int padSetActDirect | ( | int | port, |
int | slot, | ||
char | act_align[6] | ||
) |
Set actuator status on dual shock controller, act_align[0] = 0/1 turns off/on 'small' engine act_align[1] = 0-255 sets 'big' engine speed
Definition at line 800 of file libpad.c.
References actAlign, buffer, NULL, PAD_RPCCMD_SET_ACTDIR, padsif, port, SifCallRpc(), and slot.
Referenced by main(), pad_set_actuators(), and padStartAct().
int padSetButtonInfo | ( | int | port, |
int | slot, | ||
int | buttonInfo | ||
) |
Definition at line 717 of file libpad.c.
References buffer, buttonInfo, NULL, PAD_RPCCMD_SET_BTNINFO, PAD_RSTAT_BUSY, padSetReqState(), padsif, port, SifCallRpc(), and slot.
Referenced by padEnterPressMode(), and padExitPressMode().
int padSetMainMode | ( | int | port, |
int | slot, | ||
int | mode, | ||
int | lock | ||
) |
mode = 1, -> Analog/dual shock enabled; mode = 0 -> Digital lock = 3 -> Mode not changeable by user
Definition at line 656 of file libpad.c.
References buffer, lock, mode, NULL, PAD_RPCCMD_SET_MMODE, PAD_RSTAT_BUSY, padSetReqState(), padsif, port, SifCallRpc(), and slot.
Referenced by initializePad(), main(), and pad_set_mode().
int padSetReqState | ( | int | port, |
int | slot, | ||
int | state | ||
) |
Set pad request state (after a param setting) No need to export this one perhaps..
Definition at line 521 of file libpad.c.
References padGetDmaStr(), port, pad_data::reqState, slot, and pad_data::state.
Referenced by padInfoAct(), padInfoMode(), padSetActAlign(), padSetButtonInfo(), and padSetMainMode().
void padStateInt2String | ( | int | state, |
char | buf[16] | ||
) |
Definition at line 532 of file libpad.c.
References padStateString, and pad_data::state.
Referenced by waitPadReady().