7 unsigned char duration: 5;
10 static unsigned char led_counters[N_LEDS];
11 static pattern_t *led_patterns[N_LEDS];
13 #define PATTERN_END { 0, 0 }
14 pattern_t off_pattern[] = {
19 pattern_t blink_pattern[] = {
25 pattern_t mode1_pattern[] = {
34 pattern_t boot_pattern[] = {
54 pattern_t pattern_num[] = {
78 static unsigned char test_running;
84 for (i = 0; i < N_LEDS; i++) {
86 led_patterns[i] = off_pattern;
88 led_patterns[N_PWMLEDS] = boot_pattern;
89 led_counters[N_PWMLEDS] = boot_pattern->duration;
90 gpio_set(GPIO_LED2, 1);
94 static inline pattern_t *pattern_select(unsigned char n)
96 if (n < N_PWMLEDS && !pwmled_enabled(n))
97 return off_pattern; // Don't mess with non-enabled LEDs
107 return mode1_pattern;
110 return pattern_num + sizeof(pattern_num)/sizeof(pattern_t)
111 - 1 - 2*(1+ambient_zone);
114 static void led_set_mode(unsigned char n, unsigned char mode)
117 pwmled_set_mode(n, mode);
118 } else if (n == N_PWMLEDS) {
119 gpio_set(GPIO_LED2, mode);
124 static void inline led_set_level(unsigned char n, unsigned char level)
126 if (n == N_PWMLEDS) {
127 gpio_set(GPIO_LED2, 1);
131 void patterns_next_tick()
135 for (i = 0; i < N_LEDS; i++) {
136 if (led_counters[i] == 0) {
138 if (led_patterns[i]->duration == 0) { // END
139 led_patterns[i] = pattern_select(i);
141 led_counters[i] = led_patterns[i]->duration;
142 led_set_mode(i, led_patterns[i]->mode);