mirror of
https://github.com/HarbourMasters/2ship2harkinian.git
synced 2024-11-27 08:10:31 +00:00
2332f63f5a
Co-authored-by: Louis <35883445+louist103@users.noreply.github.com> Co-authored-by: Nicholas Estelami <NEstelami@users.noreply.github.com> Co-authored-by: Random06457 <28494085+Random06457@users.noreply.github.com>
211 lines
6.2 KiB
C
211 lines
6.2 KiB
C
#ifndef PR_CONTROLLER_H
|
|
#define PR_CONTROLLER_H
|
|
#include <libultraship/libultra/controller.h>
|
|
#if 0
|
|
#include "ultratypes.h"
|
|
#include "os_cont.h"
|
|
#include "os_pfs.h"
|
|
#include "rcp.h"
|
|
|
|
#define CHNL_ERR(format) (((format).rxsize & CHNL_ERR_MASK) >> 4)
|
|
|
|
#define SIAccessQueueSize 2
|
|
#define BLOCKSIZE 32
|
|
#define PFS_ONE_PAGE 8
|
|
|
|
#define PFS_PAGE_SIZE (BLOCKSIZE * PFS_ONE_PAGE)
|
|
|
|
#define CONT_CMD_REQUEST_STATUS 0
|
|
#define CONT_CMD_READ_BUTTON 1
|
|
#define CONT_CMD_READ_MEMPACK 2
|
|
#define CONT_CMD_WRITE_MEMPACK 3
|
|
#define CONT_CMD_READ_EEPROM 4
|
|
#define CONT_CMD_WRITE_EEPROM 5
|
|
#define CONT_CMD_RESET 0xFF
|
|
|
|
#define CONT_CMD_REQUEST_STATUS_TX 1
|
|
#define CONT_CMD_READ_BUTTON_TX 1
|
|
#define CONT_CMD_READ_MEMPACK_TX 3
|
|
#define CONT_CMD_WRITE_MEMPACK_TX 35
|
|
#define CONT_CMD_READ_EEPROM_TX 2
|
|
#define CONT_CMD_WRITE_EEPROM_TX 10
|
|
#define CONT_CMD_RESET_TX 1
|
|
|
|
#define CONT_CMD_REQUEST_STATUS_RX 3
|
|
#define CONT_CMD_READ_BUTTON_RX 4
|
|
#define CONT_CMD_READ_MEMPACK_RX 33
|
|
#define CONT_CMD_WRITE_MEMPACK_RX 1
|
|
#define CONT_CMD_READ_EEPROM_RX 8
|
|
#define CONT_CMD_WRITE_EEPROM_RX 1
|
|
#define CONT_CMD_RESET_RX 3
|
|
|
|
#define CONT_ERR_NO_CONTROLLER PFS_ERR_NOPACK /* 1 */
|
|
#define CONT_ERR_CONTRFAIL CONT_OVERRUN_ERROR /* 4 */
|
|
#define CONT_ERR_INVALID PFS_ERR_INVALID /* 5 */
|
|
#define CONT_ERR_DEVICE PFS_ERR_DEVICE /* 11 */
|
|
#define CONT_ERR_NOT_READY 12
|
|
#define CONT_ERR_VOICE_MEMORY 13
|
|
#define CONT_ERR_VOICE_WORD 14
|
|
#define CONT_ERR_VOICE_NO_RESPONSE 15
|
|
|
|
// Joybus commands
|
|
#define CONT_CMD_REQUEST_STATUS 0
|
|
#define CONT_CMD_READ_BUTTON 1
|
|
#define CONT_CMD_READ_PAK 2
|
|
#define CONT_CMD_WRITE_PAK 3
|
|
#define CONT_CMD_READ_EEPROM 4
|
|
#define CONT_CMD_WRITE_EEPROM 5
|
|
#define CONT_CMD_READ36_VOICE 9
|
|
#define CONT_CMD_WRITE20_VOICE 10
|
|
#define CONT_CMD_READ2_VOICE 11
|
|
#define CONT_CMD_WRITE4_VOICE 12
|
|
#define CONT_CMD_SWRITE_VOICE 13
|
|
#define CONT_CMD_CHANNEL_RESET 0xFD
|
|
#define CONT_CMD_RESET 0xFF
|
|
|
|
// Bytes transmitted for each joybus command
|
|
#define CONT_CMD_REQUEST_STATUS_TX 1
|
|
#define CONT_CMD_READ_BUTTON_TX 1
|
|
#define CONT_CMD_READ_PAK_TX 3
|
|
#define CONT_CMD_WRITE_PAK_TX 35
|
|
#define CONT_CMD_READ_EEPROM_TX 2
|
|
#define CONT_CMD_WRITE_EEPROM_TX 10
|
|
#define CONT_CMD_READ36_VOICE_TX 3
|
|
#define CONT_CMD_WRITE20_VOICE_TX 23
|
|
#define CONT_CMD_READ2_VOICE_TX 3
|
|
#define CONT_CMD_WRITE4_VOICE_TX 7
|
|
#define CONT_CMD_SWRITE_VOICE_TX 3
|
|
#define CONT_CMD_RESET_TX 1
|
|
|
|
// Bytes received for each joybus command
|
|
#define CONT_CMD_REQUEST_STATUS_RX 3
|
|
#define CONT_CMD_READ_BUTTON_RX 4
|
|
#define CONT_CMD_READ_PAK_RX 33
|
|
#define CONT_CMD_WRITE_PAK_RX 1
|
|
#define CONT_CMD_READ_EEPROM_RX 8
|
|
#define CONT_CMD_WRITE_EEPROM_RX 1
|
|
#define CONT_CMD_READ36_VOICE_RX 37
|
|
#define CONT_CMD_WRITE20_VOICE_RX 1
|
|
#define CONT_CMD_READ2_VOICE_RX 3
|
|
#define CONT_CMD_WRITE4_VOICE_RX 1
|
|
#define CONT_CMD_SWRITE_VOICE_RX 1
|
|
#define CONT_CMD_RESET_RX 3
|
|
|
|
#define CONT_CMD_NOP 0xFF
|
|
#define CONT_CMD_END 0xFE // Indicates end of a command
|
|
#define CONT_CMD_EXE 1 // Set pif ram status byte to this to do a command
|
|
|
|
#define DIR_STATUS_EMPTY 0
|
|
#define DIR_STATUS_UNKNOWN 1
|
|
#define DIR_STATUS_OCCUPIED 2
|
|
|
|
#define PFS_FORCE 1
|
|
#define PFS_DELETE 1
|
|
|
|
#define PFS_LABEL_AREA 7
|
|
|
|
#define PFS_ERR_NOPACK 1
|
|
|
|
// Accessory detection
|
|
#define CONT_ADDR_DETECT 0x8000
|
|
// Rumble
|
|
#define CONT_ADDR_RUMBLE 0xC000
|
|
// Controller Pak
|
|
// Transfer Pak
|
|
#define CONT_ADDR_GB_POWER 0x8000 // Same as the detection address, but semantically different
|
|
#define CONT_ADDR_GB_BANK 0xA000
|
|
#define CONT_ADDR_GB_STATUS 0xB000
|
|
|
|
// Addresses sent to controller accessories are in blocks, not bytes
|
|
#define CONT_BLOCKS(x) ((x) / BLOCKSIZE)
|
|
|
|
// Block addresses of the above
|
|
#define CONT_BLOCK_DETECT CONT_BLOCKS(CONT_ADDR_DETECT)
|
|
#define CONT_BLOCK_RUMBLE CONT_BLOCKS(CONT_ADDR_RUMBLE)
|
|
#define CONT_BLOCK_GB_POWER CONT_BLOCKS(CONT_ADDR_GB_POWER)
|
|
#define CONT_BLOCK_GB_BANK CONT_BLOCKS(CONT_ADDR_GB_BANK)
|
|
#define CONT_BLOCK_GB_STATUS CONT_BLOCKS(CONT_ADDR_GB_STATUS)
|
|
|
|
|
|
typedef struct {
|
|
/* 0x00 */ u32 ramarray[15];
|
|
/* 0x3C */ u32 status;
|
|
} OSPifRam; // size = 0x40
|
|
|
|
|
|
typedef struct {
|
|
/* 0x0 */ u8 dummy;
|
|
/* 0x1 */ u8 txsize;
|
|
/* 0x2 */ u8 rxsize;
|
|
/* 0x3 */ u8 cmd;
|
|
/* 0x4 */ u16 button;
|
|
/* 0x6 */ s8 stick_x;
|
|
/* 0x7 */ s8 stick_y;
|
|
} __OSContReadFormat;
|
|
|
|
|
|
// Original name: __OSContRequesFormat
|
|
typedef struct {
|
|
/* 0x00 */ u8 align;
|
|
/* 0x01 */ u8 txsize;
|
|
/* 0x02 */ u8 rxsize;
|
|
/* 0x03 */ u8 poll;
|
|
/* 0x04 */ u8 typeh;
|
|
/* 0x05 */ u8 typel;
|
|
/* 0x06 */ u8 status;
|
|
/* 0x07 */ u8 align1;
|
|
} __OSContRequestHeader; // size = 0x8
|
|
|
|
typedef struct {
|
|
/* 0x00 */ u8 txsize;
|
|
/* 0x01 */ u8 rxsize;
|
|
/* 0x02 */ u8 poll;
|
|
/* 0x03 */ u8 typeh;
|
|
/* 0x04 */ u8 typel;
|
|
/* 0x05 */ u8 status;
|
|
} __OSContRequestHeaderAligned; // size = 0x6
|
|
|
|
typedef struct {
|
|
/* 0x00 */ u8 dummy;
|
|
/* 0x01 */ u8 txsize;
|
|
/* 0x02 */ u8 rxsize;
|
|
/* 0x03 */ u8 cmd;
|
|
/* 0x04 */ u8 hi;
|
|
/* 0x05 */ u8 lo;
|
|
/* 0x06 */ u8 data[32];
|
|
/* 0x26 */ u8 datacrc;
|
|
} __OSContRamReadFormat;
|
|
|
|
#define READFORMAT(ptr) ((__OSContRamReadFormat*)(ptr))
|
|
|
|
s32 __osCheckPackId(OSPfs* pfs, __OSPackId* check);
|
|
s32 __osGetId(OSPfs* pfs);
|
|
u16 __osSumcalc(u8* ptr, s32 length);
|
|
s32 __osIdCheckSum(u16* ptr, u16* checkSum, u16* idSum);
|
|
s32 __osRepairPackId(OSPfs* pfs, __OSPackId* badid, __OSPackId* newid);
|
|
s32 __osCheckPackId(OSPfs *pfs, __OSPackId *check);
|
|
s32 __osCheckId(OSPfs* pfs);
|
|
s32 __osPfsRWInode(OSPfs* pfs, __OSInode* inode, u8 flag, u8 bank);
|
|
s32 __osPfsSelectBank(OSPfs* pfs, u8 bank);
|
|
s32 __osPfsDeclearPage(OSPfs* pfs, __OSInode* inode, s32 fileSizeInPages, s32* startPage, u8 bank, s32* decleared, s32* finalPage);
|
|
s32 __osPfsReleasePages(OSPfs *pfs, __OSInode *inode, u8 initialPage, u8 bank, __OSInodeUnit *finalPage);
|
|
s32 __osContRamRead(OSMesgQueue* ctrlrqueue, s32 channel, u16 addr, u8* buffer);
|
|
s32 __osContRamWrite(OSMesgQueue* mq, s32 channel, u16 address, u8* buffer, s32 force);
|
|
void __osContGetInitData(u8* pattern, OSContStatus* data);
|
|
void __osPackRequestData(u8 poll);
|
|
void __osPfsRequestData(u8 poll);
|
|
void __osPfsGetInitData(u8* pattern, OSContStatus* contData);
|
|
u8 __osContAddressCrc(u16 addr);
|
|
u8 __osContDataCrc(u8* data);
|
|
s32 __osPfsGetStatus(OSMesgQueue* queue, s32 channel);
|
|
s32 __osContChannelReset(OSMesgQueue* mq, s32 channel);
|
|
|
|
extern OSPifRam __osContPifRam;
|
|
extern u8 __osContLastPoll;
|
|
extern u8 __osMaxControllers;
|
|
extern OSMesgQueue __osEepromTimerQ;
|
|
extern OSMesg __osEepromTimerMsg[];
|
|
extern OSPifRam __osPfsPifRam;
|
|
#endif
|
|
#endif
|