diff options
author | David Crocker <dcrocker@eschertech.com> | 2020-08-13 18:18:50 +0300 |
---|---|---|
committer | David Crocker <dcrocker@eschertech.com> | 2020-08-13 18:18:50 +0300 |
commit | cdc173d6a702729e12e94d75c314af972b240d2a (patch) | |
tree | a2004b0171ea014b85a585815c084edca81ac63e /src/Endstops | |
parent | bf11b011723aac6c189e29a59fe95e42a1103bad (diff) |
Bug fix for G31 commands that use existing G31 OM values
The code was setting the new values and subsequently returning
norFinished, so if the new vaklues were computed from the old then the
new values were incorrect
Diffstat (limited to 'src/Endstops')
-rw-r--r-- | src/Endstops/ZProbe.cpp | 40 |
1 files changed, 24 insertions, 16 deletions
diff --git a/src/Endstops/ZProbe.cpp b/src/Endstops/ZProbe.cpp index 1704ff36..557b32f2 100644 --- a/src/Endstops/ZProbe.cpp +++ b/src/Endstops/ZProbe.cpp @@ -232,34 +232,41 @@ GCodeResult ZProbe::HandleG31(GCodeBuffer& gb, const StringRef& reply) THROWS(GC GCodeResult err = GCodeResult::ok; bool seen = false; + // Warning - don't change any values until we know that we are not going to return notFinished! + // This because users may use the existing values when calculating the new ones (e.g. "make babystepping permanent" macro) + // Do the temperature coefficient first because it may return notFinished + int8_t newSensor; if (gb.Seen('H')) { seen = true; - sensor = gb.GetIValue(); + newSensor = gb.GetIValue(); + } + else + { + newSensor = sensor; } if (gb.Seen('C')) { seen = true; - temperatureCoefficient = gb.GetFValue(); - calibTemperature = DefaultZProbeTemperature; + float newTemperatureCoefficient = gb.GetFValue(); + float newCalibTemperature = DefaultZProbeTemperature; TemperatureError terr; - const float currentTemperature = reprap.GetHeat().GetSensorTemperature(sensor, terr); + const float currentTemperature = reprap.GetHeat().GetSensorTemperature(newSensor, terr); if (terr == TemperatureError::unknownSensor) { - reply.copy("Cannot set a temperature coefficient without a valid sensor number"); - temperatureCoefficient = 0.0; - err = GCodeResult::error; + reply.printf("Cannot set a temperature coefficient with invalid sensor number %d", newSensor); + return GCodeResult::error; } else if (gb.Seen('S')) { - calibTemperature = gb.GetFValue(); + newCalibTemperature = gb.GetFValue(); } else if (terr == TemperatureError::success) { - calibTemperature = currentTemperature; + newCalibTemperature = currentTemperature; } else if (!gb.IsTimerRunning()) // the sensor may have only just been configured, so give it 500ms to produce a reading { @@ -273,16 +280,20 @@ GCodeResult ZProbe::HandleG31(GCodeBuffer& gb, const StringRef& reply) THROWS(GC else { gb.StopTimer(); - reply.printf("Sensor %d did not provide a valid temperature reading", sensor); - err = GCodeResult::warning; + reply.printf("Sensor %d did not provide a valid temperature reading", newSensor); + err = GCodeResult::error; } + gb.StopTimer(); + temperatureCoefficient = newTemperatureCoefficient; + calibTemperature = newCalibTemperature; } + // After this we don't return notFinished, so it is safe to amend values directly const char* axisLetters = reprap.GetGCodes().GetAxisLetters(); - gb.TryGetFValue(axisLetters[X_AXIS], xOffset, seen); gb.TryGetFValue(axisLetters[Y_AXIS], yOffset, seen); gb.TryGetFValue(axisLetters[Z_AXIS], triggerHeight, seen); + if (gb.Seen('P')) { seen = true; @@ -291,11 +302,8 @@ GCodeResult ZProbe::HandleG31(GCodeBuffer& gb, const StringRef& reply) THROWS(GC if (seen) { + sensor = newSensor; reprap.SensorsUpdated(); - if (!reprap.GetGCodes().LockMovementAndWaitForStandstill(gb)) - { - return GCodeResult::notFinished; - } if (gb.MachineState().runningM501) { misc.parts.saveToConfigOverride = true; // we are loading these parameters from config-override.g, so a subsequent M500 should save them to config-override.g |