|
ps2sdk
1.1
A collection of Open Source libraries used for developing applications on Sony's PlayStation 2® (PS2).
|
This graph shows which files directly or indirectly include this file: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().