From dc721aac36c840574f51271d29260591676822b2 Mon Sep 17 00:00:00 2001 From: Clyne Sullivan Date: Thu, 18 Apr 2024 07:58:03 -0400 Subject: [PATCH] remove arduino build flags and update instructions --- noisemeter-device/BUILD.md | 50 ++++++++++--------------- noisemeter-device/Doxyfile | 2 +- noisemeter-device/board.h | 6 +-- noisemeter-device/config.h.example | 34 ----------------- noisemeter-device/noisemeter-device.ino | 9 ----- platformio.ini | 4 +- 6 files changed, 25 insertions(+), 80 deletions(-) delete mode 100644 noisemeter-device/config.h.example diff --git a/noisemeter-device/BUILD.md b/noisemeter-device/BUILD.md index 9341ea6..ea1e0e2 100644 --- a/noisemeter-device/BUILD.md +++ b/noisemeter-device/BUILD.md @@ -1,5 +1,11 @@ # Build Instructions +## Required Software + +Building the noisemeter device code requires PlatformIO: [PlatformIO Installation](https://docs.platformio.org/en/latest/core/installation/methods/index.html). + +Once installed, you should be able to execute a `pio` command from your terminal. + ## Source code preparation 1. Update SSL certificate using the following command: @@ -14,45 +20,29 @@ const char* API_TOKEN = "Your API token here"; ``` (Replace "Your API token here" with your API token) -3. Copy `config.h.example` to `config.h` and edit the file to select your board type and set your device ID. - ## Code compiling and upload -### PlatformIO - -1. [Install PlatformIO](https://platformio.org/install). - -2. Run `pio run` to compile for the PCB. A breadboard target is available too: `pio run -e esp32-breadboard`. - -3. Run `pio run -t upload` to upload to the device (this also compiles the code if there have been any changes). +From the `proj-noisemeter-device` directory, run `pio run` to compile the device's code. To compile for the "breadboard" prototype, run `pio run -e esp32-breadboard`. -### Arduino - -1. Install the Arduino IDE and [follow these instructions](https://docs.espressif.com/projects/arduino-esp32/en/latest/installing.html) to add support for ESP32 microcontrollers. - -2. Under "Tools" > "Board: " > "ESP32 Arduino", select either "ESP32C3 Dev Module" for the PCB boards or "ESP32-WROOM-DA Module" for the ESP32 breadboard prototype. - -3. Compile the sketch and upload it to the device. +To upload the code to a device (that is plugged into your computer), run `pio run -t upload`. This command will also compile the code if any changes have been made; to skip recompilation, run `pio run -t nobuild -t upload`. ## HMAC encryption key -Data stored on the device (e.g. WiFi credentials) are encrypted with an "eFuse" key. This key can only be written once, and is not be read or written after that. +User data stored on the device (e.g. WiFi credentials) is encrypted with a secure "eFuse" key. This key can only be programmed once, so the below steps only apply to factory-fresh devices. A device can still be used and tested without programming this key; the default key is simply all zeros. -Using PlatformIO: +1. Create a 32-byte file of random key data. This can be done either with a text editor (type in 32 random characters) or with a tool like `dd`: `dd if=/dev/urandom of=hmac_key bs=1 count=32`. -```bash -dd if=/dev/urandom of=hmac_key bs=1 count=32 -pio pkg exec -- espefuse.py --port /dev/ttyACM0 burn_key BLOCK4 hmac_key HMAC_UP -``` +2. Program the key to a connected device (changing port path "/dev/ttyACM0" or key filename "hmac\_key" if needed): `pio pkg exec -- espefuse.py --port /dev/ttyACM0 burn_key BLOCK4 hmac_key HMAC_UP`. # Operating Instructions: -- Power on the device by connecting it to power. The device should start in Hotspot mode. -- Connect to device's wifi hotspot, which will be called "Noise Meter". Password is "noisemeter". -- Open a web browser and navigate to IP address 4.3.2.1 and fill out your Wifi network SSID and password. This will then bbe saved to the onboard flash, and should persist between restarts. -- The device should reset and begin attempting to connect to wifi. Use Serial monitor to confirm this. -- Once connected, the device will sync itself with a NTP time server and then begin taking readings. -- The device fills a buffer with integer readings from the microphone until it has enough to -- Periodically (at a time interval determined by UPLOAD_INTERVAL_MS) the device will collate its data and upload it to the server, whereupon it will clear its cached data and begin taking readings again. -- To clear your saved information, hold the Reset button (Pin 5 in this example) while you power on the device, or hold the Reset button and reset the device using the built-in reset button. +1. Power on the device. The device should enter Hotspot mode, indicated by a flashing LED. +2. Connect to the device's WiFi hotspot, which will be called "Noise meter". Password is "noisemeter". +3. You should be automatically redirected to a setup form; if not, go to "http://8.8.4.4" in your web browser. +4. Enter your WiFi network's name (SSID) and password. +5. Once submitted, the device will restart and attempt to connect to your WiFi. If the LED turns off, the connection was successful. If the LED blinks, the connection failed and the hotspot is available for reconfiguration. +6. While running, the device will take decibel noise measurements based on short 128ms recordings. Every five minutes, statistics about the decibel measurments (minimum, maximum, and average values) will be sent to the server. +7. To factory reset the device, hold down the Reset button while you power on the device. Release the button once you see the blinking LED; this should only take a few seconds. + +For testing, the device's serial output can be viewed with a serial monitor while plugged into a computer. The output includes the device's ID, version number, error messages, and decibel readings. diff --git a/noisemeter-device/Doxyfile b/noisemeter-device/Doxyfile index c0f8f74..29d9bfc 100644 --- a/noisemeter-device/Doxyfile +++ b/noisemeter-device/Doxyfile @@ -1003,7 +1003,7 @@ RECURSIVE = YES # Note that relative paths are relative to the directory from which doxygen is # run. -EXCLUDE = doc certs.h secret.h config.h +EXCLUDE = doc certs.h secret.h # The EXCLUDE_SYMLINKS tag can be used to select whether or not files or # directories that are symbolic links (a Unix file system feature) are excluded diff --git a/noisemeter-device/board.h b/noisemeter-device/board.h index 66259fe..43abbe8 100644 --- a/noisemeter-device/board.h +++ b/noisemeter-device/board.h @@ -3,7 +3,7 @@ /// /// Each supported board must have a defined section here to specify the /// hardware pins and peripherals being used. Selecting a board for -/// compilation is done either through PlatformIO or config.h. +/// compilation is done through PlatformIO. /* noisemeter-device - Firmware for CivicTechTO's Noisemeter Device * Copyright (C) 2024 Clyne Sullivan, Nick Barnard * @@ -23,8 +23,6 @@ #ifndef BOARD_H #define BOARD_H -#include "config.h" - #undef SERIAL #if defined(BOARD_ESP32_PCB) @@ -52,10 +50,8 @@ /** Serial instance to use for logging output. */ #define SERIAL USBSerial -#if defined(BUILD_PLATFORMIO) #include extern HWCDC USBSerial; -#endif #elif defined(BOARD_ESP32_BREADBOARD) diff --git a/noisemeter-device/config.h.example b/noisemeter-device/config.h.example deleted file mode 100644 index 2ec53a8..0000000 --- a/noisemeter-device/config.h.example +++ /dev/null @@ -1,34 +0,0 @@ -/* noisemeter-device - Firmware for CivicTechTO's Noisemeter Device - * Copyright (C) 2024 Clyne Sullivan, Nick Barnard - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see . - */ -#ifndef CONFIG_H -#define CONFIG_H - -// Uncomment to print passkey over serial (for debugging). -//#define STORAGE_SHOW_PASSKEY - -// Define only *one* of the follwoing board options. -// If using PlatformIO, the selected 'env' will override this selection. -#if !defined(BOARD_ESP32_PCB) && \ - !defined(BOARD_ESP32_BREADBOARD) - -//#define BOARD_ESP32_PCB -//#define BOARD_ESP32_BREADBOARD - -#endif // BOARD_* - -#endif // CONFIG_H - diff --git a/noisemeter-device/noisemeter-device.ino b/noisemeter-device/noisemeter-device.ino index 66ae3f7..4f355ad 100644 --- a/noisemeter-device/noisemeter-device.ino +++ b/noisemeter-device/noisemeter-device.ino @@ -42,12 +42,7 @@ #include #include -#if defined(BUILD_PLATFORMIO) && defined(BOARD_ESP32_PCB) HWCDC USBSerial; -#endif - -// Uncomment these to disable WiFi and/or data upload -//#define UPLOAD_DISABLED /** Maximum number of milliseconds to wait for successful WiFi connection. */ constexpr auto WIFI_CONNECT_TIMEOUT_MS = 20 * 1000; @@ -359,11 +354,7 @@ int tryWifiConnection() String createJSONPayload(const DataPacket& dp) { -#ifdef BUILD_PLATFORMIO JsonDocument doc; -#else - DynamicJsonDocument doc (2048); -#endif doc["parent"] = "/Bases/nm1"; doc["data"]["type"] = "comand"; diff --git a/platformio.ini b/platformio.ini index d41ecbc..863b5b4 100644 --- a/platformio.ini +++ b/platformio.ini @@ -24,10 +24,12 @@ build_unflags = -std=gnu++11 build_flags = -std=gnu++17 - -DBUILD_PLATFORMIO -DNO_GLOBAL_EEPROM -DNOISEMETER_VERSION=\"0.0.4\" -Wall -Wextra +# Optional build flags: +# -DSTORAGE_SHOW_PASSKEY Print passkey over serial. +# -DUPLOAD_DISABLED Disable WiFi and data upload. [env:esp32-pcb] board = esp32-c3-devkitm-1