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[0]))
 
#define CF_EFL   6000
 

Funktionen

void boot ()
 
void startup ()
 
int screen_opened (void)
 
int screen_rotated (void)
 
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
 
struct {
   int   zp
 
   int   fl
 
fl_tbl []
 
const int zoom_points = 129
 

Makro-Dokumentation

#define CF_EFL   6000

Definiert in Zeile 60 der Datei main.c.

#define NUM_FL   (int)(sizeof(fl_tbl)/sizeof(fl_tbl[0]))

Definiert in Zeile 59 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 64 der Datei main.c.

64  {
65  return (CF_EFL*get_focal_length(zp))/1000;
66 }
int get_focal_length ( int  zp)

Definiert in Zeile 68 der Datei main.c.

68  {
69  int i;
70 
71  if (zp<fl_tbl[0].zp)
72  return fl_tbl[0].fl;
73  else if (zp>fl_tbl[NUM_FL-1].zp)
74  return fl_tbl[NUM_FL-1].fl;
75  else
76  for (i=1; i<NUM_FL; ++i) {
77  if (zp==fl_tbl[i-1].zp)
78  return fl_tbl[i-1].fl;
79  else if (zp==fl_tbl[i].zp)
80  return fl_tbl[i].fl;
81  else if (zp<fl_tbl[i].zp)
82  return fl_tbl[i-1].fl+(zp-fl_tbl[i-1].zp)*(fl_tbl[i].fl-fl_tbl[i-1].fl)/(fl_tbl[i].zp-fl_tbl[i-1].zp);
83  }
84  return fl_tbl[NUM_FL-1].fl;
85 }
long get_vbatt_max ( )

Definiert in Zeile 96 der Datei main.c.

97 {
98  return 5500;
99 }
long get_vbatt_min ( )

Definiert in Zeile 91 der Datei main.c.

92 {
93  return 4700;
94 }
int get_zoom_x ( int  zp)

Definiert in Zeile 87 der Datei main.c.

87  {
88  return get_focal_length(zp)*10/fl_tbl[0].fl;
89 }
int screen_opened ( void  )

Definiert in Zeile 30 der Datei main.c.

30  {
31 // mode |= (physw_status[1] & 0x00000100)?0:MODE_SCREEN_OPENED;
32  return !(physw_status[1] & 0x00000100);
33 }
int screen_rotated ( void  )

Definiert in Zeile 35 der Datei main.c.

35  {
36 // mode |= (physw_status[1] & 0x00000200)?0:MODE_SCREEN_ROTATED;
37  return !(physw_status[1] & 0x00000200);
38 }
void startup ( )

Definiert in Zeile 12 der Datei main.c.

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

Variablen-Dokumentation

int fl

Definiert in Zeile 49 der Datei main.c.

struct { ... } fl_tbl[]
Initialisierung:
= {
{ 0, 6000 },
{ 11, 6400 },
{ 41, 12100 },
{ 64, 21300 },
{ 86, 41600 },
{ 105, 61400 },
{ 128, 72000 },
}
long link_bss_end
long link_bss_start
const int zoom_points = 129

Definiert in Zeile 62 der Datei main.c.

int zp

Definiert in Zeile 49 der Datei main.c.