diff --git a/.trunk/trunk.yaml b/.trunk/trunk.yaml
index 91bdf11cb..162fdfd2d 100644
--- a/.trunk/trunk.yaml
+++ b/.trunk/trunk.yaml
@@ -4,11 +4,12 @@ cli:
plugins:
sources:
- id: trunk
- ref: v1.6.8
+ ref: v1.7.0
uri: https://github.com/trunk-io/plugins
lint:
enabled:
- - renovate@40.0.6
+ - checkov@3.2.435
+ - renovate@40.32.7
- prettier@3.5.3
- trufflehog@3.88.34
- yamllint@1.37.1
@@ -37,7 +38,7 @@ runtimes:
enabled:
- python@3.10.8
- go@1.21.0
- - node@18.20.5
+ - node@22.16.0
actions:
disabled:
- trunk-announce
diff --git a/boards/seeed_wio_tracker_L1.json b/boards/seeed_wio_tracker_L1.json
new file mode 100644
index 000000000..7c7bc62fa
--- /dev/null
+++ b/boards/seeed_wio_tracker_L1.json
@@ -0,0 +1,54 @@
+{
+ "build": {
+ "arduino": {
+ "ldscript": "nrf52840_s140_v7.ld"
+ },
+ "core": "nRF5",
+ "cpu": "cortex-m4",
+ "extra_flags": "-DARDUINO_MDBT50Q_RX -DNRF52840_XXAA",
+ "f_cpu": "64000000L",
+ "hwids": [["0x2886", "0x1668"]],
+ "usb_product": "TRACKER L1",
+ "mcu": "nrf52840",
+ "variant": "seeed_wio_tracker_L1",
+ "bsp": {
+ "name": "adafruit"
+ },
+ "softdevice": {
+ "sd_flags": "-DS140",
+ "sd_name": "s140",
+ "sd_version": "7.3.0",
+ "sd_fwid": "0x0123"
+ },
+ "bootloader": {
+ "settings_addr": "0xFF000"
+ }
+ },
+ "connectivity": ["bluetooth"],
+ "debug": {
+ "jlink_device": "nRF52840_xxAA",
+ "svd_path": "nrf52840.svd",
+ "openocd_target": "nrf52840-mdk-rs"
+ },
+ "frameworks": ["arduino"],
+ "name": "seeed_wio_tracker_L1",
+ "upload": {
+ "maximum_ram_size": 248832,
+ "maximum_size": 815104,
+ "speed": 115200,
+ "protocol": "nrfutil",
+ "protocols": [
+ "jlink",
+ "nrfjprog",
+ "nrfutil",
+ "stlink",
+ "cmsis-dap",
+ "blackmagic"
+ ],
+ "use_1200bps_touch": true,
+ "require_upload_port": true,
+ "wait_for_upload_port": true
+ },
+ "url": "https://www.seeedstudio.com/Wio-Tracker-L1-p-6477.html",
+ "vendor": "Seeed Studio"
+}
diff --git a/platformio.ini b/platformio.ini
index d7504e6c5..e5d36d862 100644
--- a/platformio.ini
+++ b/platformio.ini
@@ -108,7 +108,7 @@ lib_deps =
[device-ui_base]
lib_deps =
# renovate: datasource=git-refs depName=meshtastic/device-ui packageName=https://github.com/meshtastic/device-ui gitBranch=master
- https://github.com/meshtastic/device-ui/archive/e63b219e78e9655be10745b4037cefd2c608d258.zip
+ https://github.com/meshtastic/device-ui/archive/3dfcc973cdfec8b34719510952e160bbfb57d9df.zip
; Common libs for environmental measurements in telemetry module
[environmental_base]
diff --git a/protobufs b/protobufs
index 022ea79ba..24c7a3d28 160000
--- a/protobufs
+++ b/protobufs
@@ -1 +1 @@
-Subproject commit 022ea79bad79b70d0bee286cd9184916ab47c1b1
+Subproject commit 24c7a3d287a4bd269ce191827e5dabd8ce8f57a7
diff --git a/src/configuration.h b/src/configuration.h
index 0c23e677d..32d99295e 100644
--- a/src/configuration.h
+++ b/src/configuration.h
@@ -99,8 +99,12 @@ along with this program. If not, see .
// -----------------------------------------------------------------------------
// OLED & Input
// -----------------------------------------------------------------------------
-
+#if defined(SEEED_WIO_TRACKER_L1)
+#define SSD1306_ADDRESS 0x3D
+#define USE_SH1106
+#else
#define SSD1306_ADDRESS 0x3C
+#endif
#define ST7567_ADDRESS 0x3F
// The SH1106 controller is almost, but not quite, the same as SSD1306
diff --git a/src/graphics/niche/InkHUD/Applets/System/Logo/LogoApplet.cpp b/src/graphics/niche/InkHUD/Applets/System/Logo/LogoApplet.cpp
index 89bdb0bc7..fa85deab3 100644
--- a/src/graphics/niche/InkHUD/Applets/System/Logo/LogoApplet.cpp
+++ b/src/graphics/niche/InkHUD/Applets/System/Logo/LogoApplet.cpp
@@ -111,9 +111,10 @@ void InkHUD::LogoApplet::onShutdown()
// Prepare for the powered-off screen now
// We can change these values because the initial "shutting down" screen has already rendered at this point
+ meshtastic_NodeInfoLite *ourNode = nodeDB->getMeshNode(nodeDB->getNodeNum());
textLeft = "";
textRight = "";
- textTitle = owner.short_name;
+ textTitle = parseShortName(ourNode);
fontTitle = fontLarge;
// This is then drawn by InkHUD::Events::onShutdown, with a blocking FULL update, after InkHUD's flash write is complete
diff --git a/src/mesh/generated/meshtastic/mesh.pb.h b/src/mesh/generated/meshtastic/mesh.pb.h
index c1ec607d6..5fc1cc4f5 100644
--- a/src/mesh/generated/meshtastic/mesh.pb.h
+++ b/src/mesh/generated/meshtastic/mesh.pb.h
@@ -252,10 +252,10 @@ typedef enum _meshtastic_HardwareModel {
meshtastic_HardwareModel_LINK_32 = 98,
/* *
Seeed Tracker L1 */
- meshtastic_HardwareModel_SEEED_TRACKER_L1 = 99,
+ meshtastic_HardwareModel_SEEED_WIO_TRACKER_L1 = 99,
/* *
Seeed Tracker L1 EINK driver */
- meshtastic_HardwareModel_SEEED_TRACKER_L1_EINK = 100,
+ meshtastic_HardwareModel_SEEED_WIO_TRACKER_L1_EINK = 100,
/* Reserved ID for future and past use */
meshtastic_HardwareModel_QWANTZ_TINY_ARMS = 101,
/* ------------------------------------------------------------------------------------------------------------------------------------------
diff --git a/src/modules/NodeInfoModule.cpp b/src/modules/NodeInfoModule.cpp
index 5142f2db0..e072fcb0f 100644
--- a/src/modules/NodeInfoModule.cpp
+++ b/src/modules/NodeInfoModule.cpp
@@ -14,6 +14,9 @@ bool NodeInfoModule::handleReceivedProtobuf(const meshtastic_MeshPacket &mp, mes
{
auto p = *pptr;
+ // Coerce user.id to be derived from the node number
+ snprintf(p.id, sizeof(p.id), "!%08x", getFrom(&mp));
+
bool hasChanged = nodeDB->updateUser(getFrom(&mp), p, mp.channel);
bool wasBroadcast = isBroadcast(mp.to);
diff --git a/src/platform/esp32/architecture.h b/src/platform/esp32/architecture.h
index 68d06c6d7..3763bce1e 100644
--- a/src/platform/esp32/architecture.h
+++ b/src/platform/esp32/architecture.h
@@ -184,6 +184,8 @@
#define HW_VENDOR meshtastic_HardwareModel_HELTEC_SENSOR_HUB
#elif defined(ELECROW_PANEL)
#define HW_VENDOR meshtastic_HardwareModel_CROWPANEL
+#elif defined(LINK_32)
+#define HW_VENDOR meshtastic_HardwareModel_LINK_32
#endif
// -----------------------------------------------------------------------------
diff --git a/src/platform/nrf52/architecture.h b/src/platform/nrf52/architecture.h
index 9d1d48f1c..eea3aee45 100644
--- a/src/platform/nrf52/architecture.h
+++ b/src/platform/nrf52/architecture.h
@@ -85,6 +85,8 @@
#define HW_VENDOR meshtastic_HardwareModel_SEEED_SOLAR_NODE
#elif defined(HELTEC_MESH_POCKET)
#define HW_VENDOR meshtastic_HardwareModel_HELTEC_MESH_POCKET
+#elif defined(SEEED_WIO_TRACKER_L1)
+#define HW_VENDOR meshtastic_HardwareModel_SEEED_WIO_TRACKER_L1
#else
#define HW_VENDOR meshtastic_HardwareModel_NRF52_UNKNOWN
#endif
diff --git a/variants/link32_s3_v1/pins_arduino.h b/variants/link32_s3_v1/pins_arduino.h
new file mode 100644
index 000000000..010e5bf2e
--- /dev/null
+++ b/variants/link32_s3_v1/pins_arduino.h
@@ -0,0 +1,19 @@
+#ifndef Pins_Arduino_h
+#define Pins_Arduino_h
+
+#include
+
+#define USB_VID 0x303a
+#define USB_PID 0x1001
+
+// The default Wire will be mapped to PMU and RTC
+static const uint8_t SDA = 47;
+static const uint8_t SCL = 48;
+
+// Default SPI will be mapped to Radio
+static const uint8_t SS = 21;
+static const uint8_t MOSI = 34;
+static const uint8_t MISO = 33;
+static const uint8_t SCK = 16;
+
+#endif /* Pins_Arduino_h */
diff --git a/variants/link32_s3_v1/platformio.ini b/variants/link32_s3_v1/platformio.ini
new file mode 100644
index 000000000..5a614a7af
--- /dev/null
+++ b/variants/link32_s3_v1/platformio.ini
@@ -0,0 +1,11 @@
+[env:link32-s3-v1]
+extends = esp32s3_base
+board = esp32-s3-devkitc-1
+build_flags =
+ ${esp32_base.build_flags} -D LINK_32 -I variants/link32_s3_v1
+ -DGPS_POWER_TOGGLE ; comment this line to disable triple press function on the user button to turn off gps entirely.
+ -DARDUINO_USB_CDC_ON_BOOT
+ -DARDUINO_USB_MODE=1
+ -DRADIOLIB_EXCLUDE_SX128X=1
+ -DRADIOLIB_EXCLUDE_SX127X=1
+ -DRADIOLIB_EXCLUDE_LR11X0=1
diff --git a/variants/link32_s3_v1/variant.h b/variants/link32_s3_v1/variant.h
new file mode 100644
index 000000000..1f8a7435a
--- /dev/null
+++ b/variants/link32_s3_v1/variant.h
@@ -0,0 +1,42 @@
+#define BATTERY_PIN 15
+#define ADC_CHANNEL ADC2_GPIO15_CHANNEL // ADC channel for battery voltage measurement
+#define BATTERY_SENSE_SAMPLES 30
+#define BAT_MEASURE_ADC_UNIT 2 // Use ADC2 for battery measurement
+
+#define USE_SSD1306
+
+#define BUTTON_PIN 0 // Button pin for this board
+#define BUTTON_PIN_ALT 36
+
+#define HAS_NEOPIXEL // If defined, we will use the neopixel library
+#define NEOPIXEL_DATA 35 // Neopixel pin for this board
+#define NEOPIXEL_COUNT 1 // Number of neopixels on this board
+#define NEOPIXEL_TYPE (NEO_GRB + NEO_KHZ800) // type of neopixels in use
+
+#define ADC_MULTIPLIER 2
+
+#define I2C_SDA 47 // I2C pins for this board
+#define I2C_SCL 48
+
+#define USE_SX1262
+
+#define LORA_SCK 16
+#define LORA_MISO 33
+#define LORA_MOSI 34
+#define LORA_CS 21
+#define LORA_RESET 18
+
+#define LORA_DIO0 12 // a No connect on the SX1262 module
+#define LORA_DIO1 13
+#define LORA_DIO2 14 // Not really used
+
+#define LORA_TCXO_GPIO 17
+
+#define TCXO_OPTIONAL
+
+#define SX126X_CS LORA_CS
+#define SX126X_DIO1 LORA_DIO1
+#define SX126X_BUSY LORA_DIO2
+#define SX126X_RESET LORA_RESET
+#define SX126X_DIO2_AS_RF_SWITCH
+#define SX126X_DIO3_TCXO_VOLTAGE 1.8
diff --git a/variants/seeed_wio_tracker_L1/platformio.ini b/variants/seeed_wio_tracker_L1/platformio.ini
new file mode 100644
index 000000000..3c4653d7e
--- /dev/null
+++ b/variants/seeed_wio_tracker_L1/platformio.ini
@@ -0,0 +1,13 @@
+[env:seeed_wio_tracker_L1]
+board = seeed_wio_tracker_L1
+extends = nrf52840_base
+;board_level = extra
+build_flags = ${nrf52840_base.build_flags}
+ -I $PROJECT_DIR/variants/seeed_wio_tracker_L1
+ -D SEEED_WIO_TRACKER_L1
+ -Isrc/platform/nrf52/softdevice -Isrc/platform/nrf52/softdevice/nrf52
+board_build.ldscript = src/platform/nrf52/nrf52840_s140_v7.ld
+build_src_filter = ${nrf52_base.build_src_filter} +<../variants/seeed_wio_tracker_L1>
+lib_deps =
+ ${nrf52840_base.lib_deps}
+debug_tool = jlink
diff --git a/variants/seeed_wio_tracker_L1/variant.cpp b/variants/seeed_wio_tracker_L1/variant.cpp
new file mode 100644
index 000000000..6c34d63e6
--- /dev/null
+++ b/variants/seeed_wio_tracker_L1/variant.cpp
@@ -0,0 +1,96 @@
+/*
+ * variant.cpp - Digital pin mapping for TRACKER L1
+ *
+ * This file defines the pin mapping array that maps logical digital pins (D0-D17)
+ * to physical GPIO ports/pins on the Nordic nRF52 series microcontroller.
+ *
+ * Board: [Seeed Studio WIO TRACKER L1]
+ * Hardware Features:
+ * - LoRa module (CS/SCK/MISO/MOSI control pins)
+ * - GNSS module (TX/RX/Reset/Wakeup)
+ * - User LEDs (D11-D12)
+ * - User button (D13)
+ * - Grove/NFC interface (D14-D15)
+ * - Battery voltage monitoring (D16)
+ *
+ * Created [20250521]
+ * By [Dylan]
+ */
+
+#include "variant.h"
+#include "nrf.h"
+#include "wiring_constants.h"
+#include "wiring_digital.h"
+
+/**
+ * @brief Digital pin to GPIO port/pin mapping table
+ *
+ * Format: Logical Pin (Dx) -> nRF Port.Pin (Px.xx)
+ *
+ */
+
+extern "C" {
+const uint32_t g_ADigitalPinMap[] = {
+ // D0 .. D10 - Peripheral control pins
+ 41, // D0 P1.09 GNSS_WAKEUP
+ 7, // D1 P0.07 LORA_DIO1
+ 39, // D2 P1,07 LORA_RESET
+ 42, // D3 P1.10 LORA_BUSY
+ 46, // D4 P1.14 (A4/SDA) LORA_CS
+ 40, // D5 P1.08 (A5/SCL) LORA_SW
+ 27, // D6 P0.27 (UART_TX) GNSS_TX
+ 26, // D7 P0.26 (UART_RX) GNSS_RX
+ 30, // D8 P0.30 (SPI_SCK) LORA_SCK
+ 3, // D9 P0.3 (SPI_MISO) LORA_MISO
+ 28, // D10 P0.28 (SPI_MOSI) LORA_MOSI
+
+ // D11-D12 - LED outputs
+ 33, // D11 P1.1 User LED
+ // Buzzzer
+ 32, // D12 P1.0 Buzzer
+
+ // D13 - User input
+ 8, // D13 P0.08 User Button
+
+ // D14-D15 - Grove interface
+ 6, // D14 P0.06 OLED SDA
+ 5, // D15 P0.05 OLED SCL
+
+ // D16 - Battery voltage ADC input
+ 31, // D16 P0.31 VBAT_ADC
+ // GROVE
+ 0, // D17 P0.00 GROVESDA
+ 1, // D18 P0.01 GROVESCL
+
+ // FLASH
+ 21, // D19 P0.21 (QSPI_SCK)
+ 25, // D20 P0.25 (QSPI_CSN)
+ 20, // D21 P0.20 (QSPI_SIO_0 DI)
+ 24, // D22 P0.24 (QSPI_SIO_1 DO)
+ 22, // D23 P0.22 (QSPI_SIO_2 WP)
+ 23, // D24 P0.23 (QSPI_SIO_3 HOLD)
+
+ 36, // D25 TB_UP
+ 12, // D26 TB_DOWN
+ 11, // D27 TB_LEFT
+ 35, // D28 TB_RIGHT
+ 37, // D29 TB_PRESS
+ 4, // D30 BAT_CTL
+};
+}
+
+void initVariant()
+{
+ pinMode(PIN_QSPI_CS, OUTPUT);
+ digitalWrite(PIN_QSPI_CS, HIGH);
+ // This setup is crucial for ensuring low power consumption and proper initialization of the hardware components.
+ // VBAT_ENABLE
+ pinMode(BAT_READ, OUTPUT);
+ digitalWrite(BAT_READ, HIGH);
+
+ pinMode(PIN_LED1, OUTPUT);
+ digitalWrite(PIN_LED1, LOW);
+ pinMode(PIN_LED2, OUTPUT);
+ digitalWrite(PIN_LED2, LOW);
+ pinMode(PIN_LED2, OUTPUT);
+}
\ No newline at end of file
diff --git a/variants/seeed_wio_tracker_L1/variant.h b/variants/seeed_wio_tracker_L1/variant.h
new file mode 100644
index 000000000..b257fd9b6
--- /dev/null
+++ b/variants/seeed_wio_tracker_L1/variant.h
@@ -0,0 +1,184 @@
+#ifndef _SEEED_TRACKER_L1_H_
+#define _SEEED_TRACKER_L1_H_
+#include "WVariant.h"
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Clock Configuration
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+#define VARIANT_MCK (64000000ul) // Master clock frequency
+#define USE_LFXO // 32.768kHz crystal for LFCLK
+
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Pin Capacity Definitions
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+#define PINS_COUNT (33u) // Total GPIO pins
+#define NUM_DIGITAL_PINS (33u) // Digital I/O pins
+#define NUM_ANALOG_INPUTS (8u) // Analog inputs (A0-A5 + VBAT + AREF)
+#define NUM_ANALOG_OUTPUTS (0u)
+
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// LED Configuration
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// LEDs
+// LEDs
+#define PIN_LED1 (11) // LED P1.15
+#define PIN_LED2 (12) //
+
+#define LED_BUILTIN PIN_LED1
+#define LED_CONN PIN_LED2
+
+#define LED_GREEN PIN_LED1
+#define LED_BLUE PIN_LED2
+// #define LED_PIN PIN_LED2
+#define LED_STATE_ON 1 // State when LED is litted
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Button Configuration
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+#define BUTTON_PIN D13 // This is the Program Button
+// #define BUTTON_NEED_PULLUP 1
+#define BUTTON_ACTIVE_LOW true
+#define BUTTON_ACTIVE_PULLUP false
+
+#define BUTTON_PIN_TOUCH 13 // Touch button
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Digital Pin Mapping (D0-D10)
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+#define D0 0 // P1.06 GNSS_WAKEUP/IO0
+#define D1 1 // P0.07 LORA_DIO1
+#define D2 2 // P1.07 LORA_RESET
+#define D3 3 // P1.10 LORA_BUSY
+#define D4 4 // P1.14 LORA_CS
+#define D5 5 // P1.08 LORA_SW
+#define D6 6 // P0.27 GNSS_TX
+#define D7 7 // P0.26 GNSS_RX
+#define D8 8 // P0.30 SPI_SCK
+#define D9 9 // P0.03 SPI_MISO
+#define D10 10 // P0.28 SPI_MOSI
+#define D12 12 // P1.00 Buzzer
+#define D13 13 // P0.08 User Button
+#define D14 14 // P0.05 OLED SCL
+#define D15 15 // P0.06 OLED SDA
+#define D16 16 // P0.31 VBAT_ADC
+#define D17 17 // P0.00 GROVE SDA
+#define D18 18 // P0.01 GROVE_SCL
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Analog Pin Definitions
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+#define PIN_A0 0 // P0.02 Analog Input 0
+#define PIN_A1 1 // P0.03 Analog Input 1
+#define PIN_A2 2 // P0.28 Analog Input 2
+#define PIN_A3 3 // P0.29 Analog Input 3
+#define PIN_A4 4 // P0.04 Analog Input 4
+#define PIN_A5 5 // P0.05 Analog Input 5
+#define PIN_VBAT D16 // P0.31 Battery voltage sense
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Communication Interfaces
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// I2C Configuration
+#define HAS_WIRE 1
+#define PIN_WIRE_SDA D14 // P0.09
+#define PIN_WIRE_SCL D15 // P0.10
+#define WIRE_INTERFACES_COUNT 1
+#define I2C_NO_RESCAN
+
+static const uint8_t SDA = PIN_WIRE_SDA;
+static const uint8_t SCL = PIN_WIRE_SCL;
+
+#define HAS_SCREEN 1
+#define USE_SSD1306 1
+
+// SPI Configuration (SX1262)
+
+#define SPI_INTERFACES_COUNT 1
+#define PIN_SPI_MISO 9 // P0.03 (D9)
+#define PIN_SPI_MOSI 10 // P0.28 (D10)
+#define PIN_SPI_SCK 8 // P0.30 (D8)
+
+// SX1262 LoRa Module Pins
+#define USE_SX1262
+#define SX126X_CS D4 // Chip select
+#define SX126X_DIO1 D1 // Digital IO 1 (Interrupt)
+#define SX126X_BUSY D3 // Busy status
+#define SX126X_RESET D2 // Reset control
+#define SX126X_DIO3_TCXO_VOLTAGE 1.8 // TCXO supply voltage
+#define SX126X_RXEN D5 // RX enable control
+#define SX126X_TXEN RADIOLIB_NC
+#define SX126X_DIO2_AS_RF_SWITCH // This Line is really necessary for SX1262 to work with RF switch or will loss TX power
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Power Management
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+
+#define BAT_READ 30 // D30 = P0.04 Reads battery voltage from divider on signal board.
+#define BATTERY_SENSE_RESOLUTION_BITS 12
+#define ADC_MULTIPLIER 2.0
+#define BATTERY_PIN PIN_VBAT // PIN_A7
+#define AREF_VOLTAGE 3.6
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// GPS L76KB
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+#define GPS_L76K
+#ifdef GPS_L76K
+#define PIN_GPS_RX D6 // P0.26
+#define PIN_GPS_TX D7
+#define HAS_GPS 1
+#define GPS_BAUDRATE 9600
+#define GPS_THREAD_INTERVAL 50
+#define PIN_SERIAL1_RX PIN_GPS_TX
+#define PIN_SERIAL1_TX PIN_GPS_RX
+
+#define GPS_RX_PIN PIN_GPS_TX
+#define GPS_TX_PIN PIN_GPS_RX
+#define PIN_GPS_STANDBY D0
+
+// #define GPS_DEBUG
+// #define GPS_EN D18 // P1.05
+#endif
+
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// On-board QSPI Flash
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// On-board QSPI Flash
+#define PIN_QSPI_SCK (21)
+#define PIN_QSPI_CS (22)
+#define PIN_QSPI_IO0 (23)
+#define PIN_QSPI_IO1 (24)
+#define PIN_QSPI_IO2 (25)
+#define PIN_QSPI_IO3 (26)
+
+#define EXTERNAL_FLASH_DEVICES P25Q16H
+#define EXTERNAL_FLASH_USE_QSPI
+
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Buzzer
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Buzzer
+
+#define PIN_BUZZER D12 // P1.00, pwm output
+
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// joystick
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+
+#define CANNED_MESSAGE_MODULE_ENABLE 1
+
+// trackball
+#define HAS_TRACKBALL 1
+#define TB_UP 25
+#define TB_DOWN 26
+#define TB_LEFT 27
+#define TB_RIGHT 28
+#define TB_PRESS 29
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+// Compatibility Definitions
+// ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
+#ifdef __cplusplus
+extern "C" {
+#endif
+// Serial port placeholders
+
+#define PIN_SERIAL2_RX (-1)
+#define PIN_SERIAL2_TX (-1)
+#ifdef __cplusplus
+}
+#endif
+
+#endif // _SEEED_SOLAR_NODE_H_
\ No newline at end of file