]> www.fi.muni.cz Git - bike-lights.git/blobdiff - firmware/lights.h
pwm.c: channels running - visible from the outside
[bike-lights.git] / firmware / lights.h
index 4a23436ea79dd84b8b21a055c70890cce5127fbe..72b719b321eaff5907a604ef2c0f2b7d528cf013 100644 (file)
@@ -1,6 +1,8 @@
 #ifndef LIGHTS_H__
 #define LIGHTS_H__ 1
 
+#define TESTING_FW 1
+
 #define N_LEDS 7
 #define N_PWMLEDS 3
 #define N_PWMLED_MODES 4
@@ -23,20 +25,27 @@ void inline log_word(uint16_t word) { }
 #endif
 
 /* adc.c */
+#define PWMLED_ADC_SHIFT 1 /* 1<<1 measurements per single callback */
 void init_adc();
 void susp_adc();
+void timer_start_slow_adcs();
 
 /* pwm.c */
-#define PWM_MAX 0x1E4 /* This should be different than ADC frequency 125 kHz */
-#define PWM_STEP_SHIFT 2 /* second parameter of pwm_set is shifted by
-                         * PWM_STEP_SHIFT bits to the right before setting
-                         * into HW */
-
+/*
+ * The real Timer/Counter 1 frequency should not be too close to the
+ * A/D converter frequency (125 kHz). Note that this is not the Top
+ * value of T/C 1, it is shifted by PWM_STEP_SHIFT as described in pwm.c
+ */
+#define PWM_MAX 0x780
+extern volatile unsigned char channels_running;
+#define PWM_IS_ON(n)   (channels_running & (1 << (n)))
+#define TIMER1_IS_ON() (channels_running)
 void init_pwm();
 void susp_pwm();
 void pwm_off(unsigned char n);
 void pwm_set(unsigned char n, uint16_t stride);
 void pwm_timer();
+void pwm_disable_if_not_needed();
 
 /* tmr.c */
 extern volatile uint16_t jiffies;
@@ -54,7 +63,10 @@ void susp_gpio();
 void gpio_set(unsigned char n, unsigned char on);
 
 /* ambient.c */
+#define AMBIENT_ADC_SHIFT 0    /* 1 measurement per callback */
 void init_ambient();
+void susp_ambient();
+void ambient_log_min_max();
 extern volatile unsigned char ambient_zone;
 void ambient_adc(uint16_t adc_val);
 
@@ -64,7 +76,6 @@ typedef struct {
        unsigned char duration: 5;
 } pattern_t;
 
-#define PATTERN_FOREVER 0x1F
 #define PATTERN_END { 0, 0 }
 void init_pattern();
 void patterns_next_tick();
@@ -77,6 +88,7 @@ void pattern_reload();
 void init_buttons();
 void susp_buttons();
 void timer_check_buttons();
+void button_adc(uint16_t adcval);
 unsigned char get_user_param(unsigned char param);
 unsigned char buttons_wait_for_release();
 unsigned char buttons_setup_in_progress();
@@ -84,14 +96,17 @@ pattern_t *buttons_setup_status0_pattern_select();
 pattern_t *buttons_setup_status1_pattern_select();
 
 /* battery.c */
-extern volatile unsigned char battery_100mv;
+extern volatile unsigned char battery_critical;
 void battery_adc();
 void init_battery();
+unsigned char battery_gauge();
 
 /* control.c */
 extern pattern_t on1_pattern[];
 
 void init_control();
+void brake_on();
+void brake_off();
 void toggle_dim_mode();
 void set_panic_mode();
 pattern_t *pwmled0_pattern_select();
@@ -99,6 +114,7 @@ pattern_t *pwmled1_pattern_select();
 pattern_t *pwmled2_pattern_select();
 pattern_t *status_led_pattern_select();
 pattern_t *illumination_led_pattern_select();
+pattern_t *laser_pattern_select();
 
 /* main.c */
 void power_down();