-
Notifications
You must be signed in to change notification settings - Fork 132
/
usbdpriv.h
328 lines (277 loc) · 8.03 KB
/
usbdpriv.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
/*
# _____ ___ ____ ___ ____
# ____| | ____| | | |____|
# | ___| |____ ___| ____| | \ PS2DEV Open Source Project.
#-----------------------------------------------------------------------
# Copyright 2001-2004, ps2dev - http://www.ps2dev.org
# Licenced under Academic Free License version 2.0
# Review ps2sdk README & LICENSE files for further details.
*/
/**
* @file
* USB Driver function prototypes and constants.
*/
#ifndef __USBDPRIV_H__
#define __USBDPRIV_H__
#include "usbd.h"
#include "types.h"
#define OHCI_REG_BASE 0xBF801600
#define MODNAME "usbd"
#ifdef DEBUG
#define dbg_printf(a...) printf(MODNAME ": " a)
#else
#define dbg_printf(a...) (void)0
#endif
#define READ_UINT16(a) (((u8 *)a)[0] | (((u8 *)a)[1] << 8))
typedef struct
{
int maxDevices;
int maxEndpoints;
int maxTransfDesc;
int maxIsoTransfDesc;
int maxIoReqs;
int maxStaticDescSize;
int maxHubDevices;
int maxPortsPerHub;
int hcdThreadPrio;
int cbThreadPrio;
} UsbdConfig;
extern UsbdConfig usbConfig;
struct _device;
struct _ioRequest;
struct _hcTd;
struct _hcIsoTd;
struct _hcEd;
struct _endpoint;
struct _UsbDriver;
struct _ioRequest;
typedef void (*TimerCallback)(void *arg);
typedef void (*InternCallback)(struct _ioRequest *arg);
typedef struct _timerCbStruct
{
u32 isActive;
struct _timerCbStruct *prev, *next;
TimerCallback callbackProc;
void *callbackArg;
u32 delayCount;
} TimerCbStruct;
typedef struct _ioRequest
{
u32 busyFlag;
struct _ioRequest *next, *prev;
struct _endpoint *correspEndpoint;
UsbDeviceRequest devReq;
void *destPtr;
u32 length; // length of destPtr buffer
InternCallback callbackProc;
u32 resultCode;
u32 transferedBytes;
u32 waitFrames; // number of frames to wait for isochronous transfers
sceUsbdDoneCallback userCallbackProc;
void *userCallbackArg;
#if USE_GP_REGISTER
void *gpSeg;
#endif
} IoRequest;
typedef struct _device
{
u32 id;
struct _device *next, *prev;
struct _endpoint *endpointListStart, *endpointListEnd;
sceUsbdLddOps *devDriver;
u8 deviceStatus;
u8 functionAddress;
u8 isLowSpeedDevice;
u8 resetFlag;
struct _device *childListStart, *childListEnd;
struct _device *parent;
u32 attachedToPortNo;
void *privDataField;
TimerCbStruct timer;
IoRequest ioRequest;
u32 functionDelay; // is this necessary?
void *staticDeviceDescPtr;
void *staticDeviceDescEndPtr;
u32 fetchDescriptorCounter;
} Device;
typedef struct _hcTd
{
u32 HcArea;
void *curBufPtr;
struct _hcTd *next;
void *bufferEnd;
} HcTD;
typedef struct _hcIsoTd
{
u32 hcArea;
void *bufferPage0;
struct _hcIsoTd *next;
void *bufferEnd;
u16 psw[8];
} HcIsoTD;
typedef struct _hcEd
{
u16 hcArea;
u16 maxPacketSize;
HcTD *tdTail;
HcTD *tdHead;
struct _hcEd *next;
} HcED;
typedef struct _endpoint
{
u32 id;
u8 endpointType;
u8 inTdQueue;
u8 alignFlag;
u8 pad;
struct _endpoint *next, *prev;
struct _endpoint *busyNext, *busyPrev;
Device *correspDevice;
IoRequest *ioReqListStart;
IoRequest *ioReqListEnd;
u32 isochronLastFrameNum; // 40
TimerCbStruct timer; // sizeof(TimerCbStruct) => 24 bytes
HcED hcEd; // HcED has to be aligned to 0x10 bytes!
} Endpoint;
typedef struct _usbHub
{
struct _usbHub *next;
Endpoint *controlEp, *statusChangeEp;
IoRequest controlIoReq, statusIoReq;
UsbHubDescriptor desc;
u32 numChildDevices;
u32 portCounter;
u32 hubStatusCounter;
u16 hubStatus; //
u16 hubStatusChange; // unite to u32 to make it match portStatusChange
u32 portStatusChange;
u8 statusChangeInfo[8]; // depends on number of ports
} UsbHub;
typedef struct
{
volatile HcED *InterruptTable[32];
volatile u16 FrameNumber;
volatile u16 pad;
volatile HcTD *DoneHead;
volatile u8 reserved[116];
volatile u32 pad2; // expand struct to 256 bytes for alignment
} HcCA;
typedef struct
{
volatile u32 HcRevision;
volatile u32 HcControl;
volatile u32 HcCommandStatus;
volatile u32 HcInterruptStatus;
volatile u32 HcInterruptEnable;
volatile u32 HcInterruptDisable;
volatile HcCA *HcHCCA;
volatile HcED *HcPeriodCurrentEd;
volatile HcED *HcControlHeadEd;
volatile HcED *HcControlCurrentEd;
volatile HcED *HcBulkHeadEd;
volatile HcED *HcBulkCurrentEd;
volatile u32 HcDoneHead;
volatile u32 HcFmInterval;
volatile u32 HcFmRemaining;
volatile u32 HcFmNumber;
volatile u32 HcPeriodicStart;
volatile u32 HcLsThreshold;
volatile u32 HcRhDescriptorA;
volatile u32 HcRhDescriptorB;
volatile u32 HcRhStatus;
volatile u32 HcRhPortStatus[2];
} OhciRegs;
typedef struct _memPool
{
volatile OhciRegs *ohciRegs;
volatile HcCA *hcHCCA;
struct _hcEd *hcEdBuf;
struct _hcTd *freeHcTdList;
struct _hcTd *hcTdBuf;
struct _hcTd *hcTdBufEnd;
struct _hcIsoTd *freeHcIsoTdList;
struct _hcIsoTd *hcIsoTdBuf;
struct _hcIsoTd *hcIsoTdBufEnd;
struct _ioRequest **hcTdToIoReqLUT;
struct _ioRequest **hcIsoTdToIoReqLUT;
struct _ioRequest *ioReqBufPtr;
struct _ioRequest *freeIoReqList;
struct _ioRequest *freeIoReqListEnd;
struct _device *deviceTreeBuf;
struct _device *freeDeviceListStart;
struct _device *freeDeviceListEnd;
struct _endpoint *endpointBuf;
struct _endpoint *freeEpListStart;
struct _endpoint *freeEpListEnd;
struct _endpoint *tdQueueStart[2], *tdQueueEnd[2];
struct _timerCbStruct *timerListStart;
struct _timerCbStruct *timerListEnd;
struct _device *deviceTreeRoot;
u32 delayResets;
} MemoryPool;
#define GENTD_QUEUE 1
#define ISOTD_QUEUE 2
#define TYPE_CONTROL 0x3F
#define TYPE_BULK 0x40
#define TYPE_ISOCHRON 0x41
#define DEVICE_NOTCONNECTED 0
#define DEVICE_CONNECTED 1
#define DEVICE_RESETDELAYED 2
#define DEVICE_RESETPENDING 3
#define DEVICE_RESETCOMPLETE 4
#define DEVICE_READY 5
#define PORT_CONNECTION 0
#define PORT_ENABLE 1
#define PORT_SUSPEND 2
#define PORT_OVER_CURRENT 3
#define PORT_RESET 4
#define PORT_POWER 8
#define PORT_LOW_SPEED 9
#define C_HUB_LOCAL_POWER 0
#define C_HUB_OVER_CURRENT 1
#define C_PORT_CONNECTION 16
#define C_PORT_ENABLE 17
#define C_PORT_SUSPEND 18
#define C_PORT_OVER_CURRENT 19
#define C_PORT_RESET 20
#define BIT(x) (((u32)1) << (x))
#define C_PORT_FLAGS (BIT(C_PORT_CONNECTION) | BIT(C_PORT_ENABLE) | BIT(C_PORT_SUSPEND) | BIT(C_PORT_OVER_CURRENT) | BIT(C_PORT_RESET))
#define HCED_DIR_OUT BIT(11) // Direction field
#define HCED_DIR_IN BIT(12) // Direction field
#define HCED_SPEED BIT(13) // Speed bit
#define HCED_SKIP BIT(14) // sKip bit
#define HCED_ISOC BIT(15) // Format bit
#define HCED_DIR_MASK (HCED_DIR_OUT | HCED_DIR_IN)
#define ED_HALTED(a) ((u32)((a).tdHead) & 1)
#define ED_SKIPPED(a) ((u32)((a).hcArea) & HCED_SKIP)
#define TD_HCAREA(CC, T, DI, DP, R) (((CC) << 12) | ((T) << 8) | ((DI) << 5) | ((DP) << 3) | ((R) << 2))
#define TD_SETUP 0
#define TD_OUT 1
#define TD_IN 2
#define OHCI_INT_SO BIT(0)
#define OHCI_INT_WDH BIT(1)
#define OHCI_INT_SF BIT(2)
#define OHCI_INT_RD BIT(3)
#define OHCI_INT_UE BIT(4)
#define OHCI_INT_FNO BIT(5)
#define OHCI_INT_RHSC BIT(6)
#define OHCI_INT_OC BIT(30)
#define OHCI_INT_MIE BIT(31)
#define OHCI_COM_HCR BIT(0)
#define OHCI_COM_CLF BIT(1)
#define OHCI_COM_BLF BIT(2)
#define OHCI_CTR_PLE BIT(2) // Periodic List Enable
#define OHCI_CTR_IE BIT(3) // Isochronous Enable
#define OHCI_CTR_CLE BIT(4) // Control List Enable
#define OHCI_CTR_BLE BIT(5) // Bulk List Enable
#define OHCI_CTR_USB_RESET (0 << 6)
#define OHCI_CTR_USB_RESUME (1 << 6)
#define OHCI_CTR_USB_OPERATIONAL (2 << 6)
#define OHCI_CTR_USB_SUSPEND (3 << 6)
int usbdLock(void);
int usbdUnlock(void);
int doGetDeviceLocation(Device *dev, u8 *path);
void processDoneQueue_IsoTd(HcIsoTD *arg);
void processDoneQueue_GenTd(HcTD *arg);
void handleTimerList(void);
#endif // __USBDPRIV_H__