CHDK_DE Vorschauversion  Trunk Rev. 6014
 Alle Datenstrukturen Dateien Funktionen Variablen Typdefinitionen Aufzählungen Aufzählungswerte Makrodefinitionen
capt_seq.c-Dateireferenz
#include "lolevel.h"
#include "platform.h"
#include "core.h"
#include "conf.h"
#include "../../../generic/capt_seq.c"
+ Include-Abhängigkeitsdiagramm für capt_seq.c:

gehe zum Quellcode dieser Datei

Makrodefinitionen

#define NR_AUTO   (0)
 

Funktionen

void _LogCameraEvent (int id, const char *fmt,...)
 
char * hook_raw_image_addr (void)
 
void log_capt_seq (int m)
 
void log_capt_seq2 (int m)
 
void log_capt_seq_override (void)
 
int _captseq_raw_addr_init (int raw_index, char **ptr)
 
void captseq_raw_addr_init_my (int raw_index, char **ptr)
 
void clear_current_raw_addr (void)
 
void __attribute__ ((naked, noinline))
 *-------------------------------------------------------------------— Mehr ...
 
void log_remote_hook (void)
 
void log_rh (void)
 

Variablen

static long * nrflag = (long*)0x1e858
 
int active_raw_buffer
 
char * current_raw_addr
 

Makro-Dokumentation

#define NR_AUTO   (0)

Definiert in Zeile 5 der Datei capt_seq.c.

Dokumentation der Funktionen

void __attribute__ ( (naked, noinline)  )

*-------------------------------------------------------------------—

!!

IS_ERROR( hSoundHandle )

IS_ERROR( RetCode )

IS_ERROR( RetCode )

IS_ERROR( RetCode )

IS_ERROR( RetCode )

"MOV R3, #0\n" "STR R3, [R9]\n"

TODO! below is from sd400

"MOV R3, #0\n" "STR R3, [R9]\n"

TODO! below is from sd400

__MovieRecorder_c__100

__MovieRecorder_c__100

ASM1989 -> In sx200:FF857190 //"Mounter.c"

ASM1989 -> In sx200:FF81B284 // DebugAssert

Definiert in Zeile 56 der Datei capt_seq.c.

56  {
57  asm volatile (
58 // task_CaptSeq 0xfc15275f
59 " push {r3, r4, r5, r6, r7, lr}\n"
60 " ldr r4, =0x0003c478\n"
61 " movs r6, #0\n"
62 " ldr r5, =0x0000ba2c\n"
63 "loc_fc152766:\n"
64 " movs r2, #0\n"
65 " mov r1, sp\n"
66 " ldr r0, [r5, #8]\n"
67 " blx sub_fc2cf34c\n" // j_ReceiveMessageQueue
68 " lsls r0, r0, #0x1f\n"
69 " beq loc_fc152788\n"
70 " movw r2, #0x448\n"
71 " ldr r1, =0xfc152410\n" // *"SsShootTask.c"
72 " movs r0, #0\n"
73 " blx sub_fc2cf40c\n" // j_DebugAssert
74 " blx sub_fc2cf35c\n"
75 " pop {r3, r4, r5, r6, r7, pc}\n"
76 "loc_fc152788:\n"
77 " ldr r0, [sp]\n"
78 " ldr r0, [r0]\n"
79 " cmp r0, #1\n"
80 " beq loc_fc1527a0\n"
81 " cmp r0, #0x29\n"
82 " beq loc_fc1527a0\n"
83 " cmp r0, #0x1d\n"
84 " beq loc_fc1527a0\n"
85 " cmp r0, #0x21\n"
86 " beq loc_fc1527a0\n"
87 " bl sub_fc1dd978\n"
88 "loc_fc1527a0:\n"
89 " ldr r0, [sp]\n"
90 " ldr r1, [r0]\n"
91 " cmp r1, #0x2b\n"
92 " bhs loc_fc152888\n"
93 " tbb [pc, r1]\n" // (jumptable r1 43 elements)
94 "branchtable_fc1527ac:\n"
95 " .byte((loc_fc1527d8 - branchtable_fc1527ac) / 2)\n" // (case 0)
96 " .byte((loc_fc1527f0 - branchtable_fc1527ac) / 2)\n" // (case 1)
97 " .byte((loc_fc1527f8 - branchtable_fc1527ac) / 2)\n" // (case 2)
98 " .byte((loc_fc152806 - branchtable_fc1527ac) / 2)\n" // (case 3)
99 " .byte((loc_fc152800 - branchtable_fc1527ac) / 2)\n" // (case 4)
100 " .byte((loc_fc152812 - branchtable_fc1527ac) / 2)\n" // (case 5)
101 " .byte((loc_fc152818 - branchtable_fc1527ac) / 2)\n" // (case 6)
102 " .byte((loc_fc15281e - branchtable_fc1527ac) / 2)\n" // (case 7)
103 " .byte((loc_fc152826 - branchtable_fc1527ac) / 2)\n" // (case 8)
104 " .byte((loc_fc152866 - branchtable_fc1527ac) / 2)\n" // (case 9)
105 " .byte((loc_fc152830 - branchtable_fc1527ac) / 2)\n" // (case 10)
106 " .byte((loc_fc152838 - branchtable_fc1527ac) / 2)\n" // (case 11)
107 " .byte((loc_fc15284c - branchtable_fc1527ac) / 2)\n" // (case 12)
108 " .byte((loc_fc152854 - branchtable_fc1527ac) / 2)\n" // (case 13)
109 " .byte((loc_fc15285a - branchtable_fc1527ac) / 2)\n" // (case 14)
110 " .byte((loc_fc152860 - branchtable_fc1527ac) / 2)\n" // (case 15)
111 " .byte((loc_fc152870 - branchtable_fc1527ac) / 2)\n" // (case 16)
112 " .byte((loc_fc152876 - branchtable_fc1527ac) / 2)\n" // (case 17)
113 " .byte((loc_fc15287c - branchtable_fc1527ac) / 2)\n" // (case 18)
114 " .byte((loc_fc152882 - branchtable_fc1527ac) / 2)\n" // (case 19)
115 " .byte((loc_fc15288a - branchtable_fc1527ac) / 2)\n" // (case 20)
116 " .byte((loc_fc15288e - branchtable_fc1527ac) / 2)\n" // (case 21)
117 " .byte((loc_fc152894 - branchtable_fc1527ac) / 2)\n" // (case 22)
118 " .byte((loc_fc15289a - branchtable_fc1527ac) / 2)\n" // (case 23)
119 " .byte((loc_fc1528a0 - branchtable_fc1527ac) / 2)\n" // (case 24)
120 " .byte((loc_fc1528a6 - branchtable_fc1527ac) / 2)\n" // (case 25)
121 " .byte((loc_fc1528ac - branchtable_fc1527ac) / 2)\n" // (case 26)
122 " .byte((loc_fc1528b4 - branchtable_fc1527ac) / 2)\n" // (case 27)
123 " .byte((loc_fc1528ba - branchtable_fc1527ac) / 2)\n" // (case 28)
124 " .byte((loc_fc1528be - branchtable_fc1527ac) / 2)\n" // (case 29)
125 " .byte((loc_fc1528c6 - branchtable_fc1527ac) / 2)\n" // (case 30)
126 " .byte((loc_fc1528cc - branchtable_fc1527ac) / 2)\n" // (case 31)
127 " .byte((loc_fc1528f6 - branchtable_fc1527ac) / 2)\n" // (case 32)
128 " .byte((loc_fc1528fc - branchtable_fc1527ac) / 2)\n" // (case 33)
129 " .byte((loc_fc152902 - branchtable_fc1527ac) / 2)\n" // (case 34)
130 " .byte((loc_fc152908 - branchtable_fc1527ac) / 2)\n" // (case 35)
131 " .byte((loc_fc15290e - branchtable_fc1527ac) / 2)\n" // (case 36)
132 " .byte((loc_fc152914 - branchtable_fc1527ac) / 2)\n" // (case 37)
133 " .byte((loc_fc15291c - branchtable_fc1527ac) / 2)\n" // (case 38)
134 " .byte((loc_fc152922 - branchtable_fc1527ac) / 2)\n" // (case 39)
135 " .byte((loc_fc152946 - branchtable_fc1527ac) / 2)\n" // (case 40)
136 " .byte((loc_fc15294c - branchtable_fc1527ac) / 2)\n" // (case 41)
137 " .byte((loc_fc152966 - branchtable_fc1527ac) / 2)\n" // (case 42)
138 ".align 1\n"
139 "loc_fc1527d8:\n"
140 " ldr r0, [r0, #0xc]\n"
141 " uxtb r0, r0\n"
142 " bl sub_fc152cfa\n"
143 #ifdef CAPTSEQ_DEBUG_LOG
144 "bl log_capt_seq_override\n"
145 #endif
146 " BL clear_current_raw_addr\n" // +
147 " BL shooting_expo_param_override\n" //sx280
148 " bl sub_fc150454\n"
149 " ldr r0, [r4, #0x28]\n"
150 " cmp r0, #0\n"
151 " beq loc_fc1527ee\n"
152 //" bl sub_fc1dcaa8\n"
153 " bl sub_fc1dcaa8_my\n"
154 "loc_fc1527ee:\n"
155 " b loc_fc152966\n"
156 "loc_fc1527f0:\n"
157 " ldr r0, [r0, #0x10]\n"
158 //" bl sub_fc1dc8d2\n"
159 " bl sub_fc1dc8d2_my\n"
160 " b loc_fc152966\n"
161 "loc_fc1527f8:\n"
162 " movs r0, #1\n"
163 " bl sub_fc152ff4\n"
164 " b loc_fc152966\n"
165 "loc_fc152800:\n"
166 " bl sub_fc152a72\n"
167 " b loc_fc15280e\n"
168 "loc_fc152806:\n"
169 " ldr r0, [r0, #0xc]\n"
170 " uxtb r0, r0\n"
171 " bl sub_fc152ce2\n"
172 "loc_fc15280e:\n"
173 " str r6, [r4, #0x28]\n"
174 " b loc_fc152966\n"
175 "loc_fc152812:\n"
176 " bl sub_fc152ce8\n"
177 " b loc_fc152966\n"
178 "loc_fc152818:\n"
179 " bl sub_fc152ef0\n"
180 " b loc_fc15282a\n"
181 "loc_fc15281e:\n"
182 " ldr r0, [r0, #0x10]\n"
183 " bl sub_fc1dcb50\n"
184 " b loc_fc152966\n"
185 "loc_fc152826:\n"
186 " bl sub_fc152f7a\n"
187 "loc_fc15282a:\n"
188 " bl sub_fc150454\n"
189 " b loc_fc152966\n"
190 "loc_fc152830:\n"
191 " ldr r0, [r4, #0x54]\n"
192 " bl sub_fc153580\n"
193 " b loc_fc152966\n"
194 "loc_fc152838:\n"
195 " bl sub_fc15380c\n"
196 " b loc_fc152966\n"
197 ".ltorg\n"
198 //skip
199 "loc_fc15284c:\n"
200 " ldr r0, [r0, #0xc]\n"
201 " bl sub_fc153858\n"
202 " b loc_fc152966\n"
203 "loc_fc152854:\n"
204 " bl sub_fc1539d2\n"
205 " b loc_fc152966\n"
206 "loc_fc15285a:\n"
207 " bl sub_fc153da0\n"
208 " b loc_fc152966\n"
209 "loc_fc152860:\n"
210 " bl sub_fc153e36\n"
211 " b loc_fc152966\n"
212 "loc_fc152866:\n"
213 " ldr r0, [r0, #0xc]\n"
214 " uxtb r0, r0\n"
215 " bl sub_fc152ce2\n"
216 " b loc_fc152966\n"
217 "loc_fc152870:\n"
218 " bl sub_fc1db418\n"
219 " b loc_fc152966\n"
220 "loc_fc152876:\n"
221 " bl sub_fc1db600\n"
222 " b loc_fc152966\n"
223 "loc_fc15287c:\n"
224 " bl sub_fc1db69c\n"
225 " b loc_fc152966\n"
226 "loc_fc152882:\n"
227 " bl sub_fc1db718\n"
228 " b loc_fc152966\n"
229 "loc_fc152888:\n"
230 " b loc_fc152958\n"
231 "loc_fc15288a:\n"
232 " movs r0, #0\n"
233 " b loc_fc1528ae\n"
234 "loc_fc15288e:\n"
235 " bl sub_fc1dbb04\n"
236 " b loc_fc152966\n"
237 "loc_fc152894:\n"
238 " bl sub_fc1dbb64\n"
239 " b loc_fc152966\n"
240 "loc_fc15289a:\n"
241 " bl sub_fc1dbb68\n"
242 " b loc_fc152966\n"
243 "loc_fc1528a0:\n"
244 " bl sub_fc1dbb78\n"
245 " b loc_fc152966\n"
246 "loc_fc1528a6:\n"
247 " bl sub_fc1dbbf0\n"
248 " b loc_fc152966\n"
249 "loc_fc1528ac:\n"
250 " movs r0, #1\n"
251 "loc_fc1528ae:\n"
252 " bl sub_fc1db9e4\n"
253 " b loc_fc152966\n"
254 "loc_fc1528b4:\n"
255 " bl sub_fc153102\n"
256 " b loc_fc152966\n"
257 "loc_fc1528ba:\n"
258 " movs r0, #0\n"
259 " b loc_fc1528c0\n"
260 "loc_fc1528be:\n"
261 " ldr r0, [r0, #0xc]\n"
262 "loc_fc1528c0:\n"
263 " bl sub_fc153164\n"
264 " b loc_fc152966\n"
265 "loc_fc1528c6:\n"
266 " bl sub_fc1db8d8\n"
267 " b loc_fc152966\n"
268 "loc_fc1528cc:\n"
269 " ldr r1, =0x0003c4da\n"
270 " movs r2, #2\n"
271 " movs r0, #0x72\n"
272 " bl _GetPropertyCase\n"
273 " lsls r0, r0, #0x1f\n"
274 " beq loc_fc1528e8\n"
275 " movw r2, #0x508\n"
276 " ldr r1, =0xfc152410\n" // *"SsShootTask.c"
277 " movs r0, #0\n"
278 " blx sub_fc2cf40c\n" // j_DebugAssert
279 "loc_fc1528e8:\n"
280 " ldrh.w r0, [r4, #0x62]\n"
281 " cmp r0, #1\n"
282 " bne loc_fc152966\n"
283 " bl sub_fc1db8d2\n"
284 " b loc_fc152966\n"
285 "loc_fc1528f6:\n"
286 " bl sub_fc1db956\n"
287 " b loc_fc152966\n"
288 "loc_fc1528fc:\n"
289 " bl sub_fc1dd354\n"
290 " b loc_fc152966\n"
291 "loc_fc152902:\n"
292 " bl sub_fc150d7a\n"
293 " b loc_fc152966\n"
294 "loc_fc152908:\n"
295 " bl sub_fc2aa48e\n"
296 " b loc_fc152966\n"
297 "loc_fc15290e:\n"
298 " bl sub_fc2aa568\n"
299 " b loc_fc152966\n"
300 "loc_fc152914:\n"
301 " ldr r0, [r0, #0xc]\n"
302 " bl sub_fc1dbcc4\n"
303 " b loc_fc152966\n"
304 "loc_fc15291c:\n"
305 " bl sub_fc1dbd2c\n"
306 " b loc_fc152966\n"
307 "loc_fc152922:\n"
308 " bl sub_fc15893e\n"
309 " ldrh.w r0, [r4, #0x1a4]\n"
310 " cmp r0, #4\n"
311 " beq loc_fc152938\n"
312 " ldrh r0, [r4]\n"
313 " sub.w r1, r0, #0x4200\n"
314 " subs r1, #0x36\n"
315 " bne loc_fc152966\n"
316 "loc_fc152938:\n"
317 " bl sub_fc2aa568\n"
318 " bl sub_fc2aaa7e\n"
319 " bl sub_fc2aa8c6\n"
320 " b loc_fc152966\n"
321 "loc_fc152946:\n"
322 " movs r2, #0\n"
323 " movs r1, #0x11\n"
324 " b loc_fc152950\n"
325 "loc_fc15294c:\n"
326 " movs r2, #0\n"
327 " movs r1, #0x10\n"
328 "loc_fc152950:\n"
329 " movs r0, #0\n"
330 " bl sub_fc150f62\n"
331 " b loc_fc152966\n"
332 "loc_fc152958:\n"
333 " movw r2, #0x572\n"
334 " ldr r1, =0xfc152410\n" // *"SsShootTask.c"
335 " movs r0, #0\n"
336 " blx sub_fc2cf40c\n" // j_DebugAssert
337 "loc_fc152966:\n"
338 // debug after message handled
339 "ldr r0, [sp]\n"
340 "ldr r0, [r0]\n"
341 "bl log_capt_seq2\n"
342 " BL capt_seq_hook_set_nr\n" // dark frame control
343 " ldr r0, [sp]\n"
344 " ldr r1, [r0, #4]\n"
345 " ldr r0, [r5, #4]\n"
346 " blx sub_fc2cf32c\n" // j_SetEventFlag
347 " ldr r7, [sp]\n"
348 " ldr r0, [r7, #8]\n"
349 " cbnz r0, loc_fc152984\n"
350 " movw r2, #0x128\n"
351 " ldr r1, =0xfc152410\n" // *"SsShootTask.c"
352 " movs r0, #0\n"
353 " blx sub_fc2cf40c\n" // j_DebugAssert
354 "loc_fc152984:\n"
355 " str r6, [r7, #8]\n"
356 " b loc_fc152766\n"
357 /*" ldr r2, =0x0003c2f0\n"
358 " movs r0, #0\n"
359 " push {r3, r4, r5, lr}\n"
360 " mov r1, r0\n"
361 */
362 ".ltorg\n"
363  );
364 }
int _captseq_raw_addr_init ( int  raw_index,
char **  ptr 
)
void _LogCameraEvent ( int  id,
const char *  fmt,
  ... 
)
void captseq_raw_addr_init_my ( int  raw_index,
char **  ptr 
)

Definiert in Zeile 43 der Datei capt_seq.c.

43  {
44  _captseq_raw_addr_init(raw_index,ptr);
45  current_raw_addr=*(ptr + 0x5c/4); // fc154c5a: 65e0 str r0, [r4, #92]
46 #ifdef CAPTSEQ_DEBUG_LOG
47  _LogCameraEvent(0x60,"rawinit i:0x%x p:0x%x v:0x%x",raw_index,ptr,current_raw_addr);
48 #endif
49 }
void clear_current_raw_addr ( void  )

Definiert in Zeile 51 der Datei capt_seq.c.

51  {
53 }
char* hook_raw_image_addr ( void  )

Definiert in Zeile 3 der Datei lib.c.

4 {
5  // Found 0x11B96B80 at ROM:FFC377A0
6  // Found 0x107D58E0 at ROM:FFC756CC
7  // 0x51C0 + 0x18 found at ROM:FFC4C504
8  return (char*) (*(int*)(0x51C0+0x18) ? 0x11B96B80 : 0x107D58E0);
9 }
void log_capt_seq ( int  m)

Definiert in Zeile 13 der Datei capt_seq.c.

14 {
15  _LogCameraEvent(0x60,"cs m:%d arb:%d rb:0x%08x i:%04d",
16  m,
17  active_raw_buffer,
20 }
void log_capt_seq2 ( int  m)

Definiert in Zeile 22 der Datei capt_seq.c.

23 {
24  _LogCameraEvent(0x60,"cs end m:%d arb:%d rb:0x%08x i:%04d",
25  m,
26  active_raw_buffer,
29 }
void log_capt_seq_override ( void  )

Definiert in Zeile 30 der Datei capt_seq.c.

31 {
32  _LogCameraEvent(0x60,"cs override arb:%d rb:0x%08x i:%04d",
33  active_raw_buffer,
36 }
void log_remote_hook ( void  )

Definiert in Zeile 879 der Datei capt_seq.c.

879  {
880  _LogCameraEvent(0x60,"remote hook");
881 }
void log_rh ( void  )

Definiert in Zeile 882 der Datei capt_seq.c.

882  {
883  _LogCameraEvent(0x60,"raw hook");
884 }

Variablen-Dokumentation

int active_raw_buffer
char* current_raw_addr

Definiert in Zeile 41 der Datei capt_seq.c.

long* nrflag = (long*)0x1e858
static

Definiert in Zeile 6 der Datei capt_seq.c.