Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
MorsGames
GitHub Repository: MorsGames/sm64plus
Path: blob/master/lib/src/__osDevMgrMain.c
7857 views
1
#include "libultra_internal.h"
2
#include "macros.h"
3
4
#if defined(VERSION_EU) || defined(VERSION_SH)
5
#include "new_func.h"
6
7
void __osDevMgrMain(void *args) {
8
OSIoMesg *mb;
9
OSMesg em;
10
OSMesg dummy;
11
s32 ret;
12
OSMgrArgs *sp34;
13
#ifdef VERSION_EU
14
UNUSED u32 sp30;
15
#endif
16
u32 sp2c;
17
__OSBlockInfo *sp28;
18
__OSTranxInfo *sp24;
19
#ifdef VERSION_SH
20
u32 tmp;
21
#endif
22
#ifdef VERSION_EU
23
sp30 = 0;
24
#endif
25
sp2c = 0;
26
mb = NULL;
27
ret = 0;
28
sp34 = (OSMgrArgs *) args;
29
while (TRUE) {
30
osRecvMesg(sp34->cmdQueue, (OSMesg) &mb, OS_MESG_BLOCK);
31
if (mb->piHandle != NULL && mb->piHandle->type == 2
32
&& (mb->piHandle->transferInfo.cmdType == 0
33
|| mb->piHandle->transferInfo.cmdType == 1)) {
34
sp24 = &mb->piHandle->transferInfo;
35
sp28 = &sp24->block[sp24->blockNum];
36
sp24->sectorNum = -1;
37
if (sp24->transferMode != 3) {
38
sp28->dramAddr = (void *) ((u32) sp28->dramAddr - sp28->sectorSize);
39
}
40
if (sp24->transferMode == 2 && mb->piHandle->transferInfo.cmdType == 0) {
41
sp2c = 1;
42
} else {
43
sp2c = 0;
44
}
45
osRecvMesg(sp34->accessQueue, &dummy, OS_MESG_BLOCK);
46
__osResetGlobalIntMask(0x00100401); // remove magic constant!
47
__osEPiRawWriteIo(mb->piHandle, 0x05000510, (sp24->bmCtlShadow | 0x80000000));
48
while (TRUE) {
49
osRecvMesg(sp34->eventQueue, &em, OS_MESG_BLOCK);
50
#ifdef VERSION_SH
51
sp24 = &mb->piHandle->transferInfo;
52
sp28 = &sp24->block[sp24->blockNum];
53
if (sp28->errStatus == 0x1D) {
54
__osEPiRawWriteIo(mb->piHandle, 0x5000510, sp24->bmCtlShadow | 0x10000000);
55
__osEPiRawWriteIo(mb->piHandle, 0x5000510, sp24->bmCtlShadow);
56
__osEPiRawReadIo(mb->piHandle, 0x5000508, &tmp);
57
if ((tmp & 0x2000000) != 0) {
58
__osEPiRawWriteIo(mb->piHandle, 0x5000510, sp24->bmCtlShadow | 0x1000000);
59
}
60
sp28->errStatus = 4;
61
HW_REG(PI_STATUS_REG, u32) = PI_STATUS_CLEAR_INTR;
62
__osSetGlobalIntMask(0x100C01);
63
}
64
osSendMesg(mb->hdr.retQueue, mb, OS_MESG_NOBLOCK);
65
if (sp2c != 1 || mb->piHandle->transferInfo.block[0].errStatus != 0) {
66
break;
67
}
68
#else
69
sp30 = osSendMesg(mb->hdr.retQueue, mb, OS_MESG_NOBLOCK);
70
if (sp2c != 1 || mb->piHandle->transferInfo.errStatus != 0) {
71
break;
72
}
73
#endif
74
sp2c = 0;
75
}
76
osSendMesg(sp34->accessQueue, NULL, OS_MESG_NOBLOCK);
77
if (mb->piHandle->transferInfo.blockNum == 1) {
78
func_802F71F0();
79
}
80
} else {
81
switch (mb->hdr.type) {
82
case 11:
83
osRecvMesg(sp34->accessQueue, &dummy, OS_MESG_BLOCK);
84
ret = sp34->dma_func(OS_READ, mb->devAddr, mb->dramAddr, mb->size);
85
break;
86
case 12:
87
osRecvMesg(sp34->accessQueue, &dummy, OS_MESG_BLOCK);
88
ret = sp34->dma_func(OS_WRITE, mb->devAddr, mb->dramAddr, mb->size);
89
break;
90
case 15:
91
osRecvMesg(sp34->accessQueue, &dummy, OS_MESG_BLOCK);
92
ret = sp34->edma_func(mb->piHandle, OS_READ, mb->devAddr, mb->dramAddr,
93
mb->size);
94
break;
95
case 16:
96
osRecvMesg(sp34->accessQueue, &dummy, OS_MESG_BLOCK);
97
ret = sp34->edma_func(mb->piHandle, OS_WRITE, mb->devAddr, mb->dramAddr,
98
mb->size);
99
break;
100
case 10:
101
osSendMesg(mb->hdr.retQueue, mb, OS_MESG_NOBLOCK);
102
ret = -1;
103
break;
104
break;
105
default:
106
ret = -1;
107
break;
108
}
109
if (ret == 0) {
110
osRecvMesg(sp34->eventQueue, &em, OS_MESG_BLOCK);
111
#ifdef VERSION_EU
112
sp30 =
113
#endif
114
osSendMesg(mb->hdr.retQueue, mb, OS_MESG_NOBLOCK);
115
osSendMesg(sp34->accessQueue, NULL, OS_MESG_NOBLOCK);
116
}
117
}
118
}
119
}
120
#else
121
void __osDevMgrMain(void *args) {
122
OSIoMesg *sp34;
123
OSMesg sp30;
124
OSMesg sp2c;
125
s32 sp28;
126
OSMgrArgs *sp24;
127
sp34 = NULL;
128
sp28 = 0;
129
sp24 = (OSMgrArgs *) args;
130
while (TRUE) {
131
osRecvMesg(sp24->cmdQueue, (OSMesg) &sp34, OS_MESG_BLOCK);
132
switch (sp34->hdr.type) {
133
case 11:
134
osRecvMesg(sp24->accessQueue, &sp2c, OS_MESG_BLOCK);
135
sp28 = sp24->dma_func(OS_READ, sp34->devAddr, sp34->dramAddr, sp34->size);
136
break;
137
case 12:
138
osRecvMesg(sp24->accessQueue, &sp2c, OS_MESG_BLOCK);
139
sp28 = sp24->dma_func(OS_WRITE, sp34->devAddr, sp34->dramAddr, sp34->size);
140
break;
141
case 10:
142
osSendMesg(sp34->hdr.retQueue, sp34, OS_MESG_NOBLOCK);
143
sp28 = -1;
144
break;
145
default:
146
sp28 = -1;
147
break;
148
}
149
if (sp28 == 0) {
150
osRecvMesg(sp24->eventQueue, &sp30, OS_MESG_BLOCK);
151
osSendMesg(sp34->hdr.retQueue, sp34, OS_MESG_NOBLOCK);
152
osSendMesg(sp24->accessQueue, NULL, OS_MESG_NOBLOCK);
153
}
154
}
155
}
156
#endif
157
158