Mario Kart 64
piint.h
Go to the documentation of this file.
1 #ifndef _PIINT_H
2 #define _PIINT_H
3 #include "PR/os_internal.h"
4 #include "PR/rcp.h"
5 #include "PR/os_pi.h"
6 #include "PR/os.h"
7 
8 //https://github.com/LuigiBlood/64dd/wiki/Memory-Map
9 
10 #define LEO_BASE_REG 0x05000000
11 
12 #define LEO_CMD (LEO_BASE_REG + 0x508)
13 #define LEO_STATUS (LEO_BASE_REG + 0x508)
14 
15 #define LEO_BM_CTL (LEO_BASE_REG + 0x510)
16 #define LEO_BM_STATUS (LEO_BASE_REG + 0x510)
17 
18 #define LEO_SEQ_CTL (LEO_BASE_REG + 0x518)
19 #define LEO_SEQ_STATUS (LEO_BASE_REG + 0x518)
20 
21 #define LEO_C2_BUFF (LEO_BASE_REG + 0x000) //C2 Sector Buffer
22 #define LEO_SECTOR_BUFF (LEO_BASE_REG + 0x400) //Data Sector Buffer
23 #define LEO_DATA (LEO_BASE_REG + 0x500) //Data
24 #define LEO_MISC_REG (LEO_BASE_REG + 0x504) //Misc Register
25 #define LEO_CUR_TK (LEO_BASE_REG + 0x50C) //Current Track
26 #define LEO_ERR_SECTOR (LEO_BASE_REG + 0x514) //Sector Error Status
27 #define LEO_CUR_SECTOR (LEO_BASE_REG + 0x51C) //Current Sector
28 #define LEO_HARD_RESET (LEO_BASE_REG + 0x520) //Hard Reset
29 #define LEO_C1_S0 (LEO_BASE_REG + 0x524) //C1
30 #define LEO_HOST_SECBYTE (LEO_BASE_REG + 0x528) //Sector Size (in bytes)
31 #define LEO_C1_S2 (LEO_BASE_REG + 0x52C) //C1
32 #define LEO_SEC_BYTE (LEO_BASE_REG + 0x530) //Sectors per Block, Full Size
33 #define LEO_C1_S4 (LEO_BASE_REG + 0x534) //C1
34 #define LEO_C1_S6 (LEO_BASE_REG + 0x538) //C1
35 #define LEO_CUR_ADDR (LEO_BASE_REG + 0x53C) //Current Address?
36 #define LEO_ID_REG (LEO_BASE_REG + 0x540) //ID
37 #define LEO_TEST_REG (LEO_BASE_REG + 0x544) //Test Read
38 #define LEO_TEST_PIN_SEL (LEO_BASE_REG + 0x548) //Test Write
39 #define LEO_RAM_ADDR (LEO_BASE_REG + 0x580) //Microsequencer RAM
40 
41 #define LEO_STATUS_PRESENCE_MASK 0xFFFF
42 
43 #define LEO_STATUS_DATA_REQUEST 0x40000000
44 #define LEO_STATUS_C2_TRANSFER 0x10000000
45 #define LEO_STATUS_BUFFER_MANAGER_ERROR 0x08000000
46 #define LEO_STATUS_BUFFER_MANAGER_INTERRUPT 0x04000000
47 #define LEO_STATUS_MECHANIC_INTERRUPT 0x02000000
48 #define LEO_STATUS_DISK_PRESENT 0x01000000
49 #define LEO_STATUS_BUSY_STATE 0x00800000
50 #define LEO_STATUS_RESET_STATE 0x00400000
51 #define LEO_STATUS_MOTOR_NOT_SPINNING 0x00100000
52 #define LEO_STATUS_HEAD_RETRACTED 0x00080000
53 #define LEO_STATUS_WRITE_PROTECT_ERROR 0x00040000
54 #define LEO_STATUS_MECHANIC_ERROR 0x00020000
55 #define LEO_STATUS_DISK_CHANGE 0x00010000
56 
57 #define LEO_STATUS_MODE_MASK (LEO_STATUS_MOTOR_NOT_SPINNING | LEO_STATUS_HEAD_RETRACTED)
58 #define LEO_STATUS_MODE_SLEEP (LEO_STATUS_MOTOR_NOT_SPINNING | LEO_STATUS_HEAD_RETRACTED)
59 #define LEO_STATUS_MODE_STANDBY (LEO_STATUS_HEAD_RETRACTED)
60 #define LEO_STATUS_MODE_ACTIVE 0
61 
62 #define LEO_CUR_TK_INDEX_LOCK 0x60000000
63 
64 #define LEO_BM_STATUS_RUNNING 0x80000000 //Running
65 #define LEO_BM_STATUS_ERROR 0x04000000 //Error
66 #define LEO_BM_STATUS_MICRO 0x02000000 //Micro Status?
67 #define LEO_BM_STATUS_BLOCK 0x01000000 //Block Transfer
68 #define LEO_BM_STATUS_C1CORRECTION 0x00800000 //C1 Correction
69 #define LEO_BM_STATUS_C1DOUBLE 0x00400000 //C1 Double
70 #define LEO_BM_STATUS_C1SINGLE 0x00200000 //C1 Single
71 #define LEO_BM_STATUS_C1ERROR 0x00010000 //C1 Error
72 
73 #define LEO_BM_CTL_START 0x80000000 //Start Buffer Manager
74 #define LEO_BM_CTL_MODE 0x40000000 //Buffer Manager Mode
75 #define LEO_BM_CTL_IMASK 0x20000000 //BM Interrupt Mask
76 #define LEO_BM_CTL_RESET 0x10000000 //Buffer Manager Reset
77 #define LEO_BM_CTL_DISABLE_OR 0x08000000 //Disable OR Check?
78 #define LEO_BM_CTL_DISABLE_C1 0x04000000 //Disable C1 Correction
79 #define LEO_BM_CTL_BLOCK 0x02000000 //Block Transfer
80 #define LEO_BM_CTL_CLR_MECHANIC_INTR 0x01000000 //Mechanic Interrupt Reset
81 
82 #define LEO_BM_CTL_CONTROL_MASK 0xFF000000
83 #define LEO_BM_CTL_SECTOR_MASK 0x00FF0000
84 #define LEO_BM_CTL_SECTOR_SHIFT 16
85 
87 #define LEO_CMD_TYPE_0 0
89 #define LEO_CMD_TYPE_1 1
91 #define LEO_CMD_TYPE_2 2
92 
93 #define LEO_ERROR_GOOD 0
94 #define LEO_ERROR_3 3
95 #define LEO_ERROR_4 4 //maybe busy?
96 #define LEO_ERROR_6 6
97 #define LEO_ERROR_17 17
98 #define LEO_ERROR_22 22
99 #define LEO_ERROR_23 23 //unrecovered read error?
100 #define LEO_ERROR_24 24 //no reference position found?
101 #define LEO_ERROR_29 29
102 #define LEO_ERROR_75 75
103 
104 extern OSDevMgr __osPiDevMgr;
105 extern OSPiHandle *__osCurrentHandle[2];
108 extern OSMesgQueue __osPiAccessQueue;
110 
112 void __osDevMgrMain(void *);
113 void __osPiCreateAccessQueue(void);
114 void __osPiRelAccess(void);
115 void __osPiGetAccess(void);
116 OSMesgQueue *osPiGetCmdQueue(void);
117 
118 #define OS_RAMROM_STACKSIZE 1024
119 
120 #define WAIT_ON_LEO_IO_BUSY(stat) \
121  stat = IO_READ(PI_STATUS_REG); \
122  while (stat & PI_STATUS_IO_BUSY) \
123  stat = IO_READ(PI_STATUS_REG);
124 
125 #define WAIT_ON_IOBUSY(stat) \
126  stat = IO_READ(PI_STATUS_REG); \
127  while (stat & (PI_STATUS_IO_BUSY | PI_STATUS_DMA_BUSY)) \
128  stat = IO_READ(PI_STATUS_REG);
129 
130 #define UPDATE_REG(reg, var) \
131  if (cHandle->var != pihandle->var) \
132  IO_WRITE(reg, pihandle->var);
133 
134 #define EPI_SYNC(pihandle, stat, domain) \
135  \
136  WAIT_ON_IOBUSY(stat) \
137  \
138  domain = pihandle->domain; \
139  if (__osCurrentHandle[domain] != pihandle) \
140  { \
141  OSPiHandle *cHandle = __osCurrentHandle[domain]; \
142  if (domain == PI_DOMAIN1) \
143  { \
144  UPDATE_REG(PI_BSD_DOM1_LAT_REG, latency); \
145  UPDATE_REG(PI_BSD_DOM1_PGS_REG, pageSize); \
146  UPDATE_REG(PI_BSD_DOM1_RLS_REG, relDuration); \
147  UPDATE_REG(PI_BSD_DOM1_PWD_REG, pulse); \
148  } \
149  else \
150  { \
151  UPDATE_REG(PI_BSD_DOM2_LAT_REG, latency); \
152  UPDATE_REG(PI_BSD_DOM2_PGS_REG, pageSize); \
153  UPDATE_REG(PI_BSD_DOM2_RLS_REG, relDuration); \
154  UPDATE_REG(PI_BSD_DOM2_PWD_REG, pulse); \
155  } \
156  __osCurrentHandle[domain] = pihandle; \
157  }
158 
159 #endif
void __osPiRelAccess(void)
Definition: __osPiCreateAccessQueue.c:23
OSMesgQueue __osPiAccessQueue
OSMesgQueue * osPiGetCmdQueue(void)
Definition: osPiGetCmdQueue.c:5
OSDevMgr __osPiDevMgr
Definition: osCreatePiManager.c:11
void __osDevMgrMain(void *)
Definition: __osDevMgrMain.c:8
u32 __osPiAccessQueueEnabled
OSPiHandle LeoDiskHandle
Definition: osLeoDiskInit.c:11
OSPiHandle CartRomHandle
Definition: osCartRomInit.c:10
OSPiHandle * __osCurrentHandle[2]
int __osPiDeviceBusy(void)
void __osPiCreateAccessQueue(void)
Definition: __osPiCreateAccessQueue.c:9
void __osPiGetAccess(void)
Definition: __osPiCreateAccessQueue.c:15
Definition: os_pi.h:28
unsigned int u32
Definition: ultratypes.h:16