#include "lolevel.h" #include "platform.h" #include "core.h" #include "keyboard.h" extern long link_bss_start; extern long link_bss_end; extern void boot(); void startup() { long *bss = &link_bss_start; // sanity check if ((long)&link_bss_end > (MEMISOSTART + MEMISOSIZE)) { started(); shutdown(); } // initialize .bss senment while (bss<&link_bss_end) *bss++ = 0; boot(); } // Focus length table in firmware 0xfff4bcf0 #define NUM_FL 101 // 0 - 101, entries in firmware @0xfff4bcf0 using finsig need to be checked #define NUM_DATA 2 // 2 words each entry, first is FL extern int focus_len_table[NUM_FL*NUM_DATA]; //asm1989 done for sx260 // Conversion factor lens FL --> 35mm equiv // lens 35mm CF // ---- ---- -- // 4.5 25 ( 25/ 4.5) * 45 = 250 (min FL) // 90.0 500 (500/90.0) * 45 = 250 (max FL) #define CF_EFL 250 #define CF_EFL_DIV 45 const int zoom_points = NUM_FL; int get_effective_focal_length(int zp) { return (CF_EFL*get_focal_length(zp))/CF_EFL_DIV; } int get_focal_length(int zp) { if (zp < 0) zp = 0; else if (zp >= NUM_FL) zp = NUM_FL-1; return focus_len_table[zp*NUM_DATA]; } int get_zoom_x(int zp) { return get_focal_length(zp)*10/focus_len_table[0]; } long get_vbatt_min() { return 3300; } long get_vbatt_max() { return 4080; }