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 59 der Datei capt_seq.c.

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

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

Definiert in Zeile 54 der Datei capt_seq.c.

54  {
56 }
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 16 der Datei capt_seq.c.

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

Definiert in Zeile 25 der Datei capt_seq.c.

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

Definiert in Zeile 33 der Datei capt_seq.c.

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

Definiert in Zeile 881 der Datei capt_seq.c.

881  {
882  _LogCameraEvent(0x60,"remote hook");
883 }
void log_rh ( void  )

Definiert in Zeile 884 der Datei capt_seq.c.

884  {
885  _LogCameraEvent(0x60,"raw hook");
886 }

Variablen-Dokumentation

int active_raw_buffer
char* current_raw_addr

Definiert in Zeile 44 der Datei capt_seq.c.

long* nrflag = (long*)0x1e858
static

Definiert in Zeile 6 der Datei capt_seq.c.