This source file includes following definitions.
- change_video_tables
- set_quality
- movie_record_task
- sub_FF96DAE0_my
1 #include "conf.h"
2
3 void change_video_tables(__attribute__ ((unused))int a, __attribute__ ((unused))int b) {}
4
5
6 void set_quality(int *x){
7 if (conf.video_mode) *x=12-((conf.video_quality-1)*(12+17)/(99-1));
8 }
9
10
11 void __attribute__((naked,noinline)) movie_record_task(){
12 asm volatile(
13 "STMFD SP!, {R2-R8,LR}\n"
14 "LDR R8, =0x4B2\n"
15 "LDR R7, =0x2710\n"
16 "LDR R4, =0x71D0\n"
17 "MOV R6, #0\n"
18 "MOV R5, #1\n"
19 "loc_FF96E128:\n"
20 "LDR R0, [R4,#0x1C]\n"
21 "MOV R2, #0\n"
22 "ADD R1, SP, #4\n"
23 "BL sub_FF839B88\n"
24 "LDR R0, [R4,#0x24]\n"
25 "CMP R0, #0\n"
26 "BNE loc_FF96E1F8\n"
27 "LDR R0, [SP,#4]\n"
28 "LDR R1, [R0]\n"
29 "SUB R1, R1, #2\n"
30 "CMP R1, #0x9\n"
31 "ADDLS PC, PC, R1,LSL#2\n"
32 "B loc_FF96E1F8\n"
33 "loc_FF96E15C:\n"
34 "B loc_FF96E1AC\n"
35 "loc_FF96E160:\n"
36 "B loc_FF96E1CC\n"
37 "loc_FF96E164:\n"
38 "B loc_FF96E1DC\n"
39 "loc_FF96E168:\n"
40 "B loc_FF96E1E4\n"
41 "loc_FF96E16C:\n"
42 "B loc_FF96E1B4\n"
43 "loc_FF96E170:\n"
44 "B loc_FF96E1EC\n"
45 "loc_FF96E174:\n"
46 "B loc_FF96E1BC\n"
47 "loc_FF96E178:\n"
48 "B loc_FF96E1F8\n"
49 "loc_FF96E17C:\n"
50 "B loc_FF96E1F4\n"
51 "loc_FF96E180:\n"
52 "B loc_FF96E184\n"
53 "loc_FF96E184:\n"
54 "LDR R0, =0xFF96DE54\n"
55 "STR R6, [R4,#0x38]\n"
56 "STR R0, [R4,#0xA8]\n"
57 "LDR R2, =0xFF96D37C\n"
58 "LDR R1, =0x9817C\n"
59 "LDR R0, =0xFF96D460\n"
60 "STR R6, [R4,#0x28]\n"
61 "BL sub_FF850ED8\n"
62 "STR R5, [R4,#0x3C]\n"
63 "B loc_FF96E1F8\n"
64 "loc_FF96E1AC:\n"
65
66 "BL sub_FF96DF5C\n"
67 "B loc_FF96E1F8\n"
68 "loc_FF96E1B4 :\n"
69 "BL sub_FF96DAE0_my\n"
70
71 "B loc_FF96E1F8\n"
72 "loc_FF96E1BC:\n"
73 "LDR R1, [R0,#0x18]\n"
74 "LDR R0, [R0,#4]\n"
75 "BL sub_FFABBB18\n"
76 "B loc_FF96E1F8\n"
77 "loc_FF96E1CC:\n"
78 "LDR R0, [R4,#0x3C]\n"
79 "CMP R0, #5\n"
80 "STRNE R5, [R4,#0x2C]\n"
81 "B loc_FF96E1F8\n"
82 "loc_FF96E1DC:\n"
83 "BL sub_FF96D7DC\n"
84 "B loc_FF96E1F8\n"
85 "loc_FF96E1E4:\n"
86 "BL sub_FF96D4AC\n"
87 "B loc_FF96E1F8\n"
88 "loc_FF96E1EC:\n"
89 "BL sub_FF96D308\n"
90 "B loc_FF96E1F8\n"
91 "loc_FF96E1F4:\n"
92 "BL sub_FF96E360\n"
93 "loc_FF96E1F8:\n"
94 "LDR R1, [SP,#4]\n"
95 "LDR R3, =0xFF96D194\n"
96 "STR R6, [R1]\n"
97 "STR R8, [SP]\n"
98 "LDR R0, [R4,#0x20]\n"
99 "MOV R2, R7\n"
100 "BL sub_FF83A4DC\n"
101 "B loc_FF96E128\n"
102 );
103 }
104
105 void __attribute__((naked,noinline)) sub_FF96DAE0_my(){
106 asm volatile(
107 "STMFD SP!, {R4-R8,LR}\n"
108 "SUB SP, SP, #0x40\n"
109 "MOV R7, #0\n"
110 "LDR R6, =0x71D0\n"
111 "MOV R4, R0\n"
112 "STR R7, [SP,#0x30]\n"
113 "STR R7, [SP,#0x28]\n"
114 "LDR R0, [R6,#0x3C]\n"
115 "MOV R8, #4\n"
116 "CMP R0, #3\n"
117 "STREQ R8, [R6,#0x3C]\n"
118 "LDR R0, [R6,#0xA8]\n"
119 "BLX R0\n"
120 "LDR R0, [R6,#0x3C]\n"
121 "CMP R0, #4\n"
122 "BNE loc_FF96DC4C\n"
123 "ADD R3, SP, #0x28\n"
124 "ADD R2, SP, #0x2C\n"
125 "ADD R1, SP, #0x30\n"
126 "ADD R0, SP, #0x34\n"
127 "BL sub_FFABBBB4\n"
128 "CMP R0, #0\n"
129 "MOV R5, #1\n"
130 "BNE loc_FF96DB5C\n"
131 "LDR R1, [R6,#0x2C]\n"
132 "CMP R1, #1\n"
133 "BNE loc_FF96DC54\n"
134 "LDR R1, [R6,#0x60]\n"
135 "LDR R2, [R6,#0x40]\n"
136 "CMP R1, R2\n"
137 "BCC loc_FF96DC54\n"
138
139 "loc_FF96DB5C:\n"
140 "CMP R0, #0x80000001\n"
141 "STREQ R8, [R6,#0x64]\n"
142 "BEQ loc_FF96DB94\n"
143 "CMP R0, #0x80000003\n"
144 "STREQ R5, [R6,#0x64]\n"
145 "BEQ loc_FF96DB94\n"
146 "CMP R0, #0x80000005\n"
147 "MOVEQ R0, #2\n"
148 "BEQ loc_FF96DB90\n"
149 "CMP R0, #0x80000007\n"
150 "STRNE R7, [R6,#0x64]\n"
151 "BNE loc_FF96DB94\n"
152 "MOV R0, #3\n"
153 "loc_FF96DB90:\n"
154 "STR R0, [R6,#0x64]\n"
155 "loc_FF96DB94:\n"
156 "LDR R0, =0x981B0\n"
157 "LDR R0, [R0,#8]\n"
158 "CMP R0, #0\n"
159 "BEQ loc_FF96DBAC\n"
160 "BL sub_FF8659EC\n"
161 "B loc_FF96DBB0\n"
162
163 "loc_FF96DBAC:\n"
164 "BL sub_FF96D308\n"
165 "loc_FF96DBB0:\n"
166 "LDR R0, [R4,#0x1C]\n"
167 "ADD R4, SP, #0x18\n"
168 "ADD R3, SP, #0x38\n"
169 "MVN R2, #1\n"
170 "MOV R1, #0\n"
171 "STMIA R4, {R0-R3}\n"
172 "ADD R1, SP, #0x3C\n"
173 "ADD R4, SP, #8\n"
174 "MOV R0, #0\n"
175 "LDRD R2, [R6,#0x78]\n"
176 "STMIA R4, {R0-R3}\n"
177 "MOV R3, #0\n"
178 "MOV R2, #0x40\n"
179 "STRD R2, [SP]\n"
180 "LDR R3, =0x981C8\n"
181 "MOV R2, #0\n"
182 "MOV R1, #0\n"
183 "BL sub_FFA74800\n"
184 "LDR R0, [R6,#0x14]\n"
185 "LDR R1, [R6,#0x58]\n"
186 "BL sub_FF839FA4\n"
187 "CMP R0, #9\n"
188 "BNE loc_FF96DC1C\n"
189
190
191 "loc_FF96DC0C:\n"
192 "BL sub_FFABC088\n"
193 "MOV R0, #1\n"
194 "STR R5, [R6,#0x3C]\n"
195 "B loc_FF96DD74\n"
196 "loc_FF96DC1C:\n"
197 "LDR R0, [SP,#0x38]\n"
198 "CMP R0, #0\n"
199 "BEQ loc_FF96DC38\n"
200
201 "loc_FF96DC28:\n"
202 "BL sub_FFABC088\n"
203 "MOV R0, #1\n"
204 "STR R5, [R6,#0x3C]\n"
205 "B loc_FF96DDA0\n"
206 "loc_FF96DC38:\n"
207 "MOV R0, #1\n"
208 "BL sub_FFA748A4\n"
209 "BL sub_FFA74900\n"
210 "MOV R0, #5\n"
211 "STR R0, [R6,#0x3C]\n"
212 "loc_FF96DC4C:\n"
213 "ADD SP, SP, #0x40\n"
214 "LDMFD SP!, {R4-R8,PC}\n"
215
216
217 "loc_FF96DC54:\n"
218 "LDR R12, [SP,#0x30]\n"
219 "CMP R12, #0\n"
220 "BEQ loc_FF96DDFC\n"
221 "STR R5, [R6,#0x30]\n"
222 "LDR R0, [R6,#0x60]\n"
223 "LDR R8, [R4,#0xC]\n"
224 "CMP R0, #0\n"
225 "LDRNE LR, [SP,#0x34]\n"
226 "BNE loc_FF96DCFC\n"
227 "LDR R0, [R4,#0x1C]\n"
228 "LDR R1, [R4,#0x20]\n"
229 "ADD R3, SP, #0x38\n"
230 "MVN R2, #0\n"
231 "ADD LR, SP, #0x18\n"
232 "STMIA LR, {R0-R3}\n"
233 "LDRD R2, [R6,#0x78]\n"
234 "LDR R0, [SP,#0x28]\n"
235 "ADD R1, SP,#0x3C\n"
236 "ADD LR, SP,#8\n"
237 "STMIA LR, {R0-R3}\n"
238 "LDR R3, [SP,#0x2C]\n"
239 "STR R12, [SP]\n"
240 "STR R3, [SP,#4]\n"
241 "LDMIB R4, {R0,R1}\n"
242 "LDR R3, [SP,#0x34]\n"
243 "MOV R2, R8\n"
244 "BL sub_FFA74800\n"
245 "LDR R0, [R6,#0x14]\n"
246 "LDR R1, [R6,#0x58]\n"
247 "BL sub_FF839FA4\n"
248 "CMP R0, #9\n"
249 "BEQ loc_FF96DC0C\n"
250 "LDR R0, [SP,#0x38]\n"
251 "CMP R0, #0\n"
252 "BNE loc_FF96DC28\n"
253 "MOV R0, #1\n"
254 "BL sub_FFA748A4\n"
255 "LDR R0, [SP,#0x3C]\n"
256 "LDR R1, [SP,#0x34]\n"
257 "ADD LR, R1, R0\n"
258 "LDR R1, [SP,#0x30]\n"
259 "SUB R12, R1, R0\n"
260 "loc_FF96DCFC:\n"
261 "LDR R2, [R6,#0x5C]\n"
262 "LDR R0, [R4,#0x1C]\n"
263 "LDR R1, [R4,#0x20]\n"
264 "ADD R3, SP, #0x38\n"
265 "STR R1, [SP,#0x1C]\n"
266 "STR R3, [SP,#0x24]\n"
267 "STR R2, [SP,#0x20]\n"
268 "STR R0, [SP,#0x18]\n"
269 "LDRD R2, [R6,#0x78]\n"
270 "LDR R0, [SP,#0x28]\n"
271 "STR R3, [SP,#0x14]\n"
272 "LDR R3, [SP,#0x2C]\n"
273 "ADD R1, SP, #0x3C\n"
274 "STR R2, [SP,#0x10]\n"
275 "STR R3, [SP,#0x4]\n"
276 "STR R1, [SP,#0xC]\n"
277 "STR R12, [SP]\n"
278 "STR R0, [SP,#0x8]\n"
279 "LDMIB R4, {R0,R1}\n"
280 "MOV R3, LR\n"
281 "MOV R2, R8\n"
282 "BL sub_FFA74800\n"
283 "LDR R0, [R6,#0x14]\n"
284 "LDR R1, [R6,#0x58]\n"
285 "BL sub_FF839FA4\n"
286 "CMP R0, #9\n"
287 "BNE loc_FF96DD88\n"
288 "BL sub_FFABC088\n"
289 "MOV R0, #0\n"
290 "STR R5, [R6,#0x3C]\n"
291 "loc_FF96DD74:\n"
292 "BL sub_FFA748A4\n"
293 "MOV R0, #0xC\n"
294 "BL sub_FF88BB38\n"
295 "MOV R0, #0x90000\n"
296 "B loc_FF96DDB0\n"
297 "loc_FF96DD88:\n"
298 "LDR R0, [SP,#0x38]\n"
299 "CMP R0, #0\n"
300 "BEQ loc_FF96DDC4\n"
301 "BL sub_FFABC088\n"
302 "MOV R0, #0\n"
303 "STR R5, [R6,#0x3C]\n"
304 "loc_FF96DDA0:\n"
305 "BL sub_FFA748A4\n"
306 "MOV R0, #0xC\n"
307 "BL sub_FF88BB38\n"
308 "MOV R0, #0xA0000\n"
309 "loc_FF96DDB0:\n"
310 "BL sub_FF897858\n"
311 "LDR R1, [R6,#0x98]!\n"
312 "LDR R0, [R6,#0xC]\n"
313 "BLX R1\n"
314 "B loc_FF96DC4C\n"
315
316 "loc_FF96DDC4:\n"
317 "MOV R0, #0\n"
318 "BL sub_FFA748A4\n"
319
320 "LDR R0, [SP,#0x34]\n"
321 "LDR R1, [SP,#0x3C]\n"
322
323
324 "BL sub_FFABBDE0\n"
325 "LDR R0, [R6,#0x5C]\n"
326 "LDR R3, =0x724C\n"
327 "ADD R1, R0, #1\n"
328 "STR R1, [R6,#0x5C]\n"
329 "STR R3, [SP]\n"
330 "LDR R0, [SP,#0x3C]\n"
331 "SUB R3, R3, #4\n"
332 "MOV R2, #0xF\n"
333 "BL sub_FFAB9F20\n"
334
335 "LDR R0, =0x724C-4\n"
336 "BL set_quality\n"
337 "loc_FF96DDFC:\n"
338 "LDR R0, [R6,#0x60]\n"
339 "ADD R0, R0, #1\n"
340 "STR R0, [R6,#0x60]\n"
341 "LDR R1, [R6,#0x4C]\n"
342 "MUL R0, R1, R0\n"
343 "LDR R1, [R6,#0x48]\n"
344 "BL sub_FFB61FF4\n"
345 "MOV R4, R0\n"
346 "BL sub_FFABC0C0\n"
347 "LDR R1, [R6,#0x80]\n"
348 "CMP R1, R4\n"
349 "BNE loc_FF96DE38\n"
350 "LDR R0, [R6,#0x34]\n"
351 "CMP R0, #1\n"
352 "BNE loc_FF96DE4C\n"
353 "loc_FF96DE38:\n"
354 "LDR R1, [R6,#0x8C]\n"
355 "MOV R0, R4\n"
356 "BLX R1\n"
357 "STR R4, [R6,#0x80]\n"
358 "STR R7, [R6,#0x34]\n"
359 "loc_FF96DE4C:\n"
360 "STR R7, [R6,#0x30]\n"
361 "B loc_FF96DC4C\n"
362 );
363 }