mirror of
https://github.com/HarbourMasters/SpaghettiKart
synced 2026-06-08 12:28:35 -04:00
a1f0d32d66
* Update menus.c (#634) * Update common_data.yml (#635) * Renames for screenId and other changes (#636) * screenId renames * Rename surface map to collision mesh (#637) * Rename some stack vars (#638) * Fix syntax error (#639) * Rename some stack vars * Update collision.c * Collision Documentation (#640) * Collision related renames * update doxygen (#649) * change bool (#644) Co-authored-by: MegaMech <MegaMech@users.noreply.github.com> * Update (#642) * Delete trig_tables_bss.c (#650) * fix typo audio (#656) * fix typo src actor (#657) Co-authored-by: MegaMech <MegaMech@users.noreply.github.com> * fix typo include (#658) * fix course (#659) * fix typo debug (#660) * fix typo data (#661) * replace number with const (#665) * fix typo buffers (#655) * fix typo buffers * tweak ld file * rename to sMemoryPool * add a warning --------- * fix typo src (#654) * fix typo src * fix non matcing * Update code_80091750.c --------- * fix typo racing (#653) * fix typo racing * get it match * replace G_LINE3D to G_QUAD --------- * fix typo src (#652) * fix ending typo (#651) * Action more info when it doesn't match and fix first diff (#662) * Update linux-compile.yml * fix first-diff * Update first-diff.py --------- * document texture of kart (#663) * document texture of kart * change screenPlayerId to screenId * some documentation around object * Revert "some documentation around object" This reverts commit cbb39078e036bf2a417bed67359e910213acab28. * more rename --------- * Make evaluate_collision_players_palm_tree better (#667) This matches just the same as before, but using those two casts instead of shifts seems more likely to be accurate to the original source code Signed-off-by: Gabriel Ravier <gabravier@gmail.com> * add fedora instruciton (#666) * start documenting animation (#668) * start documenting animation * Update course_data.c * change comment * update libultra asm (#648) * update libultra asm * fix gcc __osThreadTail --------- * Document Vehicles (#641) * start doc collision * fix merge * finish rename fonction related to vehicle * document around waypoint of vehicle * make some modification * make some change and rename one * copy_ to oldPos * doc smoke ferry and train * some rename * fix some renaming * precise index * rename a funciton * simplify waypoint_vehicles * change some name * change some name * rename move_to_point_direction * fix some conflict * Update code_80005FD0.c * Update code_80005FD0.h --------- * Label a save info loop (#645) * save info * more gcc progress * fix a value and do a rename (#669) * update clang and add action (#664) * update clang and add action * try clang on course folder only * forget two file * Update course_displaylists.inc.c * forget few other file * Update course_vertices.inc.c * format all code while get it match * second pass * format other dir * disable clang format on bad ido code * fix some tabulation * revert format on tool dir * Update clang-format.yml * ignore gbi.h * add some read me instruction * fix error * format and fixing error * Update README.md --------- * Update linkonly_generator.py (#670) * format more file * update * fix compilation issue * remove course_metadata folder * re add course metadata folder * fix banshee bordwalk crash * fix windows eurk * Update CMakeLists.txt ---------
93 lines
2.6 KiB
C
93 lines
2.6 KiB
C
#include "libultra_internal.h"
|
|
#include "osContInternal.h"
|
|
|
|
void __osPackRequestData(u8);
|
|
void __osContGetInitData(u8*, OSContStatus*);
|
|
|
|
u32 _osContInitialized = 0;
|
|
|
|
extern u64 osClockRate;
|
|
|
|
// these probably belong in EEPROMlongread or something
|
|
u8 __osContLastCmd;
|
|
u8 _osContNumControllers;
|
|
OSTimer D_80196548;
|
|
OSMesgQueue _osContMesgQueue;
|
|
OSMesg _osContMesgBuff[4];
|
|
s32 osContInit(OSMesgQueue* mq, u8* bitpattern, OSContStatus* status) {
|
|
OSMesg mesg;
|
|
u32 ret = 0;
|
|
OSTime currentTime;
|
|
OSTimer timer;
|
|
OSMesgQueue timerMesgQueue;
|
|
|
|
if (_osContInitialized) {
|
|
return 0;
|
|
}
|
|
_osContInitialized = 1;
|
|
currentTime = osGetTime();
|
|
if (500000 * osClockRate / 1000000 > currentTime) {
|
|
osCreateMesgQueue(&timerMesgQueue, &mesg, 1);
|
|
osSetTimer(&timer, 500000 * osClockRate / 1000000 - currentTime, 0, &timerMesgQueue, &mesg);
|
|
osRecvMesg(&timerMesgQueue, &mesg, OS_MESG_BLOCK);
|
|
}
|
|
//! @todo figure out what it means
|
|
_osContNumControllers = 4;
|
|
__osPackRequestData(0);
|
|
ret = __osSiRawStartDma(OS_WRITE, _osContCmdBuf);
|
|
osRecvMesg(mq, &mesg, OS_MESG_BLOCK);
|
|
ret = __osSiRawStartDma(OS_READ, _osContCmdBuf);
|
|
osRecvMesg(mq, &mesg, OS_MESG_BLOCK);
|
|
__osContGetInitData(bitpattern, status);
|
|
__osContLastCmd = 0;
|
|
__osSiCreateAccessQueue();
|
|
osCreateMesgQueue(&_osContMesgQueue, _osContMesgBuff, 1);
|
|
return ret;
|
|
}
|
|
void __osContGetInitData(u8* bitpattern, OSContStatus* status) {
|
|
OSContPackedRequest* cmdBufPtr;
|
|
OSContPackedRequest response;
|
|
s32 i;
|
|
u8 sp7;
|
|
|
|
sp7 = 0;
|
|
cmdBufPtr = &(_osContCmdBuf[0].request);
|
|
for (i = 0; i < _osContNumControllers; i++, cmdBufPtr++, status++) {
|
|
response = *(OSContPackedRequest*) cmdBufPtr;
|
|
status->errnum = (response.rxLen & 0xc0) >> 4;
|
|
if (status->errnum == 0) {
|
|
status->type = response.data2 << 8 | response.data1;
|
|
status->status = response.data3;
|
|
|
|
sp7 |= 1 << i;
|
|
}
|
|
}
|
|
*bitpattern = sp7;
|
|
}
|
|
void __osPackRequestData(u8 command) {
|
|
OSContPackedRequest* cmdBufPtr;
|
|
OSContPackedRequest request;
|
|
s32 i;
|
|
|
|
// some kind of weird zeroing code
|
|
for (i = 0; i < 0x10; i++) {
|
|
*((u32*) &_osContCmdBuf + i) = 0;
|
|
}
|
|
|
|
_osContPifCtrl = 1;
|
|
cmdBufPtr = &_osContCmdBuf[0].request;
|
|
request.padOrEnd = 255;
|
|
request.txLen = 1;
|
|
request.rxLen = 3;
|
|
request.command = command;
|
|
request.data1 = 255;
|
|
request.data2 = 255;
|
|
request.data3 = 255;
|
|
request.data4 = 255;
|
|
|
|
for (i = 0; i < _osContNumControllers; i++) {
|
|
*cmdBufPtr++ = request;
|
|
}
|
|
cmdBufPtr->padOrEnd = 254;
|
|
}
|