From c5521513771552297c789b4021f257fb449b93c2 Mon Sep 17 00:00:00 2001 From: Eiren Rain Date: Thu, 19 Dec 2024 19:35:31 +0100 Subject: [PATCH] Add compatibility with multi-sensor/glove/v0.6.0 firmware --- src/firmware/firmware-builder.service.ts | 28 ++++++++++++++++++++++++ src/firmware/firmwares.json | 3 +++ 2 files changed, 31 insertions(+) diff --git a/src/firmware/firmware-builder.service.ts b/src/firmware/firmware-builder.service.ts index 4b6c78d..6ff66f8 100644 --- a/src/firmware/firmware-builder.service.ts +++ b/src/firmware/firmware-builder.service.ts @@ -64,6 +64,21 @@ export class FirmwareBuilderService { }, ${imuConfig.optional}, ${imuConfig.intPin || 255})`; }; + /** + * Define of one sensor entry, computes the address + * For 0.6.0+ firmware versions + */ + const sensorDesc = (imuConfig: ImuConfig, index: number) => { + const imu = IMUS.find(({ type }) => type === imuConfig.type); + if (!imu) return null; + + return `SENSOR_DESC_ENTRY(${imuConfig.type}, ${ + imu.imuStartAddress + index * imu.addressIncrement + }, ${rotationToFirmware(imuConfig.rotation)}, DIRECT_WIRE(${imuConfig.sclPin}, ${ + imuConfig.sdaPin + }), ${imuConfig.optional}, DIRECT_PIN(${imuConfig.intPin || 255}))`; + }; + // this is to deal with old firmware versions where two imus where always declared // i just use the values of the first one if i only have one const secondImu = imusConfig.length === 1 ? imusConfig[0] : imusConfig[1]; @@ -76,6 +91,7 @@ export class FirmwareBuilderService { #define SECOND_IMU_ROTATION ${rotationToFirmware(secondImu.rotation)} #define MAX_IMU_COUNT ${imusConfig.length} + #define MAX_SENSORS_COUNT ${imusConfig.length} #ifndef IMU_DESC_LIST #define IMU_DESC_LIST \\ @@ -85,6 +101,18 @@ export class FirmwareBuilderService { .join(' \\\n\t\t ')} #endif + #ifndef SENSOR_DESC_LIST + #define SENSOR_DESC_LIST \\ + ${imusConfig + .map(sensorDesc) + .filter((imu) => !!imu) + .join(' \\\n\t\t ')} + #endif + + #infdef SENSOR_INFO_LIST + #define SENSOR_INFO_LIST + #endif + #define BATTERY_MONITOR ${boardConfig.batteryType} ${ boardConfig.batteryType === BatteryType.BAT_EXTERNAL && diff --git a/src/firmware/firmwares.json b/src/firmware/firmwares.json index 4aef3c0..8cf361d 100644 --- a/src/firmware/firmwares.json +++ b/src/firmware/firmwares.json @@ -25,5 +25,8 @@ }, "l0ud": { "SlimeVR-Tracker-ESP-BMI270": ["main"] + }, + "Multi-sensor/Glove": { + "SlimeVR-Tracker-ESP": ["glove"] } }