source: branches/reyalp-ptp-live/platform/g1x/lib.c @ 1911

Revision 1911, 7.4 KB checked in by reyalp, 12 months ago (diff)

update live view branch to trunk 1910

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