Cleaner failure of UBL without EEPROM
This commit is contained in:
parent
9128d9ab45
commit
dac29e0f75
1 changed files with 30 additions and 21 deletions
|
@ -8866,25 +8866,43 @@ void quickstop_stepper() {
|
||||||
inline void gcode_M420() {
|
inline void gcode_M420() {
|
||||||
|
|
||||||
#if ENABLED(AUTO_BED_LEVELING_UBL)
|
#if ENABLED(AUTO_BED_LEVELING_UBL)
|
||||||
|
|
||||||
// L to load a mesh from the EEPROM
|
// L to load a mesh from the EEPROM
|
||||||
if (parser.seen('L')) {
|
if (parser.seen('L')) {
|
||||||
const int8_t storage_slot = parser.has_value() ? parser.value_int() : ubl.state.storage_slot;
|
|
||||||
const int16_t a = settings.calc_num_meshes();
|
|
||||||
|
|
||||||
if (!a) {
|
#if ENABLED(EEPROM_SETTINGS)
|
||||||
|
const int8_t storage_slot = parser.has_value() ? parser.value_int() : ubl.state.storage_slot;
|
||||||
|
const int16_t a = settings.calc_num_meshes();
|
||||||
|
|
||||||
|
if (!a) {
|
||||||
|
SERIAL_PROTOCOLLNPGM("?EEPROM storage not available.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!WITHIN(storage_slot, 0, a - 1)) {
|
||||||
|
SERIAL_PROTOCOLLNPGM("?Invalid storage slot.");
|
||||||
|
SERIAL_PROTOCOLLNPAIR("?Use 0 to ", a - 1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
settings.load_mesh(storage_slot);
|
||||||
|
ubl.state.storage_slot = storage_slot;
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
SERIAL_PROTOCOLLNPGM("?EEPROM storage not available.");
|
SERIAL_PROTOCOLLNPGM("?EEPROM storage not available.");
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
|
|
||||||
if (!WITHIN(storage_slot, 0, a - 1)) {
|
#endif
|
||||||
SERIAL_PROTOCOLLNPGM("?Invalid storage slot.");
|
|
||||||
SERIAL_PROTOCOLLNPAIR("?Use 0 to ", a - 1);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
settings.load_mesh(storage_slot);
|
|
||||||
ubl.state.storage_slot = storage_slot;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// L to load a mesh from the EEPROM
|
||||||
|
if (parser.seen('L') || parser.seen('V')) {
|
||||||
|
ubl.display_map(0); // Currently only supports one map type
|
||||||
|
SERIAL_ECHOLNPAIR("UBL_MESH_VALID = ", UBL_MESH_VALID);
|
||||||
|
SERIAL_ECHOLNPAIR("ubl.state.storage_slot = ", ubl.state.storage_slot);
|
||||||
|
}
|
||||||
|
|
||||||
#endif // AUTO_BED_LEVELING_UBL
|
#endif // AUTO_BED_LEVELING_UBL
|
||||||
|
|
||||||
// V to print the matrix or mesh
|
// V to print the matrix or mesh
|
||||||
|
@ -8906,15 +8924,6 @@ void quickstop_stepper() {
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#if ENABLED(AUTO_BED_LEVELING_UBL)
|
|
||||||
// L to load a mesh from the EEPROM
|
|
||||||
if (parser.seen('L') || parser.seen('V')) {
|
|
||||||
ubl.display_map(0); // Currently only supports one map type
|
|
||||||
SERIAL_ECHOLNPAIR("UBL_MESH_VALID = ", UBL_MESH_VALID);
|
|
||||||
SERIAL_ECHOLNPAIR("ubl.state.storage_slot = ", ubl.state.storage_slot);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
bool to_enable = false;
|
bool to_enable = false;
|
||||||
if (parser.seen('S')) {
|
if (parser.seen('S')) {
|
||||||
to_enable = parser.value_bool();
|
to_enable = parser.value_bool();
|
||||||
|
|
Reference in a new issue