diff --git a/firmware/controllers/bench_test.cpp b/firmware/controllers/bench_test.cpp index 4fb29c9c78..28712d4886 100644 --- a/firmware/controllers/bench_test.cpp +++ b/firmware/controllers/bench_test.cpp @@ -435,6 +435,11 @@ void executeTSCommand(uint16_t subsystem, uint16_t index) { case CMD_TS_X14: handleCommandX14(index); break; +#ifdef EFI_WIDEBAND_FIRMWARE_UPDATE + case 0x15: + setWidebandOffset(logger, index); + break; +#endif // EFI_WIDEBAND_FIRMWARE_UPDATE case CMD_TS_BENCH_CATEGORY: handleBenchCategory(index); break; @@ -498,7 +503,11 @@ void initBenchTest(Logging *sharedLogger) { addConsoleAction("fanbench", fanBench); addConsoleAction("mainrelaybench", mainRelayBench); addConsoleActionS("fanbench2", fanBenchExt); + +#if EFI_WIDEBAND_FIRMWARE_UPDATE addConsoleAction("update_wideband", []() { widebandUpdatePending = true; }); + addConsoleActionI("set_wideband_index", [](int index) { setWidebandOffset(logger, index); }); +#endif // EFI_WIDEBAND_FIRMWARE_UPDATE addConsoleAction(CMD_STARTER_BENCH, starterRelayBench); addConsoleAction(CMD_MIL_BENCH, milBench); diff --git a/firmware/controllers/can/can.h b/firmware/controllers/can/can.h index d8b37a918a..e942468e82 100644 --- a/firmware/controllers/can/can.h +++ b/firmware/controllers/can/can.h @@ -29,6 +29,8 @@ void registerCanSensor(CanSensorBase& sensor); void handleWidebandBootloaderAck(); // Update the firmware on any connected wideband controller void updateWidebandFirmware(Logging*); +// Set the CAN index offset of any attached wideband controller +void setWidebandOffset(Logging* logging, uint8_t index); class CanWrite final : public PeriodicController<512> { public: diff --git a/firmware/controllers/can/wideband_bootloader.cpp b/firmware/controllers/can/wideband_bootloader.cpp index 26a48c15c1..761630d63f 100644 --- a/firmware/controllers/can/wideband_bootloader.cpp +++ b/firmware/controllers/can/wideband_bootloader.cpp @@ -95,4 +95,28 @@ void updateWidebandFirmware(Logging* logging) { waitingBootloaderThread = nullptr; } +void setWidebandOffset(Logging* logging, uint8_t index) { + // Clear any pending acks for this thread + chEvtGetAndClearEvents(EVT_BOOTLOADER_ACK); + + // Send messages to the current thread when acks come in + waitingBootloaderThread = chThdGetSelfX(); + + scheduleMsg(logging, "***************************************"); + scheduleMsg(logging, " WIDEBAND INDEX SET"); + scheduleMsg(logging, "***************************************"); + scheduleMsg(logging, "Setting all connected widebands to index %d...", index); + + { + CanTxMessage m(0xEF4'0000, 1, true); + m[0] = index; + } + + if (!waitAck()) { + firmwareError(OBD_PCM_Processor_Fault, "Wideband index set failed: no controller detected!"); + } + + waitingBootloaderThread = nullptr; +} + #endif // EFI_WIDEBAND_FIRMWARE_UPDATE && HAL_USE_CAN diff --git a/firmware/controllers/can/wideband_firmware b/firmware/controllers/can/wideband_firmware index ab8c24564f..374b9aaf11 160000 --- a/firmware/controllers/can/wideband_firmware +++ b/firmware/controllers/can/wideband_firmware @@ -1 +1 @@ -Subproject commit ab8c24564f40162b08599831b03eec3568a9c953 +Subproject commit 374b9aaf11657469f4f1df7b51545db79b791ad0 diff --git a/firmware/tunerstudio/rusefi.input b/firmware/tunerstudio/rusefi.input index 490bb306ec..1377bc956b 100644 --- a/firmware/tunerstudio/rusefi.input +++ b/firmware/tunerstudio/rusefi.input @@ -1663,6 +1663,9 @@ cmb_etb_auto_calibrate_2 = "@@TS_IO_TEST_COMMAND_char@@\x00\x14\x00\x11" cmd_wideband_firmare_update = "@@TS_IO_TEST_COMMAND_char@@\x00\x14\x00\x12" cmd_enable_ext_stim = "@@TS_IO_TEST_COMMAND_char@@\x00\x14\x00\x13" +cmd_set_wideband_idx_0 = "@@TS_IO_TEST_COMMAND_char@@\x00\x15\x00\x00" +cmd_set_wideband_idx_1 = "@@TS_IO_TEST_COMMAND_char@@\x00\x15\x00\x01" + cmd_cj125_calibrate = "@@TS_IO_TEST_COMMAND_char@@\x00\x18\x00\x00" cmd_call_from_pit = "@@TS_IO_TEST_COMMAND_char@@\x00\x20\x34\x56" cmd_stop_engine = "@@TS_IO_TEST_COMMAND_char@@\x00\x79\x00\x00" @@ -3357,9 +3360,13 @@ cmd_set_engine_type_default = "@@TS_IO_TEST_COMMAND_char@@\x00\x31\x00\x00" panel = testMisc dialog = widebandConfig, "rusEFI Wideband Config" - field = "!Please connect exactly one wideband controller before pressing this button!" + field = "!Please connect exactly one wideband controller before pressing these buttons!" commandButton = "Update Firmware", cmd_wideband_firmare_update - + field = "!These buttons will set ALL connected controllers to the specified index." + field = "!Disconnect all controllers you don't want to set!" + commandButton = "Set Index 0", cmd_set_wideband_idx_0 + commandButton = "Set Index 1", cmd_set_wideband_idx_1 + dialog = engineTypeDialog, "Popular vehicles" field = "!These buttons send a command to rusEFI controller to apply preset values" field = "!Once you send the command, please reconnect to rusEFI controller in order to read fresh values"