X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=firmware%2Flights.h;h=4a23436ea79dd84b8b21a055c70890cce5127fbe;hb=647f353f4d8c87c5cf18cae905e9d600cd0e6bcb;hp=eede4d140935182950d2de3e5ff60b7cf0dba224;hpb=63d8caf3a232630160a7af8c371b98351cd534bc;p=bike-lights.git diff --git a/firmware/lights.h b/firmware/lights.h index eede4d1..4a23436 100644 --- a/firmware/lights.h +++ b/firmware/lights.h @@ -9,14 +9,14 @@ /* logging.c */ #ifdef USE_LOGGING +void init_log(); void log_set_state(unsigned char val); -void log_init(); void log_flush(); void log_byte(unsigned char byte); void log_word(uint16_t word); #else +void inline init_log() { } void inline log_set_state(unsigned char val) { } -void inline log_init() { } void inline log_flush() { } void inline log_byte(unsigned char byte) { } void inline log_word(uint16_t word) { } @@ -25,15 +25,18 @@ void inline log_word(uint16_t word) { } /* adc.c */ void init_adc(); void susp_adc(); -void timer_start_adcs(); /* pwm.c */ -#define PWM_MAX 0x1FF +#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 */ void init_pwm(); void susp_pwm(); void pwm_off(unsigned char n); void pwm_set(unsigned char n, uint16_t stride); +void pwm_timer(); /* tmr.c */ extern volatile uint16_t jiffies; @@ -41,20 +44,17 @@ void init_tmr(); void susp_tmr(); /* pwmled.c */ -void pwmled_init(); +void init_pwmled(); void pwmled_adc(unsigned char n, uint16_t adcval); void pwmled_set_mode(unsigned char n, unsigned char mode); -unsigned char pwmled_needs_adc(unsigned char n); -unsigned char pwmled_enabled(unsigned char n); /* gpio.c */ -void gpio_init(); +void init_gpio(); void susp_gpio(); void gpio_set(unsigned char n, unsigned char on); -void gpio_before_poweroff(); /* ambient.c */ -void ambient_init(); +void init_ambient(); extern volatile unsigned char ambient_zone; void ambient_adc(uint16_t adc_val); @@ -66,26 +66,40 @@ typedef struct { #define PATTERN_FOREVER 0x1F #define PATTERN_END { 0, 0 } -extern pattern_t off_pattern[]; -extern pattern_t on_pattern[]; - -void pattern_init(); +void init_pattern(); void patterns_next_tick(); -void led_set_status(unsigned char status); void led_set_pattern(unsigned char led, pattern_t *pattern); -pattern_t *number_pattern(unsigned char num); +pattern_t *number_pattern(unsigned char num, unsigned char inv); +void pattern_reload(); /* buttons.c */ #define MAX_USER_PARAMS 3 void init_buttons(); +void susp_buttons(); void timer_check_buttons(); unsigned char get_user_param(unsigned char param); +unsigned char buttons_wait_for_release(); +unsigned char buttons_setup_in_progress(); +pattern_t *buttons_setup_status0_pattern_select(); +pattern_t *buttons_setup_status1_pattern_select(); /* battery.c */ extern volatile unsigned char battery_100mv; void battery_adc(); void init_battery(); +/* control.c */ +extern pattern_t on1_pattern[]; + +void init_control(); +void toggle_dim_mode(); +void set_panic_mode(); +pattern_t *pwmled0_pattern_select(); +pattern_t *pwmled1_pattern_select(); +pattern_t *pwmled2_pattern_select(); +pattern_t *status_led_pattern_select(); +pattern_t *illumination_led_pattern_select(); + /* main.c */ void power_down();