Files
oot/src/libultra/io/controller.c
T
Tharo a57d449196 [iQue] Match remaining libultra/io files (#2411)
* [iQue] Match remaining libultra/io files

* Match osSpTaskYielded

* Fix bss, remove double space in controller.h

* Fix BSS
2025-01-09 19:31:11 -05:00

123 lines
3.0 KiB
C

#include "global.h"
OSPifRam __osContPifRam;
u8 __osContLastCmd;
u8 __osMaxControllers; // always 4
OSTimer __osEepromTimer;
OSMesgQueue __osEepromTimerMsgQueue;
OSMesg __osEepromTimerMsg;
u32 __osContInitialized = false;
#define HALF_SECOND OS_USEC_TO_CYCLES(500000)
s32 osContInit(OSMesgQueue* mq, u8* ctlBitfield, OSContStatus* status) {
OSMesg msg;
s32 ret = 0;
OSTime currentTime;
OSTimer timer;
OSMesgQueue timerMesgQueue;
if (__osContInitialized) {
return 0;
}
__osContInitialized = true;
currentTime = osGetTime();
if (currentTime < HALF_SECOND) {
osCreateMesgQueue(&timerMesgQueue, &msg, 1);
osSetTimer(&timer, HALF_SECOND - currentTime, 0, &timerMesgQueue, &msg);
osRecvMesg(&timerMesgQueue, &msg, OS_MESG_BLOCK);
}
__osMaxControllers = MAXCONTROLLERS;
__osPackRequestData(CONT_CMD_REQUEST_STATUS);
ret = __osSiRawStartDma(OS_WRITE, &__osContPifRam);
osRecvMesg(mq, &msg, OS_MESG_BLOCK);
ret = __osSiRawStartDma(OS_READ, &__osContPifRam);
osRecvMesg(mq, &msg, OS_MESG_BLOCK);
__osContGetInitData(ctlBitfield, status);
#ifdef BBPLAYER
__osContLastCmd = CONT_CMD_CHANNEL_RESET;
#else
__osContLastCmd = CONT_CMD_REQUEST_STATUS;
#endif
__osSiCreateAccessQueue();
osCreateMesgQueue(&__osEepromTimerMsgQueue, &__osEepromTimerMsg, 1);
return ret;
}
void __osContGetInitData(u8* ctlBitfield, OSContStatus* data) {
u8* ptr;
__OSContRequesFormat req;
s32 i;
u8 bits = 0;
ptr = (u8*)&__osContPifRam;
for (i = 0; i < __osMaxControllers; i++, ptr += sizeof(req), data++) {
req = *(__OSContRequesFormat*)ptr;
data->errno = CHNL_ERR(req);
if (data->errno) {
continue;
}
data->type = req.typel << 8 | req.typeh;
#ifdef BBPLAYER
data->status = __osBbPakAddress[i] != 0;
#else
data->status = req.status;
#endif
bits |= 1 << i;
}
#ifdef BBPLAYER
if (__osBbIsBb && __osBbHackFlags != 0) {
OSContStatus tmp;
bits = (bits & ~((1 << __osBbHackFlags) | 1)) | ((bits & 1) << __osBbHackFlags) |
((bits & (1 << __osBbHackFlags)) >> __osBbHackFlags);
data -= __osMaxControllers;
tmp = data[0];
data[0] = data[__osBbHackFlags];
data[__osBbHackFlags] = tmp;
}
#endif
*ctlBitfield = bits;
}
void __osPackRequestData(u8 poll) {
u8* ptr;
__OSContRequesFormat req;
s32 i;
for (i = 0; i < ARRAY_COUNT(__osContPifRam.ram); i++) {
__osContPifRam.ram[i] = 0;
}
__osContPifRam.status = CONT_CMD_EXE;
ptr = (u8*)&__osContPifRam;
req.align = CONT_CMD_NOP;
req.txsize = CONT_CMD_RESET_TX;
req.rxsize = CONT_CMD_RESET_RX;
req.cmd = poll;
req.typeh = CONT_CMD_NOP;
req.typel = CONT_CMD_NOP;
req.status = CONT_CMD_NOP;
req.align1 = CONT_CMD_NOP;
for (i = 0; i < __osMaxControllers; i++) {
*((__OSContRequesFormat*)ptr) = req;
ptr += sizeof(req);
}
*ptr = CONT_CMD_END;
}