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 "dryos31.h"
+ Include-Abhängigkeitsdiagramm für boot.c:

gehe zum Quellcode dieser Datei

Makrodefinitionen

#define offsetof(TYPE, MEMBER)   ((int) &((TYPE *)0)->MEMBER)
 
#define LED_AF   0xC02200F4
 
#define LED_PR   0xC02200F0
 

Funktionen

void CreateTask_PhySw ()
 
void CreateTask_spytask ()
 
void boot ()
 
void task_CaptSeq ()
 
void task_InitFileModules ()
 
void task_MovieRecord ()
 
void task_ExpDrv ()
 
void task_PhySw ()
 
void task_FileWrite ()
 
void taskHook (context_t **context)
 
void __attribute__ ((naked, noinline))
 

Variablen

const char *const new_sa = &_end
 

Makro-Dokumentation

#define LED_AF   0xC02200F4

Definiert in Zeile 7 der Datei boot.c.

#define LED_PR   0xC02200F0

Definiert in Zeile 8 der Datei boot.c.

#define offsetof (   TYPE,
  MEMBER 
)    ((int) &((TYPE *)0)->MEMBER)

Definiert in Zeile 5 der Datei boot.c.

Dokumentation der Funktionen

void __attribute__ ( (naked, noinline)  )

Definiert in Zeile 94 der Datei boot.c.

94  {
95 asm volatile (
96  "LDR R1, =0xC0410000 \n"
97  "MOV R0, #0 \n"
98  "STR R0, [R1] \n"
99  "MOV R1, #0x78 \n"
100  "MCR p15, 0, R1, c1, c0 \n"
101  "MOV R1, #0 \n"
102  "MCR p15, 0, R1, c7, c10, 4 \n"
103  "MCR p15, 0, R1, c7, c5 \n"
104  "MCR p15, 0, R1, c7, c6 \n"
105  "MOV R0, #0x3D \n"
106  "MCR p15, 0, R0, c6, c0 \n"
107  "MOV R0, #0xC000002F \n"
108  "MCR p15, 0, R0, c6, c1 \n"
109  "MOV R0, #0x33 \n" // memory region & size. bits 5:1 = size index, actual size = 2^(size index + 1) = 64MB
110  "MCR p15, 0, R0, c6, c2 \n"
111  "MOV R0, #0x40000033 \n" // memory region & size. bits 5:1 = size index, actual size = 2^(size index + 1) = 64MB
112  "MCR p15, 0, R0, c6, c3 \n"
113  "MOV R0, #0x80000017 \n"
114  "MCR p15, 0, R0, c6, c4 \n"
115  "LDR R0, =0xFF80002D \n"
116  "MCR p15, 0, R0, c6, c5 \n"
117  "MOV R0, #0x34 \n"
118  "MCR p15, 0, R0, c2, c0 \n"
119  "MOV R0, #0x34 \n"
120  "MCR p15, 0, R0, c2, c0, 1 \n"
121  "MOV R0, #0x34 \n"
122  "MCR p15, 0, R0, c3, c0 \n"
123  "LDR R0, =0x3333330 \n"
124  "MCR p15, 0, R0, c5, c0, 2 \n"
125  "LDR R0, =0x3333330 \n"
126  "MCR p15, 0, R0, c5, c0, 3 \n"
127  "MRC p15, 0, R0, c1, c0 \n"
128  "ORR R0, R0, #0x1000 \n"
129  "ORR R0, R0, #4 \n"
130  "ORR R0, R0, #1 \n"
131  "MCR p15, 0, R0, c1, c0 \n"
132  "MOV R1, #0x80000006 \n"
133  "MCR p15, 0, R1, c9, c1 \n"
134  "MOV R1, #6 \n"
135  "MCR p15, 0, R1, c9, c1, 1 \n"
136  "MRC p15, 0, R1, c1, c0 \n"
137  "ORR R1, R1, #0x50000 \n"
138  "MCR p15, 0, R1, c1, c0 \n"
139  "LDR R2, =0xC0200000 \n"
140  "MOV R1, #1 \n"
141  "STR R1, [R2, #0x10C] \n"
142  "MOV R1, #0xFF \n"
143  "STR R1, [R2, #0xC] \n"
144  "STR R1, [R2, #0x1C] \n"
145  "STR R1, [R2, #0x2C] \n"
146  "STR R1, [R2, #0x3C] \n"
147  "STR R1, [R2, #0x4C] \n"
148  "STR R1, [R2, #0x5C] \n"
149  "STR R1, [R2, #0x6C] \n"
150  "STR R1, [R2, #0x7C] \n"
151  "STR R1, [R2, #0x8C] \n"
152  "STR R1, [R2, #0x9C] \n"
153  "STR R1, [R2, #0xAC] \n"
154  "STR R1, [R2, #0xBC] \n"
155  "STR R1, [R2, #0xCC] \n"
156  "STR R1, [R2, #0xDC] \n"
157  "STR R1, [R2, #0xEC] \n"
158  "STR R1, [R2, #0xFC] \n"
159  "LDR R1, =0xC0400008 \n"
160  "LDR R2, =0x430005 \n"
161  "STR R2, [R1] \n"
162  "MOV R1, #1 \n"
163  "LDR R2, =0xC0243100 \n"
164  "STR R2, [R1] \n"
165  "LDR R2, =0xC0242010 \n"
166  "LDR R1, [R2] \n"
167  "ORR R1, R1, #1 \n"
168  "STR R1, [R2] \n"
169  "LDR R0, =0xFFC337A8 \n" // canon_data_src
170  "LDR R1, =0x1900 \n" // MEMBASEADDR
171  "LDR R3, =0xF0AC \n"
172 "loc_FF81013C:\n"
173  "CMP R1, R3 \n"
174  "LDRCC R2, [R0], #4 \n"
175  "STRCC R2, [R1], #4 \n"
176  "BCC loc_FF81013C \n"
177  "LDR R1, =0x16A88C \n" // MEMISOSTART
178  "MOV R2, #0 \n"
179 "loc_FF810154:\n"
180  "CMP R3, R1 \n"
181  "STRCC R2, [R3], #4 \n"
182  "BCC loc_FF810154 \n"
183  "B sub_FF810358_my \n" //patched
184  );
185 }
void boot ( )

Definiert in Zeile 43 der Datei boot.c.

43  {
44 
45  long *canon_data_src = (void*)0xFFEDAC70; // value taken at ROM:FFC00188
46  long *canon_data_dst = (void*)0x1900;
47  long canon_data_len = 0xDF84 - 0x1900; // data_end - data_start 0xDF7C taken at ROM:FFC00138
48  long *canon_bss_start = (void*)0xDF84; // just after data
49  long canon_bss_len = 0xD4F38 - 0xDF84; // d4ec8 taken at ROM:FFC00FB4
50 
51  long i;
52 
53  // enable caches and write buffer...
54  // this is a carryover from old dryos ports, may not be useful
55  asm volatile (
56  "MRC p15, 0, R0,c1,c0\n"
57  "ORR R0, R0, #0x1000\n"
58  "ORR R0, R0, #4\n"
59  "ORR R0, R0, #1\n"
60  "MCR p15, 0, R0,c1,c0\n"
61  :::"r0"
62  );
63 
64  for(i=0;i<canon_data_len/4;i++)
65  canon_data_dst[i]=canon_data_src[i];
66 
67  for(i=0;i<canon_bss_len/4;i++)
68  canon_bss_start[i]=0;
69 
70  asm volatile ("B sub_FFC001A4_my\n");
71 };
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 task_CaptSeq ( )
void task_ExpDrv ( )
void task_FileWrite ( )
void task_InitFileModules ( )
void task_MovieRecord ( )
void task_PhySw ( )
void taskHook ( context_t **  context)

Definiert in Zeile 62 der Datei boot.c.

62  {
63 
64  task_t *tcb=(task_t*)((char*)context-offsetof(task_t, context));
65 
66  // Replace firmware task addresses with ours
67  if(tcb->entry == (void*)task_PhySw) tcb->entry = (void*)mykbd_task;
68  if(tcb->entry == (void*)task_CaptSeq) tcb->entry = (void*)capt_seq_task;
69  if(tcb->entry == (void*)task_InitFileModules) tcb->entry = (void*)init_file_modules_task;
70  if(tcb->entry == (void*)task_MovieRecord) tcb->entry = (void*)movie_record_task;
71  if(tcb->entry == (void*)task_ExpDrv) tcb->entry = (void*)exp_drv_task;
72  if(tcb->entry == (void*)task_FileWrite) tcb->entry = (void*)filewritetask;
73 }

Variablen-Dokumentation

const char* const new_sa = &_end

Definiert in Zeile 10 der Datei boot.c.