]> www.fi.muni.cz Git - bike-lights.git/commitdiff
Common patterns rewrite
authorJan "Yenya" Kasprzak <kas@fi.muni.cz>
Tue, 25 Jun 2013 21:41:04 +0000 (23:41 +0200)
committerJan "Yenya" Kasprzak <kas@fi.muni.cz>
Wed, 26 Jun 2013 20:03:33 +0000 (22:03 +0200)
slowN_pattern, normalN_pattern, and onN_pattern for N=(1..4)
rewritten to be brightness-independent, and to avoid switching
multiple outputs on at once, if possible.
If not (such as when PWMLED 2 is continuously on), use mode 2 and 3
with the same target current to accomodate for different battery voltages
when more than one output is running.

TODO: actually set brightness based on various conditions, such as
ambient lights, user-requested dim mode, etc.

firmware/buttons.c
firmware/control.c
firmware/lights.h

index ac41c06879b46a01c2cbae7ef19a321b271332a2..15c70e28f5b594eb983bc4fbc4b379b7f3aeac0a 100644 (file)
@@ -171,7 +171,7 @@ static void handle_button(unsigned char button, unsigned char cur,
                uint16_t duration = jiffies - button_start[button];
 
                if (duration >= LONG_PRESS_MIN) {
-                       set_status_led(button, on1_pattern);
+                       set_status_led(button, on_pattern);
                                // acknowledge long press
                }
        } else if (!cur && prev) {            // --- just released ---
index 1ac813a62a0f408ec8f9abfb70a783a0988da53e..efc61ad2498d4a240d31a64415b545a0946769b9 100644 (file)
@@ -29,96 +29,45 @@ static pattern_t panic_pattern[] = {
        PATTERN_END
 };
 
-pattern_t on1_pattern [] = {
-       { 1, D_8 },
-       PATTERN_END
-};
-
-static pattern_t on2_pattern [] = {
-       { 2, D_8 },
-       PATTERN_END
-};
-
-static pattern_t on3_pattern [] = {
-       { 3, D_8 },
-       PATTERN_END
-};
-
 static pattern_t brake_pattern [] = {
        { 4, D_2 },
        { 3, D_8 },
        PATTERN_END
 };
 
-static pattern_t normal2_pattern[] = {
-       { 2, D_1 },
-       { 0, D_1 },
-       { 2, D_1 },
-       { 0, D_8 },
-       { 1, D_1 },
-       { 0, D_1 },
-       { 1, D_1 },
-       { 0, D_8 },
-       PATTERN_END
-};
-
-static pattern_t normal3_pattern[] = {
-       { 3, D_1 },
-       { 0, D_1 },
-       { 3, D_1 },
-       { 0, D_8 },
-       { 1, D_1 },
-       { 0, D_1 },
-       { 1, D_1 },
-       { 0, D_8 },
-       PATTERN_END
-};
-
-static pattern_t normal4_pattern[] = {
-       { 4, D_1 },
-       { 0, D_1 },
-       { 4, D_1 },
-       { 0, D_8 },
-       { 1, D_1 },
-       { 0, D_1 },
-       { 1, D_1 },
-       { 0, D_8 },
-       PATTERN_END
-};
-
-static pattern_t slow1_pattern[] = {
-       { 1, D_1 },
-       { 0, D_13 },
+static pattern_t slow_pattern[] = {
+       { PWM_PAT(1, 0, 0), D_1 },
+       { PWM_PAT(0, 0, 1), D_1 },
+       { PWM_PAT(0, 0, 0), D_13 },
        PATTERN_END
 };
 
-static pattern_t slow2_pattern[] = {
-       { 2, D_1 },
-       { 0, D_13 },
+static pattern_t fast_pattern[] = {
+       { PWM_PAT(2, 0, 0), D_1 },
+       { PWM_PAT(0, 0, 2), D_1 },
+       { PWM_PAT(2, 0, 0), D_1 },
+       { PWM_PAT(0, 0, 2), D_1 },
+       { PWM_PAT(0, 0, 0), D_8 },
+       { PWM_PAT(1, 0, 0), D_1 },
+       { PWM_PAT(0, 0, 1), D_1 },
+       { PWM_PAT(1, 0, 0), D_1 },
+       { PWM_PAT(0, 0, 1), D_1 },
+       { PWM_PAT(0, 0, 0), D_8 },
        PATTERN_END
 };
 
-static pattern_t slow3_pattern[] = {
-       { 3, D_1 },
-       { 0, D_13 },
+static pattern_t night_pattern[] = {
+       { PWM_PAT(2, 0, 2), D_3 },
+       { PWM_PAT(3, 0, 0), D_8 },
+       { PWM_PAT(2, 0, 2), D_1 },
+       { PWM_PAT(3, 0, 0), D_2 },
+       { PWM_PAT(2, 0, 2), D_1 },
+       { PWM_PAT(3, 0, 0), D_8 },
        PATTERN_END
 };
 
-static pattern_t tmp1_pattern[] = {
-       { PWM_PAT(3, 0, 0), D_1 },
-       { PWM_PAT(0, 0, 1), D_1 },
-       { PWM_PAT(3, 0, 0), D_1 },
-       { PWM_PAT(0, 0, 1), D_1 },
-       { PWM_PAT(0, 0, 0), D_3 },
-       { PWM_PAT(0, 1, 0), D_1 },
-       { PWM_PAT(0, 0, 0), D_5 },
-       { PWM_PAT(1, 0, 0), D_1 },
-       { PWM_PAT(0, 0, 3), D_1 },
-       { PWM_PAT(1, 0, 0), D_1 },
-       { PWM_PAT(0, 0, 3), D_1 },
-       { PWM_PAT(0, 0, 0), D_5 },
-       { PWM_PAT(0, 1, 0), D_1 },
-       { PWM_PAT(0, 0, 0), D_3 },
+pattern_t on_pattern[] = {
+       { 1, D_8 },
        PATTERN_END
 };
 
@@ -161,10 +110,8 @@ void set_panic_mode()
 
 pattern_t *pwmled_pattern_select()
 {
-       return tmp1_pattern;
-
        if (battery_critical)
-               return on1_pattern;
+               return slow_pattern;
 
        if (towbar_mode)
                return NULL;
@@ -173,18 +120,19 @@ pattern_t *pwmled_pattern_select()
                return brake_pattern;
 
        switch (ambient_zone) {
-       case 0: return dim_mode ? NULL : number_pattern(2, 1);
-       case 1: return dim_mode ? slow1_pattern : normal2_pattern;
-       case 2: return dim_mode ? slow2_pattern : normal3_pattern;
+       case 0: return night_pattern;
+       case 1:
+       case 2:
        case 3:
-       default: return dim_mode ? slow3_pattern : normal4_pattern;
+       default:
+               return dim_mode ? slow_pattern : fast_pattern;
        }
 }
 
 pattern_t *status_led_pattern_select()
 {
        if (braking)
-               return on1_pattern;
+               return on_pattern;
 
        if (buttons_setup_in_progress())
                return buttons_setup_status0_pattern_select();
@@ -201,7 +149,7 @@ pattern_t *illumination_led_pattern_select()
        switch (ambient_zone) {
        case 0: return dim_mode
                ? number_pattern(1, 1)
-               : on1_pattern;
+               : on_pattern;
        case 1: return dim_mode
                ? number_pattern(2, 1)
                : number_pattern(3, 1);
index 25e2233141a152175b8038cde3f4e4879749b58d..26f7372988d00bff323654f41adea2459581b59f 100644 (file)
@@ -128,7 +128,7 @@ void init_battery();
 unsigned char battery_gauge();
 
 /* control.c */
-extern pattern_t on1_pattern[];
+extern pattern_t on_pattern[];
 
 void init_control();
 void brake_on();