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

gehe zum Quellcode dieser Datei

Makrodefinitionen

#define NUM_FL   (int)(sizeof fl_tbl / sizeof *fl_tbl)
 
#define CF_EFL   56000
 

Funktionen

void boot ()
 
void startup ()
 
int get_effective_focal_length (int zp)
 
int get_focal_length (int zp)
 
int get_zoom_x (int zp)
 
long get_vbatt_min ()
 
long get_vbatt_max ()
 

Variablen

long link_bss_start
 
long link_bss_end
 
static const int fl_tbl [] = { 5000, 6400, 7400, 9000, 11200, 13000, 15600, 20000 }
 
const int zoom_points = NUM_FL
 

Makro-Dokumentation

#define CF_EFL   56000

Definiert in Zeile 36 der Datei main.c.

#define NUM_FL   (int)(sizeof fl_tbl / sizeof *fl_tbl)

Definiert in Zeile 35 der Datei main.c.

Dokumentation der Funktionen

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 };
int get_effective_focal_length ( int  zp)

Definiert in Zeile 40 der Datei main.c.

40  {
41  return (CF_EFL*get_focal_length(zp))/10000;
42 }
int get_focal_length ( int  zp)

Definiert in Zeile 44 der Datei main.c.

44  {
45  if (zp<0) return fl_tbl[0];
46  else if (zp>NUM_FL-1) return fl_tbl[NUM_FL-1];
47  else return fl_tbl[zp];
48 }
long get_vbatt_max ( )

Definiert in Zeile 62 der Datei main.c.

63 {
64  return 4000; // fresh off charger slightly greater
65 }
long get_vbatt_min ( )

Definiert in Zeile 57 der Datei main.c.

58 {
59  return 3425; // hnikesch on forum
60 }
int get_zoom_x ( int  zp)

Definiert in Zeile 50 der Datei main.c.

50  {
51  if (zp<1) return 10;
52  else if (zp>NUM_FL-1) return fl_tbl[NUM_FL-1]*10/fl_tbl[0];
53  else return fl_tbl[zp]*10/fl_tbl[0];
54 }
void startup ( )

Definiert in Zeile 15 der Datei main.c.

16 {
17  long *bss = &link_bss_start;
18 
19  // sanity check (pointless with automemiso)
20  if ((long)&link_bss_end > (MEMISOSTART + MEMISOSIZE)){
21  started();
22  shutdown();
23  }
24 
25  // initialize .bss senment
26  while (bss < &link_bss_end)
27  *bss++ = 0;
28 
29  boot();
30 }

Variablen-Dokumentation

const int fl_tbl[] = { 5000, 6400, 7400, 9000, 11200, 13000, 15600, 20000 }
static

Definiert in Zeile 34 der Datei main.c.

long link_bss_end
long link_bss_start
const int zoom_points = NUM_FL

Definiert in Zeile 38 der Datei main.c.