CHDK_DE Vorschauversion  Trunk Rev. 6014
 Alle Datenstrukturen Dateien Funktionen Variablen Typdefinitionen Aufzählungen Aufzählungswerte Makrodefinitionen
lib.c-Dateireferenz
#include "platform.h"
#include "platform_palette.h"
#include "lolevel.h"
+ Include-Abhängigkeitsdiagramm für lib.c:

gehe zum Quellcode dieser Datei

Makrodefinitionen

#define LED_PR   0xC0220120
 

Funktionen

void shutdown ()
 
void debug_led (int state)
 
void camera_set_led (int led, int state, __attribute__((unused)) int bright)
 
int get_flash_params_count (void)
 
int vid_get_viewport_width ()
 
long vid_get_viewport_height ()
 
void * vid_get_viewport_fb ()
 
void * vid_get_viewport_live_fb ()
 
void vid_bitmap_refresh ()
 
void * vid_get_bitmap_active_palette ()
 
int vid_get_palette_type ()
 
int vid_get_palette_size ()
 
void * vid_get_bitmap_active_buffer ()
 

Variablen

char active_viewport_buffer
 
void * viewport_buffers []
 

Makro-Dokumentation

#define LED_PR   0xC0220120

Definiert in Zeile 5 der Datei lib.c.

Dokumentation der Funktionen

void camera_set_led ( int  led,
int  state,
__attribute__((unused)) int  bright 
)

Definiert in Zeile 36 der Datei lib.c.

36  {
37  static char led_table[2]={0,4};
38  if(state<=1) _LEDDrive(led_table[led%sizeof(led_table)], (!state)&1);
39 }
void debug_led ( int  state)

Definiert in Zeile 24 der Datei lib.c.

25 {
26  // using power LED, which defaults to on
27  // for debugging turn LED off if state is 1 and on for state = 0
28  // leaves LED on at end of debugging
29  *(int*)LED_PR=state ? 0x46 : 0x44;
30 }
int get_flash_params_count ( void  )

Definiert in Zeile 41 der Datei lib.c.

41 { return 0xa6; }
void shutdown ( )

Definiert in Zeile 8 der Datei lib.c.

9 {
10  volatile long *p = (void*)LED_PR;
11 
12  asm(
13  "MRS R1, CPSR\n"
14  "AND R0, R1, #0x80\n"
15  "ORR R1, R1, #0x80\n"
16  "MSR CPSR_cf, R1\n"
17  :::"r1","r0");
18 
19  *p = 0x44; // power off.
20 
21  while(1);
22 }
void vid_bitmap_refresh ( )

Definiert in Zeile 74 der Datei lib.c.

75 {
76  extern int full_screen_refresh;
77  extern void _ScreenLock();
78  extern void _ScreenUnlock();
79 
80  full_screen_refresh |= 3;
81  _ScreenLock();
82  _ScreenUnlock();
83 }
void* vid_get_bitmap_active_buffer ( )

Definiert in Zeile 132 der Datei lib.c.

133 {
134  return (void*)(*(int*)(0x546C+0x18)); //Found @ loc_FF90B408 a2400 100e
135 }
void* vid_get_bitmap_active_palette ( )

Definiert in Zeile 85 der Datei lib.c.

85  {
86  extern int active_palette_buffer;
87  extern char* palette_buffer[];
88  void* p = palette_buffer[active_palette_buffer];
89  // Don't add offset if value is 0
90  if (p) p += 4;
91  return p;
92 }
int vid_get_palette_size ( )

Definiert in Zeile 130 der Datei lib.c.

130 { return 256 * 4; }
int vid_get_palette_type ( )

Definiert in Zeile 129 der Datei lib.c.

129 { return 3; }
void* vid_get_viewport_fb ( )

Definiert in Zeile 58 der Datei lib.c.

59 {
60  // Return first viewport buffer - for case when vid_get_viewport_live_fb not defined
61  return viewport_buffers[0];
62 }
long vid_get_viewport_height ( )

Definiert in Zeile 48 der Datei lib.c.

49 {
50  return 240;
51 }
void* vid_get_viewport_live_fb ( )

Definiert in Zeile 64 der Datei lib.c.

65 {
66  if (MODE_IS_VIDEO(mode_get()))
67  return viewport_buffers[0]; // Video only seems to use the first viewport buffer.
68 
69  // Hopefully return the most recently used viewport buffer so that motion detect, histogram, zebra and edge overly are using current image data
71 }
int vid_get_viewport_width ( )

Definiert in Zeile 43 der Datei lib.c.

44 {
45  return 360;
46 }

Variablen-Dokumentation

char active_viewport_buffer
void* viewport_buffers[]