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 34 der Datei lib.c.

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

Definiert in Zeile 23 der Datei lib.c.

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

Definiert in Zeile 7 der Datei lib.c.

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

Definiert in Zeile 69 der Datei lib.c.

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

Definiert in Zeile 130 der Datei lib.c.

131 { //found @loc_ff90ad5c a4000.100c ->Called before *"..<GetBmpVramInfo> Add
132  return (void*)(*(int*)(0x5470+0x18));
133 }
void* vid_get_bitmap_active_palette ( )

Definiert in Zeile 80 der Datei lib.c.

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

Definiert in Zeile 128 der Datei lib.c.

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

Definiert in Zeile 127 der Datei lib.c.

127 { return 3; }
void* vid_get_viewport_fb ( )

Definiert in Zeile 53 der Datei lib.c.

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

Definiert in Zeile 44 der Datei lib.c.

45 {
46  return 240;
47 }
void* vid_get_viewport_live_fb ( )

Definiert in Zeile 59 der Datei lib.c.

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

Definiert in Zeile 39 der Datei lib.c.

40 {
41  return 360;
42 }

Variablen-Dokumentation

char active_viewport_buffer
void* viewport_buffers[]