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 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  _LEDDrive(led_table[led%sizeof(led_table)], state<=1 ? !state : state);
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 }
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 70 der Datei lib.c.

71 {
72  extern int full_screen_refresh;
73  extern void _ScreenLock();
74  extern void _ScreenUnlock();
75 
76  full_screen_refresh |= 3;
77  _ScreenLock();
78  _ScreenUnlock();
79 }
void* vid_get_bitmap_active_buffer ( )

Definiert in Zeile 128 der Datei lib.c.

129 {
130  return (void*)(*(int*)(0x542C+0x18)); //found @ loc_ff90a118 a2300 b101
131 }
void* vid_get_bitmap_active_palette ( )

Definiert in Zeile 81 der Datei lib.c.

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

Definiert in Zeile 126 der Datei lib.c.

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

Definiert in Zeile 125 der Datei lib.c.

125 { return 3; }
void* vid_get_viewport_fb ( )

Definiert in Zeile 55 der Datei lib.c.

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

Definiert in Zeile 46 der Datei lib.c.

47 {
48  return 240;
49 }
void* vid_get_viewport_live_fb ( )

Definiert in Zeile 61 der Datei lib.c.

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

Definiert in Zeile 41 der Datei lib.c.

42 {
43  return 360;
44 }

Variablen-Dokumentation

char active_viewport_buffer
void* viewport_buffers[]