From 93d85322d55700e12be978b2164e6b0a3d5bdda3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?King=20K=C3=A9vin?= Date: Thu, 28 Jan 2021 11:13:34 +0100 Subject: [PATCH] application: add gm1351 decoding --- application.c | 22 ++++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/application.c b/application.c index c25e74d..d081232 100644 --- a/application.c +++ b/application.c @@ -477,16 +477,18 @@ void main(void) if (sensor_gm1351_received_flag) { // meter data has been received action = true; // action has been performed sensor_gm1351_received_flag = false; // reset flag - led_toggle(); // notify user about activity - gm1351_last = rtc_get_counter_val(); // remember we got a value - char measurement[10 + 1]; // to store the string with the measurement value - snprintf(measurement, LENGTH(measurement), "%u.%u dBa\n", sensor_gm1351_decidba / 10, sensor_gm1351_decidba % 10); // generate string - if (gm1351_show) { - puts(measurement); // display measurement to user - } - // sen measurement to Bluetooth module - for (uint8_t i = 0; i < LENGTH(measurement) && measurement[i] != '\0'; i++) { - spp_tx_putchar_nonblocking( measurement[i]); + if (sensor_gm1351_decode()) { // decode received value + led_toggle(); // notify user about activity + gm1351_last = rtc_get_counter_val(); // remember we got a value + char measurement[10 + 1]; // to store the string with the measurement value + snprintf(measurement, LENGTH(measurement), "%u.%u dBa\n", sensor_gm1351_decidba / 10, sensor_gm1351_decidba % 10); // generate string + if (gm1351_show) { + puts(measurement); // display measurement to user + } + // sen measurement to Bluetooth module + for (uint8_t i = 0; i < LENGTH(measurement) && measurement[i] != '\0'; i++) { + spp_tx_putchar_nonblocking( measurement[i]); + } } } if (action) { // go to sleep if nothing had to be done, else recheck for activity