diff --git a/src/js/msp/MSPHelper.js b/src/js/msp/MSPHelper.js index 55e428f320..c85d3f32d0 100644 --- a/src/js/msp/MSPHelper.js +++ b/src/js/msp/MSPHelper.js @@ -2790,6 +2790,11 @@ MspHelper.prototype.sendSerialConfig = function(callback) { }; MspHelper.prototype.writeConfiguration = function(reboot, callback) { + // We need some protection when testing motors on motors tab + if (!FC.CONFIG.armingDisabled) { + this.setArmingEnabled(false, false); + } + setTimeout(function() { MSP.send_message(MSPCodes.MSP_EEPROM_WRITE, false, false, function() { gui_log(i18n.getMessage('configurationEepromSaved')); diff --git a/src/js/tabs/motors.js b/src/js/tabs/motors.js index a999792471..b681d4f77e 100644 --- a/src/js/tabs/motors.js +++ b/src/js/tabs/motors.js @@ -917,6 +917,7 @@ motors.initialize = async function (callback) { // Send enable extended dshot telemetry command const buffer = []; + // this should include check for using extended dshot telemetry buffer.push8(DshotCommand.dshotCommandType_e.DSHOT_CMD_TYPE_BLOCKING); buffer.push8(255); // Send to all escs buffer.push8(1); // 1 command @@ -994,6 +995,9 @@ motors.initialize = async function (callback) { } } + // After saving configuration [in another tab], arming will be disabled + motorsRunning = motorsRunning && !FC.CONFIG.armingDisabled; + if (motorsRunning) { motorsEnableTestModeElement.prop('checked', true).trigger('change'); @@ -1020,6 +1024,9 @@ motors.initialize = async function (callback) { $('div.sliders input.master').val(masterValue) .trigger('input'); } + } else { + // prevent jump on re-enable as FC.MOTOR_DATA has not been reset yet + FC.MOTOR_DATA.fill(zeroThrottleValue); } // data pulling functions used inside interval timer