From 3b987c5b53dd6113f2194541f5184264f447c9e4 Mon Sep 17 00:00:00 2001 From: Gergely Nagy Date: Sun, 26 Nov 2017 19:39:31 +0100 Subject: [PATCH 1/2] explanatory comments Based on #1 by @mattvenn. Signed-off-by: Gergely Nagy --- firmware/debounce.h | 35 +++++++++++++++++++++++++++++++---- 1 file changed, 31 insertions(+), 4 deletions(-) diff --git a/firmware/debounce.h b/firmware/debounce.h index 8231fa8..a9488ef 100644 --- a/firmware/debounce.h +++ b/firmware/debounce.h @@ -2,6 +2,12 @@ #include +/* +each of these 8 bit variables are storing the state for 8 keys + +so for key 0, the counter is represented by db0[0] and db1[0] +and the state in state[0]. +*/ typedef struct { uint8_t db0; // counter bit 0 uint8_t db1; // counter bit 1 @@ -15,24 +21,45 @@ typedef struct { * will increment that bit's counter. When it overflows, the change is * comitted to the final debounced state and the changed bit returned. * + * Because each key's counter and state are stored in this stacked way, + * 8 keys are processed in parallel at each operation. + * * args: * sample - the current state * debouncer - the state variables of the debouncer * * returns: bits that have changed in the final debounced state + * + * handy XOR truth table: A B O + * 0 0 0 + * 0 1 1 + * 1 0 1 + * 1 1 0 + * + * This is used below as a difference detector: + * if A ^ B is true, A and B are different. + * + * And a way to flip selected bits in a variable or register: + * Set B to 1, then A ^ B = !A */ static inline uint8_t debounce(uint8_t sample, debounce_t *debouncer) { uint8_t delta, changes; - // Set delta to changes from last stable state + // Use xor to detect changes from last stable state: + // if a key has changed, it's bit will be 1, otherwise 0 delta = sample ^ debouncer->state; - // Increment counters and reset any unchanged bits + // Increment counters and reset any unchanged bits: + // increment bit 1 for all changed keys debouncer->db1 = ((debouncer->db1) ^ (debouncer->db0)) & delta; - debouncer->db0 = ~(debouncer->db0) & delta; + // increment bit 0 for all changed keys + debouncer->db0 = ~(debouncer->db0) & delta; + + // Calculate returned change set: if delta is still true + // and the counter has wrapped back to 0, the key is changed. - // update state & calculate returned change set changes = ~(~delta | (debouncer->db0) | (debouncer->db1)); + // Update state: in this case use xor to flip any bit that is true in changes. debouncer->state ^= changes; return changes; From da7fd39906c63f84b679e1abcbbfbf43fc340275 Mon Sep 17 00:00:00 2001 From: Gergely Nagy Date: Sun, 26 Nov 2017 19:44:21 +0100 Subject: [PATCH 2/2] Refactor the debounce change calculation Based on #1 by @mattven. Signed-off-by: Gergely Nagy --- firmware/debounce.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/firmware/debounce.h b/firmware/debounce.h index a9488ef..13d11dc 100644 --- a/firmware/debounce.h +++ b/firmware/debounce.h @@ -57,8 +57,8 @@ static inline uint8_t debounce(uint8_t sample, debounce_t *debouncer) { // Calculate returned change set: if delta is still true // and the counter has wrapped back to 0, the key is changed. + changes = delta & ~debouncer->db0 & ~debouncer->db1; - changes = ~(~delta | (debouncer->db0) | (debouncer->db1)); // Update state: in this case use xor to flip any bit that is true in changes. debouncer->state ^= changes;