From 69d0d92c7902aa27510ab52a533bf91c37363910 Mon Sep 17 00:00:00 2001 From: Selene ToyKeeper Date: Sun, 11 Nov 2018 16:01:12 -0700 Subject: Fixed the sleep tick counter wrapping around to 0 instead of 32768. --- spaghetti-monster/fsm-events.h | 15 +++++---------- spaghetti-monster/fsm-wdt.c | 4 +++- 2 files changed, 8 insertions(+), 11 deletions(-) (limited to 'spaghetti-monster') diff --git a/spaghetti-monster/fsm-events.h b/spaghetti-monster/fsm-events.h index 45c95ee..2fd47b6 100644 --- a/spaghetti-monster/fsm-events.h +++ b/spaghetti-monster/fsm-events.h @@ -34,11 +34,6 @@ typedef struct Emission { #define MISCHIEF_MANAGED EVENT_HANDLED #define MISCHIEF_NOT_MANAGED EVENT_NOT_HANDLED -#ifndef MAX_CLICKS -#define MAX_CLICKS 15 -#endif - -#define EV_MAX_LEN ((MAX_CLICKS*2)+3) Event current_event; // at 0.016 ms per tick, 255 ticks = 4.08 s static volatile uint16_t ticks_since_last_event = 0; @@ -59,7 +54,7 @@ static volatile uint16_t ticks_since_last_event = 0; * Bit 5: 1 for a "hold" event, 0 otherwise. * Bit 6: 1 for a "timeout" event, 0 otherwise. * If bit 7 is 0: - * Not yet defined. + * Sort of ad-hoc, shown in #defines below. */ // event masks / bits @@ -73,6 +68,9 @@ static volatile uint16_t ticks_since_last_event = 0; #define B_FLAGS 0b11110000 // Event types +#define EV_none 0 + +// Events which aren't button presses #define EV_debug (B_SYSTEM|0b01111111) #define EV_enter_state (B_SYSTEM|0b00001000) #define EV_leave_state (B_SYSTEM|0b00001001) @@ -89,7 +87,7 @@ static volatile uint16_t ticks_since_last_event = 0; #define EV_temperature_low (B_SYSTEM|0b00000110) #endif -#define EV_none 0 +// Button press events // shouldn't normally happen, but UI might reset event while button is down // so a release with no recorded prior hold could be possible @@ -202,9 +200,6 @@ static volatile uint16_t ticks_since_last_event = 0; #define EV_15clicks EV_click15_complete -#define events_match(a,b) (a == b) -// return 1 if (a == b), 0 otherwise -#define compare_event_sequences(a,b) (a == b) void empty_event_sequence(); uint8_t push_event(uint8_t ev_type); diff --git a/spaghetti-monster/fsm-wdt.c b/spaghetti-monster/fsm-wdt.c index 3606c67..d5bbdb9 100644 --- a/spaghetti-monster/fsm-wdt.c +++ b/spaghetti-monster/fsm-wdt.c @@ -64,7 +64,9 @@ ISR(WDT_vect) { // handle standby mode specially if (go_to_standby) { // emit a halfsleep tick, and process it - emit(EV_sleep_tick, sleep_counter++); + emit(EV_sleep_tick, sleep_counter); + // wrap around from 65535 to 32768, not 0 + sleep_counter = (sleep_counter + 1) | (sleep_counter & 0x8000); process_emissions(); return; } -- cgit v1.2.3