source: trunk/platform/g12/lib.c @ 2798

Revision 2548, 6.7 KB checked in by philmoz, 4 months ago (diff)

Fix chdkptp live view display in movie mode for G12, G1X, SX30 and SX40.

  • 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 0xC0220138       // Lower Indicator
33
34void debug_led(int state)
35{
36 *(int*)LED_PR=state ? 0x46 : 0x44;
37}
38
39// G12 has 7 led values
40// 0/0 - Upper indicator Green
41// 1/1 - Upper indicator Orange
42// 2/2 - Lower indicator Yellow
43// 3/3 - Power LED Green
44// 4/9 - AF Assist Lamp
45// 5/14 - ISO LED
46// 6/15 - EV LED
47void camera_set_led(int led, int state, int bright) {
48 static char led_table[7]={0,1,2,3,9,14,15};
49 _LEDDrive(led_table[led%sizeof(led_table)], state<=1 ? !state : state);
50}
51
52int get_flash_params_count(void){
53 return 0x9a;   // found in GetParameterData
54}
55
56void JogDial_CW(void){
57 _PostLogicalEventForNotPowerType(0x86E, 1);  // RotateJogDialRight (table @ FFC0BE90)
58}
59
60void JogDial_CCW(void){
61 _PostLogicalEventForNotPowerType(0x86F, 1);  // RotateJogDialLeft (table @ FFC0BE90)
62}
63
64// Viewport and Bitmap values that shouldn't change across firmware versions.
65// Values that may change are in lib.c for each firmware version.
66
67// Defined in stubs_min.S
68extern char active_viewport_buffer;
69extern void* viewport_buffers[];
70
71void *vid_get_viewport_fb()
72{
73    // Return first viewport buffer - for case when vid_get_viewport_live_fb not defined
74    return viewport_buffers[0];
75}
76
77void *vid_get_viewport_live_fb()
78{
79    if (MODE_IS_VIDEO(mode_get()))
80        return viewport_buffers[0];     // Video only seems to use the first viewport buffer.
81
82    // Hopefully return the most recently used viewport buffer so that motion detect, histogram, zebra and edge overly are using current image data
83    return viewport_buffers[(active_viewport_buffer-1)&3];
84}
85
86// Defined in stubs_min.S
87extern int active_bitmap_buffer;
88extern char* bitmap_buffer[];
89
90void *vid_get_bitmap_fb()
91{
92    // Return first bitmap buffer address
93    return bitmap_buffer[0];
94}
95
96// Y multiplier for cameras with 480 pixel high viewports (CHDK code assumes 240)
97int vid_get_viewport_yscale() {
98        return 2;               // G12 viewport is 480 pixels high
99}
100
101int vid_get_viewport_width()
102{
103    if ((mode_get() & MODE_MASK) == MODE_PLAY)
104    {
105        return 360;
106    }
107    extern int _GetVRAMHPixelsSize();
108    return _GetVRAMHPixelsSize() >> 1;
109}
110
111// viewport width offset table for each image size
112// 0 = 4:3, 1 = 16:9, 2 = 3:2, 3 = 1:1, 4 = 4:5
113static long vp_xo[5] = { 0, 0, 0, 44, 72 };                             // should all be even values for edge overlay
114
115int vid_get_viewport_xoffset()
116{
117    if ((mode_get() & MODE_MASK) == MODE_PLAY)
118    {
119        return 0;
120    }
121    else if (shooting_get_prop(PROPCASE_SHOOTING_MODE) == 16908) // Stitch mode
122    {
123        return 0;
124    }
125    else
126    {
127            return vp_xo[shooting_get_prop(PROPCASE_ASPECT_RATIO)];
128    }
129}
130
131int vid_get_viewport_display_xoffset()
132{
133    if ((mode_get() & MODE_MASK) == MODE_PLAY)
134    {
135        return 0;
136    }
137    else if (shooting_get_prop(PROPCASE_SHOOTING_MODE) == 16908) // Stitch mode
138    {
139        if (shooting_get_prop(PROPCASE_STITCH_DIRECTION) == 0)      // Direction check
140            if (shooting_get_prop(PROPCASE_STITCH_SEQUENCE) == 0)   // Shot already taken?
141                return 40;
142            else
143                return 140;
144        else
145            if (shooting_get_prop(PROPCASE_STITCH_SEQUENCE) == 0)   // Shot already taken?
146                return 140;
147            else
148                return 40;
149    }
150    else
151    {
152            return vp_xo[shooting_get_prop(PROPCASE_ASPECT_RATIO)];
153    }
154}
155
156long vid_get_viewport_height()
157{
158    if ((mode_get() & MODE_MASK) == MODE_PLAY)
159    {
160        return 240;
161    }
162    extern int _GetVRAMVPixelsSize();
163    return _GetVRAMVPixelsSize() >> 1;
164}
165
166static int vp_yoffset(int stitch)
167{
168    // viewport height offset table for each image size
169    // 0 = 4:3, 1 = 16:9, 2 = 3:2, 3 = 1:1, 4 = 4:5
170    static long vp_yo[5] = { 0, 30, 13, 0, 0 };
171
172    int m = mode_get();
173    if ((m & MODE_MASK) == MODE_PLAY)
174    {
175        return 0;
176    }
177    else if (shooting_get_prop(PROPCASE_SHOOTING_MODE) == 16908) // Stitch mode
178    {
179        return stitch;
180    }
181    else if (mode_is_video(m))
182    {
183        return 30;
184    }
185    else
186    {
187            return vp_yo[shooting_get_prop(PROPCASE_ASPECT_RATIO)];
188    }
189}
190
191int vid_get_viewport_yoffset()
192{
193    return vp_yoffset(0);
194}
195
196int vid_get_viewport_display_yoffset()
197{
198    return vp_yoffset(72);
199}
200
201// Functions for PTP Live View system
202int vid_get_viewport_display_xoffset_proper()   { return vid_get_viewport_display_xoffset() * 2; }
203int vid_get_viewport_display_yoffset_proper()   { return vid_get_viewport_display_yoffset() * 2; }
204int vid_get_viewport_width_proper()             { return vid_get_viewport_width() * 2; }
205int vid_get_viewport_height_proper()            { return vid_get_viewport_height() * 2; }
206int vid_get_viewport_fullscreen_height()        { return 480; }
207int vid_get_palette_type()                      { return 3; }
208int vid_get_palette_size()                      { return 256 * 4; }
209
210void *vid_get_bitmap_active_buffer()
211{
212    return bitmap_buffer[active_bitmap_buffer];
213}
214
215void *vid_get_bitmap_active_palette()
216{
217    extern int active_palette_buffer;
218    extern char* palette_buffer[];
219    return (palette_buffer[active_palette_buffer]+8);
220}
221
222// Function to load CHDK custom colors into active Canon palette
223void load_chdk_palette()
224{
225    extern int active_palette_buffer;
226    // Only load for the standard record and playback palettes
227    if ((active_palette_buffer == 0) || (active_palette_buffer == 4) || (active_palette_buffer == 6))
228    {
229        int *pal = (int*)vid_get_bitmap_active_palette();
230        if (pal[CHDK_COLOR_BASE+0] != 0x33ADF62)
231        {
232            pal[CHDK_COLOR_BASE+0]  = 0x33ADF62;  // Red
233            pal[CHDK_COLOR_BASE+1]  = 0x326EA40;  // Dark Red
234            pal[CHDK_COLOR_BASE+2]  = 0x34CD57F;  // Light Red
235            pal[CHDK_COLOR_BASE+3]  = 0x373BFAE;  // Green
236            pal[CHDK_COLOR_BASE+4]  = 0x34BD6CA;  // Dark Green
237            pal[CHDK_COLOR_BASE+5]  = 0x395AB95;  // Light Green
238            pal[CHDK_COLOR_BASE+6]  = 0x34766F0;  // Blue
239            pal[CHDK_COLOR_BASE+7]  = 0x31250F3;  // Dark Blue
240            pal[CHDK_COLOR_BASE+8]  = 0x37F408F;  // Cyan
241            pal[CHDK_COLOR_BASE+9]  = 0x3512D5B;  // Magenta
242            pal[CHDK_COLOR_BASE+10] = 0x3A9A917;  // Yellow
243            pal[CHDK_COLOR_BASE+11] = 0x3819137;  // Dark Yellow
244            pal[CHDK_COLOR_BASE+12] = 0x3DED115;  // Light Yellow
245
246            extern char palette_control;
247            palette_control = 1;
248            vid_bitmap_refresh();
249        }
250    }
251}
Note: See TracBrowser for help on using the repository browser.