This source file includes following definitions.
- movie_record_task
- sub_fc1a5b6e_my
- sub_fc1a499c_my
- sub_fc02167a_my
- getchunkinfo
- replace_apendstrm
1
2
3 #define BR_LOW_OFS 0x2c
4 #define BR_MID_OFS 0x30
5 #define BR_HI_OFS 0x28
6
7
8 #define MAX_VIDEO_BITRATE 35040
9
10 #define FW_SHORT_TIME_LIMIT 30
11 #define SHORT_TIME_LIMIT 300
12 #define LONG_TIME_LIMIT (3*60*60)
13
14 #include "../../../generic/movie_rec.c"
15
16 void __attribute__((naked,noinline)) movie_record_task() {
17 asm volatile (
18
19
20 " push.w {r2, r3, r4, r5, r6, r7, r8, lr}\n"
21 " ldr r5, =0x00010b08\n"
22 " movs r6, #0\n"
23 " movw r7, #0xaea\n"
24 " movw r8, #0x2710\n"
25 " sub.w r4, r5, #0x80\n"
26 "loc_fc1a5d1c:\n"
27 " movs r2, #0\n"
28 " add r1, sp, #4\n"
29 " ldr r0, [r4, #0xc]\n"
30 " blx sub_fc251bfc\n"
31 " ldr r0, [sp, #4]\n"
32 " ldr r0, [r0]\n"
33 " cmp r0, #6\n"
34 " bhs loc_fc1a5dd0\n"
35 " tbb [pc, r0]\n"
36 "branchtable_fc1a5d32:\n"
37 " .byte((loc_fc1a5d38 - branchtable_fc1a5d32) / 2)\n"
38 " .byte((loc_fc1a5d56 - branchtable_fc1a5d32) / 2)\n"
39 " .byte((loc_fc1a5d78 - branchtable_fc1a5d32) / 2)\n"
40 " .byte((loc_fc1a5d7e - branchtable_fc1a5d32) / 2)\n"
41 " .byte((loc_fc1a5d9e - branchtable_fc1a5d32) / 2)\n"
42 " .byte((loc_fc1a5db0 - branchtable_fc1a5d32) / 2)\n"
43 ".align 1\n"
44 "loc_fc1a5d38:\n"
45 " bl replace_apendstrm\n"
46 " ldr r0, [r5, #0x1c]\n"
47 " cbz r0, loc_fc1a5d42\n"
48 "loc_fc1a5d3c:\n"
49 " bl sub_fc1a4618\n"
50 " b loc_fc1a5dd0\n"
51 "loc_fc1a5d42:\n"
52 " ldr r0, [r4, #0x5c]\n"
53 " cbnz r0, loc_fc1a5d4a\n"
54 " bl sub_fc1a63b4\n"
55 "loc_fc1a5d4a:\n"
56 " bl sub_fc1a5b6e_my\n"
57 "loc_fc1a5d4e:\n"
58 " cmp r0, #0\n"
59 " str r0, [r5, #0x1c]\n"
60 " bne loc_fc1a5d3c\n"
61 " b loc_fc1a5dd0\n"
62 "loc_fc1a5d56:\n"
63 " bl sub_fc1a5996\n"
64 " str r0, [r5, #0x1c]\n"
65 " ldr r1, [r4, #0x5c]\n"
66 " cbnz r1, loc_fc1a5d6e\n"
67 " lsls r0, r0, #0x1f\n"
68 " bne loc_fc1a5d6a\n"
69 " bl sub_fc1a57e8\n"
70 " str r0, [r5, #0x1c]\n"
71 "loc_fc1a5d6a:\n"
72 " bl sub_fc1a63d2\n"
73 "loc_fc1a5d6e:\n"
74 " ldr r0, [r5, #0x1c]\n"
75 " b loc_fc1a5d98\n"
76 "loc_fc1a5d72:\n"
77 " ldr r1, [r5, #0x30]\n"
78 " ldr r0, [r5, #0x44]\n"
79 " b loc_fc1a5dac\n"
80 "loc_fc1a5d78:\n"
81 " bl sub_fc1a65fe\n"
82 " b loc_fc1a5d4e\n"
83 "loc_fc1a5d7e:\n"
84 " bl sub_fc1a63b4\n"
85 " bl sub_fc1a562e\n"
86 " cmp r0, #0\n"
87 " str r0, [r5, #0x1c]\n"
88 " bne loc_fc1a5d3c\n"
89 " ldr r0, [r4, #0x6c]\n"
90 " cmp r0, #0\n"
91 " beq loc_fc1a5d72\n"
92 " bl sub_fc1a54cc\n"
93 " str r0, [r5, #0x1c]\n"
94 "loc_fc1a5d98:\n"
95 " cmp r0, #0\n"
96 " beq loc_fc1a5d72\n"
97 " b loc_fc1a5d3c\n"
98 "loc_fc1a5d9e:\n"
99 " bl sub_fc1a54cc\n"
100 " cmp r0, #0\n"
101 " str r0, [r5, #0x1c]\n"
102 " bne loc_fc1a5d3c\n"
103 " ldr r1, [r5, #0x38]\n"
104 " ldr r0, [r5, #0x4c]\n"
105 "loc_fc1a5dac:\n"
106 " blx r1\n"
107 " b loc_fc1a5dd0\n"
108 "loc_fc1a5db0:\n"
109 " bl sub_fc1a5eea\n"
110 " lsls r0, r0, #0x1f\n"
111 " beq loc_fc1a5dbc\n"
112 " movs r0, #1\n"
113 " b loc_fc1a5dc4\n"
114 "loc_fc1a5dbc:\n"
115 " str r6, [r4, #0x34]\n"
116 " mov r0, r6\n"
117 " str r6, [r4, #0x5c]\n"
118 " str r6, [r4, #0x58]\n"
119 "loc_fc1a5dc4:\n"
120 " str r0, [r5, #0x1c]\n"
121 " cbz r0, loc_fc1a5dd0\n"
122 " mov.w r0, #0xa0000\n"
123 " bl sub_fc07b032\n"
124 "loc_fc1a5dd0:\n"
125 " ldr r1, [sp, #4]\n"
126 " mov r2, r8\n"
127 " ldr r3, =0xfc1a4a18\n"
128 " str r6, [r1]\n"
129 " str r7, [sp]\n"
130 " ldr r0, [r4, #0x14]\n"
131 " blx sub_fc251afc\n"
132 " b loc_fc1a5d1c\n"
133 ".ltorg\n"
134 );
135 }
136
137 void __attribute__((naked,noinline)) sub_fc1a5b6e_my() {
138 asm volatile (
139
140 " push.w {r4, r5, r6, r7, r8, lr}\n"
141 " ldr r5, =0x00010a88\n"
142 " sub sp, #0xf0\n"
143 " add r1, sp, #0x18\n"
144 " add r0, sp, #0x84\n"
145 " mov r4, r1\n"
146 " ldr r2, [r5, #0x5c]\n"
147 " bl sub_fc1a484e\n"
148 " add r0, sp, #0x84\n"
149 " bl sub_fc23e51c\n"
150 " add r0, sp, #4\n"
151 " mov r1, r4\n"
152 " bl sub_fc1a499c_my\n"
153 " ldr pc, =0xFC1A5B91\n"
154 ".ltorg\n"
155 );
156 }
157
158 void __attribute__((naked,noinline)) sub_fc1a499c_my() {
159 asm volatile (
160
161 " push.w {r0, r1, r2, r3, r4, r5, r6, r7, r8, sb, sl, fp, ip, lr}\n"
162 " movs r6, #0\n"
163 " ldr.w r8, =0x00010a88\n"
164 " mov.w fp, #1\n"
165 " mov r5, r0\n"
166 " add.w r8, r8, #0x80\n"
167 " mov r4, r1\n"
168 " strd fp, r6, [sp]\n"
169 " strb.w fp, [r0]\n"
170 " mov sl, r6\n"
171 " strb r6, [r0, #1]\n"
172 " ldr.w r0, [r8, #0x20]\n"
173 " bl sub_fc2a4636\n"
174 " ldr r7, =0x00010a88\n"
175 " str r0, [r7, #0x40]\n"
176 " str r0, [r5, #8]\n"
177 " strb.w sl, [r5, #4]\n"
178 " ldr.w r0, [r8, #0x20]\n"
179 " bl sub_fc2a4d98\n"
180 " cbz r0, loc_fc1a4a08\n"
181 " ldr.w r0, [r8, #0x20]\n"
182 " bl sub_fc2a45d0\n"
183 " cmp r0, #4\n"
184 " bne loc_fc1a49ea\n"
185 " mov r0, fp\n"
186 " b loc_fc1a49ec\n"
187 "loc_fc1a49ea:\n"
188 " mov r0, sl\n"
189 "loc_fc1a49ec:\n"
190 " strb r0, [r7]\n"
191 " uxtb r0, r0\n"
192 " mov sb, r7\n"
193 " cmp r0, #2\n"
194 " strb r0, [r5, #6]\n"
195 " beq loc_fc1a4ab4\n"
196 " add.w r2, r5, #0x10\n"
197 " ldr.w r0, [r8, #0x20]\n"
198 " subs r1, r2, #4\n"
199 " bl sub_fc2a4cbe\n"
200 " b loc_fc1a4abc\n"
201 "loc_fc1a4a08:\n"
202
203
204
205 " movs r0, #2\n"
206 " b loc_fc1a49ec\n"
207 "loc_fc1a4ab4:\n"
208 " ldr.w r0, [sb, #0x40]\n"
209 " str r0, [r5, #0xc]\n"
210 " str r0, [r5, #0x10]\n"
211 "loc_fc1a4abc:\n"
212 " add.w r4, r4, #0x1c\n"
213 " movs r0, #0x64\n"
214 " movw r1, #0xbb80\n"
215 " mov r7, fp\n"
216 " strb r0, [r4, #3]\n"
217 " strb.w sl, [r4, #8]\n"
218 " strb.w sl, [r4, #6]\n"
219 " strb.w fp, [r4, #9]\n"
220 " strb.w fp, [r4, #0xb]\n"
221 " str sl, [r4, #-0x10]\n"
222 " strb.w sl, [r4, #5]\n"
223 " strb.w fp, [r4, #7]\n"
224 " strb.w fp, [r4, #0x1c]\n"
225 " str r1, [r4, #0x30]\n"
226 " mov.w r1, #0x10\n"
227 " strh r1, [r4, #0x34]\n"
228 " mov.w r1, #0x1f400\n"
229 " str r1, [r4, #0x3c]\n"
230 " mov.w r1, #0x300000\n"
231 " strb.w sl, [r4, #0x38]\n"
232 " sub.w r4, r4, #0x1c\n"
233 " ldr.w r0, [sb, #0x40]\n"
234 " cmp r0, r1\n"
235 " bls loc_fc1a4b10\n"
236 " str r0, [r4, #0x14]\n"
237 " b loc_fc1a4b12\n"
238 ".ltorg\n"
239 "loc_fc1a4b10:\n"
240 " str r1, [r4, #0x14]\n"
241 "loc_fc1a4b12:\n"
242 " movs r2, #0xf\n"
243 " ldr.w r3, [r8, #0x60]\n"
244 " movw r0, #0x3e9\n"
245 " ldr.w lr, =0x0001003c\n"
246 " movw r1, #0xbb5\n"
247 " cmp r3, #0xc\n"
248 " movw ip, #0x7530\n"
249 " mov.w fp, #3\n"
250 " bhs loc_fc1a4bf8\n"
251 " tbb [pc, r3]\n"
252 "branchtable_fc1a4b34:\n"
253 " .byte((loc_fc1a4b92 - branchtable_fc1a4b34) / 2)\n"
254 " .byte((loc_fc1a4bf8 - branchtable_fc1a4b34) / 2)\n"
255 " .byte((loc_fc1a4bf8 - branchtable_fc1a4b34) / 2)\n"
256 " .byte((loc_fc1a4b76 - branchtable_fc1a4b34) / 2)\n"
257 " .byte((loc_fc1a4b66 - branchtable_fc1a4b34) / 2)\n"
258 " .byte((loc_fc1a4b40 - branchtable_fc1a4b34) / 2)\n"
259 " .byte((loc_fc1a4bf8 - branchtable_fc1a4b34) / 2)\n"
260 " .byte((loc_fc1a4bf8 - branchtable_fc1a4b34) / 2)\n"
261 " .byte((loc_fc1a4bf8 - branchtable_fc1a4b34) / 2)\n"
262 " .byte((loc_fc1a4ba4 - branchtable_fc1a4b34) / 2)\n"
263 " .byte((loc_fc1a4bb4 - branchtable_fc1a4b34) / 2)\n"
264 " .byte((loc_fc1a4bd6 - branchtable_fc1a4b34) / 2)\n"
265 ".align 1\n"
266 "loc_fc1a4b40:\n"
267 " movw r1, #0x176a\n"
268 " strh r1, [r4, #0x1c]\n"
269 " movs r1, #0x1e\n"
270 " strb r1, [r4, #1]\n"
271 " str.w lr, [r4, #0x34]\n"
272 " movw r3, #0xea60\n"
273 " strb.w r7, [r4, #0x22]\n"
274 " strb r1, [r5, #5]\n"
275 " strd r3, r0, [r8, #8]\n"
276 " strd r0, r3, [sp]\n"
277 " strh.w r1, [sb, #2]\n"
278 " b loc_fc1a4c06\n"
279 "loc_fc1a4b66:\n"
280 " strh r1, [r4, #0x1c]\n"
281 " ldr r1, =0x0001003c\n"
282 " strb r2, [r4, #1]\n"
283 " adds r1, #0x3c\n"
284 " str r1, [r4, #0x34]\n"
285 " ldr r1, =0x0001d4c0\n"
286 " strb r2, [r5, #5]\n"
287 " b loc_fc1a4b84\n"
288 "loc_fc1a4b76:\n"
289 " strh r1, [r4, #0x1c]\n"
290 " ldr r1, =0x0001003c\n"
291 " strb r2, [r4, #1]\n"
292 " adds r1, #0xb4\n"
293 " str r1, [r4, #0x34]\n"
294 " ldr r1, =0x0003a980\n"
295 " strb r2, [r5, #5]\n"
296 "loc_fc1a4b84:\n"
297 " strd r1, r0, [r8, #8]\n"
298 "loc_fc1a4b88:\n"
299 " strd r0, ip, [sp]\n"
300 " mov r0, sb\n"
301 "loc_fc1a4b8e:\n"
302 " strh r2, [r0, #2]\n"
303 " b loc_fc1a4c06\n"
304 "loc_fc1a4b92:\n"
305 " strh r1, [r4, #0x1c]\n"
306 " ldr r1, =0x0001003c\n"
307 " strb r2, [r4, #1]\n"
308 " subs r1, #0x1e\n"
309 " str r1, [r4, #0x34]\n"
310 " strb r2, [r5, #5]\n"
311 " strd ip, r0, [r8, #8]\n"
312 " b loc_fc1a4b88\n"
313 "loc_fc1a4ba4:\n"
314 " strh r1, [r4, #0x1c]\n"
315 " movw r1, #0x1770\n"
316 " strb r2, [r4, #1]\n"
317 " str.w lr, [r4, #0x34]\n"
318 " strb r2, [r5, #5]\n"
319 " b loc_fc1a4b84\n"
320 "loc_fc1a4bb4:\n"
321 " strh r1, [r4, #0x1c]\n"
322 " movw r1, #0xbb8\n"
323 " strb r2, [r4, #1]\n"
324 " str.w lr, [r4, #0x34]\n"
325 " strb r2, [r5, #5]\n"
326 " strd r1, r0, [r8, #8]\n"
327 " strd r0, ip, [sp]\n"
328 " str.w r7, [sb, #0x78]\n"
329 " mov r0, sb\n"
330 " str.w r7, [sb, #0x7c]\n"
331 " b loc_fc1a4b8e\n"
332 "loc_fc1a4bd6:\n"
333 " strh r1, [r4, #0x1c]\n"
334 " movw r1, #0x5dc\n"
335 " strb r2, [r4, #1]\n"
336 " str.w lr, [r4, #0x34]\n"
337 " strb r2, [r5, #5]\n"
338 " strd r1, r0, [r8, #8]\n"
339 " strd r0, ip, [sp]\n"
340 " str.w fp, [sb, #0x78]\n"
341 " mov r0, sb\n"
342 " str.w fp, [sb, #0x7c]\n"
343 " b loc_fc1a4b8e\n"
344 "loc_fc1a4bf8:\n"
345 " movw r2, #0x3b9\n"
346 " ldr r1, =0xfc1a4a18\n"
347 " movs r0, #0\n"
348 " blx sub_fc251d14\n"
349 "loc_fc1a4c06:\n"
350 " movs r0, #2\n"
351 " strb r0, [r4]\n"
352 " strb.w sl, [r4, #0x26]\n"
353 " mov r1, sl\n"
354 " ldr.w r0, [sb, #0x58]\n"
355 " cbz r0, loc_fc1a4c2e\n"
356 " strb r1, [r4]\n"
357 " strb r7, [r4, #1]\n"
358 " strb.w r7, [r4, #0x26]\n"
359 " strb.w r7, [r4, #0x22]\n"
360 " ldr r2, =0x00010ba0\n"
361 " strh.w r7, [sb, #2]\n"
362 " str.w r2, [r8, #0x10]\n"
363 " b loc_fc1a4c32\n"
364 "loc_fc1a4c2e:\n"
365 " str.w r1, [r8, #0x10]\n"
366 "loc_fc1a4c32:\n"
367 " movs r1, #0\n"
368 " ldr r2, =0x001a0800\n"
369 " movs r3, #6\n"
370 " movw ip, #0x140\n"
371 " movw lr, #0xffff\n"
372 " strd r2, r1, [r4, #0x3c]\n"
373 " lsls r1, r2, #0x10\n"
374 " str r1, [r4, #0x44]\n"
375 " movs r2, #5\n"
376 " movw sl, #0xe0f\n"
377 " asrs r1, r1, #0x10\n"
378 " str r1, [r4, #0x48]\n"
379 " ldr.w r1, [r8, #0x58]\n"
380 " cmp r1, ip\n"
381 " beq loc_fc1a4d50\n"
382 " movw ip, #0x280\n"
383 " cmp r1, ip\n"
384 " beq loc_fc1a4d1e\n"
385 " lsls r3, r2, #8\n"
386 " mov.w ip, #0x29\n"
387 " cmp r1, r3\n"
388 " movw r2, #0x707\n"
389 " beq loc_fc1a4ccc\n"
390 " movw r0, #0x780\n"
391 " cmp r1, r0\n"
392 " bne loc_fc1a4d52\n"
393 " strh r0, [r4, #4]\n"
394 " movw r1, #0x438\n"
395 " strh r1, [r4, #2]\n"
396 " strh r0, [r4, #8]\n"
397 " strh r1, [r4, #6]\n"
398 " strb.w r7, [r4, #0x20]\n"
399 " strb.w r7, [r4, #0x39]\n"
400 " strb.w r7, [r4, #0x3a]\n"
401 " strb.w r7, [r4, #0x3b]\n"
402 " strh.w r7, [sb, #6]\n"
403 " ldr.w r0, [r8, #0x60]\n"
404 " cmp r0, #5\n"
405 " bne loc_fc1a4cb6\n"
406 " movw r0, #0x88b8\n"
407 " str r0, [r4, #0x28]\n"
408 " movw r0, #0x8854\n"
409 " str r0, [r4, #0x30]\n"
410 " movw r0, #0x87f0\n"
411 " str r0, [r4, #0x2c]\n"
412 " movs r0, #0x2a\n"
413 " b loc_fc1a4d1a\n"
414 "loc_fc1a4cb6:\n"
415 " movw r0, #0x5dc0\n"
416 " str r0, [r4, #0x28]\n"
417 " movw r0, #0x5d5c\n"
418 " str r0, [r4, #0x30]\n"
419 " movw r0, #0x5cf8\n"
420 " b loc_fc1a4cfe\n"
421 "loc_fc1a4cc8:\n"
422 " mov r6, r2\n"
423 " b loc_fc1a4de6\n"
424 "loc_fc1a4ccc:\n"
425 " strh r3, [r4, #4]\n"
426 " movw r1, #0x2d0\n"
427 " strh r1, [r4, #2]\n"
428 " strh r3, [r4, #8]\n"
429 " strh r1, [r4, #6]\n"
430 " strb.w r7, [r4, #0x20]\n"
431 " strb.w r7, [r4, #0x39]\n"
432 " strb.w r7, [r4, #0x3a]\n"
433 " strb.w r7, [r4, #0x3b]\n"
434 " strh.w r7, [sb, #6]\n"
435 " cbz r0, loc_fc1a4d06\n"
436 " movw r0, #0x9c40\n"
437 " str r0, [r4, #0x28]\n"
438 " movw r0, #0x9bdc\n"
439 " str r0, [r4, #0x30]\n"
440 " movw r0, #0x9b78\n"
441 "loc_fc1a4cfe:\n"
442 " str r0, [r4, #0x2c]\n"
443 " strb.w ip, [r4, #0x1e]\n"
444 " b loc_fc1a4cc8\n"
445 "loc_fc1a4d06:\n"
446 " movw r0, #0x1f40\n"
447 " str r0, [r4, #0x28]\n"
448 " movw r0, #0x1edc\n"
449 " str r0, [r4, #0x30]\n"
450 " movw r0, #0x1e78\n"
451 " str r0, [r4, #0x2c]\n"
452 " movs r0, #0x1f\n"
453 "loc_fc1a4d1a:\n"
454 " strb r0, [r4, #0x1e]\n"
455 " b loc_fc1a4cc8\n"
456 "loc_fc1a4d1e:\n"
457 " strh.w ip, [r4, #4]\n"
458 " movw r0, #0x1e0\n"
459 " strh r0, [r4, #2]\n"
460 " strh.w ip, [r4, #8]\n"
461 " strh r0, [r4, #6]\n"
462 " add.w r4, r4, #0x20\n"
463 " ldr.w r0, [r8, #0x60]\n"
464 " cmp r0, #1\n"
465 " beq loc_fc1a4d54\n"
466 " strb r3, [r4]\n"
467 " strb.w fp, [r4, #0x19]\n"
468 " strb r7, [r4, #0x1a]\n"
469 " strb.w fp, [r4, #0x1b]\n"
470 " sub.w r4, r4, #0x20\n"
471 " strh.w r3, [sb, #6]\n"
472 " b loc_fc1a4d66\n"
473 "loc_fc1a4d50:\n"
474 " b loc_fc1a4d7c\n"
475 "loc_fc1a4d52:\n"
476 " b loc_fc1a4dd8\n"
477 "loc_fc1a4d54:\n"
478 " strb r2, [r4]\n"
479 " movs r0, #2\n"
480 " strb r0, [r4, #0x19]\n"
481 " strb r7, [r4, #0x1a]\n"
482 " strb r0, [r4, #0x1b]\n"
483 " sub.w r4, r4, #0x20\n"
484 " strh.w lr, [sb, #6]\n"
485 "loc_fc1a4d66:\n"
486 " movw r0, #0xbb8\n"
487 " str r0, [r4, #0x28]\n"
488 " movw r0, #0xb54\n"
489 " str r0, [r4, #0x30]\n"
490 " movw r0, #0xaf0\n"
491 " str r0, [r4, #0x2c]\n"
492 " movs r0, #0x1e\n"
493 " b loc_fc1a4dd2\n"
494 "loc_fc1a4d7c:\n"
495 " strh.w ip, [r4, #4]\n"
496 " movs r0, #0xf0\n"
497 " strh r0, [r4, #2]\n"
498 " strh.w ip, [r4, #8]\n"
499 " strh r0, [r4, #6]\n"
500 " add.w r4, r4, #0x20\n"
501 " ldr.w r0, [r8, #0x60]\n"
502 " cmp r0, #1\n"
503 " beq loc_fc1a4dac\n"
504 " strb r3, [r4]\n"
505 " strb.w fp, [r4, #0x19]\n"
506 " strb r7, [r4, #0x1a]\n"
507 " strb.w fp, [r4, #0x1b]\n"
508 " sub.w r4, r4, #0x20\n"
509 " strh.w r3, [sb, #6]\n"
510 " b loc_fc1a4dbe\n"
511 "loc_fc1a4dac:\n"
512 " strb r2, [r4]\n"
513 " movs r0, #2\n"
514 " strb r0, [r4, #0x19]\n"
515 " strb r7, [r4, #0x1a]\n"
516 " strb r0, [r4, #0x1b]\n"
517 " sub.w r4, r4, #0x20\n"
518 " strh.w lr, [sb, #6]\n"
519 "loc_fc1a4dbe:\n"
520 " movw r0, #0x3e8\n"
521 " str r0, [r4, #0x28]\n"
522 " movw r0, #0x384\n"
523 " str r0, [r4, #0x30]\n"
524 " movw r0, #0x320\n"
525 " str r0, [r4, #0x2c]\n"
526 " movs r0, #0x14\n"
527 "loc_fc1a4dd2:\n"
528 " mov r6, sl\n"
529 " strb r0, [r4, #0x1e]\n"
530 " b loc_fc1a4de6\n"
531 "loc_fc1a4dd8:\n"
532 " movw r2, #0x443\n"
533 " ldr r1, =0xfc1a4a18\n"
534 " movs r0, #0\n"
535 " blx sub_fc251d14\n"
536 "loc_fc1a4de6:\n"
537 " ldr.w r0, [r8, #0x60]\n"
538 " cmp r0, #4\n"
539 " beq loc_fc1a4df2\n"
540 " cmp r0, #3\n"
541 " bne loc_fc1a4df8\n"
542 "loc_fc1a4df2:\n"
543 " movs r6, #0x1e\n"
544 " str.w r7, [sb, #0x60]\n"
545 "loc_fc1a4df8:\n"
546
547
548 " mov r0, r6\n"
549 " bl set_movie_time_limit\n"
550 " mov r6, r0\n"
551
552 " mov r0, r4\n"
553 " bl set_quality\n"
554
555 " ldr r1, =0x00010ba0\n"
556 " mov.w r8, #0\n"
557 " subs r1, #0x98\n"
558 " ldr r0, [r1, #8]\n"
559 " str r0, [sp, #0xc]\n"
560 " mul r2, r6, r0\n"
561 " ldr r0, [r1, #0xc]\n"
562 " mov sl, r0\n"
563 " udiv r0, r2, r0\n"
564 " mvn r2, #9\n"
565 " str r0, [r1, #0x6c]\n"
566 " str r0, [sp, #8]\n"
567 " adds r0, r6, r2\n"
568 " str.w r0, [sb, #0x50]\n"
569 " adc r1, r8, #-1\n"
570 " ldr.w r0, [sb, #0x74]\n"
571 " mov r1, sb\n"
572 " cbnz r0, loc_fc1a4e36\n"
573 " ldr r0, [sp, #0xc]\n"
574 " add r0, sl\n"
575 " subs r0, r0, #1\n"
576 " udiv r0, r0, sl\n"
577 " str r0, [r1, #0x74]\n"
578 "loc_fc1a4e36:\n"
579 " ldr r0, [r1, #0x5c]\n"
580 " cbz r0, loc_fc1a4e4c\n"
581 " strb r7, [r5, #2]\n"
582 " movs r0, #8\n"
583 " strb.w r8, [r5, #7]\n"
584 " str r0, [r4, #0x10]\n"
585 " movw r0, #0x780\n"
586 " str r0, [r4, #0x18]\n"
587 " b loc_fc1a4e72\n"
588 "loc_fc1a4e4c:\n"
589 " strb.w r8, [r5, #2]\n"
590 " ldrb r0, [r5, #6]\n"
591 " cmp r0, #2\n"
592 " beq loc_fc1a4e5a\n"
593 " strb r7, [r5, #7]\n"
594 " b loc_fc1a4e5e\n"
595 "loc_fc1a4e5a:\n"
596 " strb.w r8, [r5, #7]\n"
597 "loc_fc1a4e5e:\n"
598 " ldrh r0, [r1, #2]\n"
599 " ldr r2, [sp, #8]\n"
600 " str.w r8, [r4, #0x18]\n"
601 " add r2, r0\n"
602 " subs r2, r2, #1\n"
603 " udiv r0, r2, r0\n"
604 " adds r0, r0, #1\n"
605 " str r0, [r4, #0x10]\n"
606 "loc_fc1a4e72:\n"
607 " movs r0, #2\n"
608 " strh.w r0, [r4, #0x52]\n"
609 " strh r0, [r1, #4]\n"
610 " mov r6, r1\n"
611 " ldr r0, [r1, #0x64]\n"
612 " cbz r0, loc_fc1a4e84\n"
613 " strb r7, [r5, #3]\n"
614 " b loc_fc1a4e88\n"
615 "loc_fc1a4e84:\n"
616 " strb.w r8, [r5, #3]\n"
617 "loc_fc1a4e88:\n"
618 " movs r3, #2\n"
619 " ldr r5, =0x00010ba0\n"
620 " movs r1, #0xa9\n"
621 " add r2, sp, #4\n"
622 " subs r5, #0x98\n"
623 " ldr r0, [r5, #0x24]\n"
624 " bl sub_fc297b4a\n"
625 " ldr r0, [r5, #0x24]\n"
626 " movs r3, #2\n"
627 " movs r1, #0xa8\n"
628 " mov r2, sp\n"
629 " bl sub_fc297b4a\n"
630 " ldr r0, [r5, #0x24]\n"
631 " movs r3, #4\n"
632 " movs r1, #0xa2\n"
633 " add.w r2, r5, #8\n"
634 " bl sub_fc297b4a\n"
635 " ldr r0, [r5, #0x24]\n"
636 " movs r3, #4\n"
637 " movs r1, #0xa3\n"
638 " add.w r2, r5, #0xc\n"
639 " bl sub_fc297b4a\n"
640 " ldr r0, [r4, #0x28]\n"
641 " lsls r0, r0, #7\n"
642 " movs r2, #0xa\n"
643 " umull r2, r3, r0, r2\n"
644 " strd r0, r2, [r6, #0x44]\n"
645 " umull r0, r2, r0, fp\n"
646 " str r0, [r6, #0x4c]\n"
647 " pop.w {r0, r1, r2, r3, r4, r5, r6, r7, r8, sb, sl, fp, ip, pc}\n"
648 ".ltorg\n"
649 );
650 }
651
652
653
654
655 void __attribute__((naked,noinline)) sub_fc02167a_my() {
656 asm volatile (
657 " push {r0, lr}\n"
658 " ldr r0, [r0, #8]\n"
659 " ldr r0, [r0, #4]\n"
660 " bl getchunkinfo\n"
661 " pop {r0, lr}\n"
662 " ldr pc, =0xfc02167b\n"
663 );
664 }
665
666 void getchunkinfo(int *r0) {
667 int m;
668 unsigned int lsum = 0;
669 m = *r0;
670 int *cl = (int*)(*(r0+1));
671 while (m>0) {
672
673 lsum += *(cl+1);
674 cl+=3;
675 m--;
676 }
677 bitrate_calc(lsum);
678 }
679
680
681 void replace_apendstrm() {
682 *(int*)0x10E20 = (int)sub_fc02167a_my | 1;
683 }
684
685