source: branches/philmoz/platform/ixus310_elph500hs/lib.c @ 1340

Revision 1340, 3.5 KB checked in by philmoz, 20 months ago (diff)

Update development branch (merged from main trunk + updates to makefile for batch building).

  • Property svn:eol-style set to native
Line 
1#include "platform.h"
2#include "lolevel.h"
3
4void vid_bitmap_refresh()
5{
6        extern int full_screen_refresh;
7        extern void _ScreenUnlock();
8        extern void _ScreenLock();
9
10        full_screen_refresh |= 3;
11        _ScreenLock();
12        _ScreenUnlock();
13}
14
15
16void shutdown()
17{
18        volatile long *p = (void*)0xC022001C;   
19       
20        asm(
21                "MRS     R1, CPSR\n"
22                "AND     R0, R1, #0x80\n"
23                "ORR     R1, R1, #0x80\n"
24                "MSR     CPSR_cf, R1\n"
25                :::"r1","r0");
26       
27        *p = 0x44;  // power off.
28       
29        while(1);
30}
31
32#define LED_PR 0xC0220110       // Power Indicator
33
34void debug_led(int state)
35{
36 *(int*)LED_PR=state ? 0x46 : 0x44;
37}
38
39// IXUS 310 has 2 led values
40// 0/7 - Power LED (Green)
41// 1/11 - AF Assist Lamp
42void camera_set_led(int led, int state, int bright) {
43 static char led_table[2]={7,11};
44 _LEDDrive(led_table[led%sizeof(led_table)], state<=1 ? !state : state);
45}
46
47int get_flash_params_count(void){
48 return 0xA0;   // found in GetParameterData
49}
50
51// Viewport and Bitmap values that shouldn't change across firmware versions.
52// Values that may change are in lib.c for each firmware version.
53
54long vid_get_bitmap_screen_width() { return 480; }
55long vid_get_bitmap_screen_height() { return 240; }
56long vid_get_bitmap_buffer_width() { return 960; }
57long vid_get_bitmap_buffer_height() { return 270; }
58
59int vid_get_viewport_buffer_width() { return 960; }     // IXUS 310 - wide screen LCD (viewport is actually 480 high, CHDK not set up for this so we skip every 2nd row)
60
61int vid_get_viewport_width()
62{
63        // viewport width table for each image size
64        // 0 = 4:3, 1 = 16:9, 2 = 3:2, 3 = 1:1
65        static long vp_w[5] = { 360, 480, 408, 272 };
66        return vp_w[shooting_get_prop(PROPCASE_ASPECT_RATIO)];
67}
68
69int vid_get_viewport_xoffset()
70{
71        // viewport width offset table for each image size
72        // 0 = 4:3, 1 = 16:9, 2 = 3:2, 3 = 1:1
73        static long vp_w[5] = { 60, 0, 36, 104 };                               // should all be even values for edge overlay
74        return vp_w[shooting_get_prop(PROPCASE_ASPECT_RATIO)];
75}
76
77long vid_get_viewport_height(){ return 240; }
78
79// viewport image offset - used when image size != viewport size (zebra, histogram, motion detect & edge overlay)
80// returns the byte offset into the viewport buffer where the image pixels start (to skip any black borders)
81int vid_get_viewport_image_offset() {
82        return vid_get_viewport_xoffset() * 3;
83}
84
85// viewport image offset - used when image size != viewport size (zebra, histogram, motion detect & edge overlay)
86// returns the byte offset to skip at the end of a viewport buffer row to get to the next row.
87int vid_get_viewport_row_offset() {
88        return (vid_get_viewport_buffer_width() - vid_get_viewport_width()) * 3;
89}
90
91// Functions for PTP Live View system
92
93int vid_get_viewport_xoffset_proper()           { return vid_get_viewport_xoffset() * 2; }
94int vid_get_viewport_yoffset_proper()           { return 480; }
95int vid_get_viewport_width_proper()             { return vid_get_viewport_width() * 2; }
96int vid_get_viewport_height_proper()            { return 480; }
97int vid_get_viewport_max_width()                { return 960; }
98int vid_get_viewport_max_height()               { return 480; }
99int vid_get_palette_type()                      { return 3; }
100int vid_get_palette_size()                      { return 256 * 4; }
101int vid_get_aspect_ratio()                      { return 1; }
102
103void *vid_get_bitmap_active_buffer()
104{
105    extern int active_bitmap_buffer;
106    extern char* bitmap_buffer[];
107    return bitmap_buffer[active_bitmap_buffer];
108}
109
110void *vid_get_bitmap_active_palette()
111{
112    extern int active_palette_buffer;
113    extern char* palette_buffer[];
114    return (palette_buffer[active_palette_buffer]+8);
115}
Note: See TracBrowser for help on using the repository browser.