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

gehe zum Quellcode dieser Datei

Funktionen

void CreateTask_PhySw ()
 
void CreateTask_spytask ()
 
void JogDial_task_my (void)
 
void taskCreateHook (int *p)
 
void __attribute__ ((naked, noinline))
 *-------------------------------------------------------------------— Mehr ...
 
void spytask (long ua, long ub, long uc, long ud, long ue, long uf)
 

Variablen

const char *const new_sa = &_end
 
volatile int jogdial_stopped
 

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

Definiert in Zeile 65 der Datei boot.c.

66 {
67  asm volatile (
68 " LDR R1, =0xC0410000 \n"
69 " MOV R0, #0 \n"
70 " STR R0, [R1] \n"
71 
72 " MOV R1, #0x78 \n"
73 " MCR p15, 0, R1,c1,c0 \n" // control reg
74 
75 " MOV R1, #0 \n"
76 " MCR p15, 0, R1,c7,c10, 4 \n" // drain write buffer
77 " MCR p15, 0, R1,c7,c5 \n" // flush instruction cache
78 " MCR p15, 0, R1,c7,c6 \n" // flush data cache
79 
80 " MOV R0, #0x3D \n" // size 2GB base 0x00000000
81 " MCR p15, 0, R0,c6,c0 \n" // protection region 0
82 " MOV R0, #0xC000002F \n" // size 16M base 0xc0000000
83 " MCR p15, 0, R0,c6,c1 \n" // protection region 1
84 " MOV R0, #0x35 \n" // size 128M base 0x00000000 (s90 is 64M)
85 " MCR p15, 0, R0,c6,c2 \n" // protection region 2
86 " MOV R0, #0x40000035 \n" // size 128M base 0x40000000 (s90 is 64M)
87 " MCR p15, 0, R0,c6,c3 \n" // protection region 3
88 " MOV R0, #0x80000017 \n" // size 4k base 0x80000000
89 " MCR p15, 0, R0,c6,c4 \n" // protection region 4
90 " LDR R0, =0xFF80002D \n" // size 8M base 0xff800000
91 " MCR p15, 0, R0,c6,c5 \n" // protection region 5
92 
93 " MOV R0, #0x34 \n" // regions 2,4,5
94 " MCR p15, 0, R0,c2,c0 \n" // data cachable bits
95 " MOV R0, #0x34 \n" // regions 2,4,5
96 " MCR p15, 0, R0,c2,c0, 1 \n" // instruction cachable bits
97 
98 " MOV R0, #0x34 \n" // regions 2,4,5
99 " MCR p15, 0, R0,c3,c0 \n" // data bufferable bits
100 " LDR R0, =0x3333330 \n" // region 0,7 = --, 1-6 = rw
101 " MCR p15, 0, R0,c5,c0, 2 \n" // data access permission
102 " LDR R0, =0x3333330 \n" // region 0,7 = --, 1-6 = rw
103 " MCR p15, 0, R0,c5,c0, 3 \n" // instruction access permission
104 
105 " MRC p15, 0, R0,c1,c0 \n" // control reg
106 " ORR R0, R0, #0x1000 \n" // enable L1 instruction cache
107 " ORR R0, R0, #4 \n" // L1 unified/data cache enable
108 " ORR R0, R0, #1 \n" // MMU or Protection Unit enable
109 " MCR p15, 0, R0,c1,c0 \n" // control reg
110 
111 " MOV R1, #0x80000006 \n" // size 4K base 0x80000000
112 " MCR p15, 0, R1,c9,c1 \n" // data tightly-coupled memory
113 " MOV R1, #6 \n" // size 4K base 0x00000000
114 " MCR p15, 0, R1,c9,c1, 1 \n" // instruction tightly-coupled memory
115 " MRC p15, 0, R1,c1,c0 \n" // control reg
116 
117 " ORR R1, R1, #0x50000 \n" // DRAM bit | IRAM bit
118 " MCR p15, 0, R1,c1,c0 \n" // control reg
119 
120 " LDR R2, =0xC0200000 \n"
121 " MOV R1, #1 \n"
122 " STR R1, [R2,#0x10C] \n"
123 
124 " MOV R1, #0xFF \n"
125 " STR R1, [R2,#0xC] \n"
126 " STR R1, [R2,#0x1C] \n"
127 " STR R1, [R2,#0x2C] \n"
128 " STR R1, [R2,#0x3C] \n"
129 " STR R1, [R2,#0x4C] \n"
130 " STR R1, [R2,#0x5C] \n"
131 " STR R1, [R2,#0x6C] \n"
132 " STR R1, [R2,#0x7C] \n"
133 " STR R1, [R2,#0x8C] \n"
134 " STR R1, [R2,#0x9C] \n"
135 " STR R1, [R2,#0xAC] \n"
136 " STR R1, [R2,#0xBC] \n"
137 " STR R1, [R2,#0xCC] \n"
138 " STR R1, [R2,#0xDC] \n"
139 " STR R1, [R2,#0xEC] \n"
140 " STR R1, [R2,#0xFC] \n"
141 
142 " LDR R1, =0xC0400008 \n"
143 " LDR R2, =0x430005 \n"
144 " STR R2, [R1] \n"
145 
146 " MOV R1, #1 \n"
147 " LDR R2, =0xC0243100 \n"
148 " STR R2, [R1] \n"
149 
150 " LDR R2, =0xC0242010 \n"
151 " LDR R1, [R2] \n"
152 " ORR R1, R1, #1 \n"
153 " STR R1, [R2] \n"
154 
155 " LDR R0, =0xFFC9A08C \n" // init data section
156 " LDR R1, =0x1900 \n"
157 " LDR R3, =0x10FE4 \n"
158 "loc_FF81013C: \n"
159 " CMP R1, R3 \n"
160 " LDRCC R2, [R0],#4 \n"
161 " STRCC R2, [R1],#4 \n"
162 " BCC loc_FF81013C \n"
163 
164 " LDR R1, =0x16EE30 \n" // clear bss section
165 " MOV R2, #0 \n"
166 "loc_FF810154: \n"
167 " CMP R3, R1 \n"
168 " STRCC R2, [R3],#4 \n"
169 " BCC loc_FF810154 \n"
170 
171 //" B sub_FF810354 \n"
172 " B sub_FF810354_my \n" // patched
173  );
174 };
void CreateTask_PhySw ( )
void CreateTask_spytask ( )

Definiert in Zeile 34 der Datei boot.c.

34  {
35  _CreateTask("SpyTask", 0x19, 0x2000, core_spytask, 0);
36 };
void JogDial_task_my ( void  )
void spytask ( long  ua,
long  ub,
long  uc,
long  ud,
long  ue,
long  uf 
)

Definiert in Zeile 451 der Datei boot.c.

452 {
453  (void)ua; (void)ub; (void)uc; (void)ud; (void)ue; (void)uf;
454  core_spytask();
455 }
void taskCreateHook ( int *  p)

Definiert in Zeile 39 der Datei boot.c.

40 {
41  p-=17;
42 
43  if (p[0] == (int)0xFF88322C)
44  p[0] = (int) capt_seq_task;
45 
46  if (p[0] == (int)0xFF986420)
47  p[0] = (int) movie_record_task;
48 
49  if (p[0] == (int)0xFF8A0AA0)
50  p[0] = (int) init_file_modules_task;
51 
52  if (p[0] == (int)0xFF8CF1A8)
53  p[0] = (int) exp_drv_task;
54 
55  if (p[0] == (int)0xFF865894)
56  p[0] = (int) JogDial_task_my;
57 }

Variablen-Dokumentation

volatile int jogdial_stopped

Definiert in Zeile 81 der Datei kbd.c.

const char* const new_sa = &_end

Definiert in Zeile 5 der Datei boot.c.