|
|
|
@ -1008,10 +1008,6 @@ void MarlinSettings::postprocess() {
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
float dummy = 0;
|
|
|
|
|
#if DISABLED(AUTO_BED_LEVELING_UBL) || DISABLED(FWRETRACT) || DISABLED(FWRETRACT_AUTORETRACT) || ENABLED(NO_VOLUMETRICS)
|
|
|
|
|
bool dummyb;
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
working_crc = 0; // Init to 0. Accumulated by EEPROM_READ
|
|
|
|
|
|
|
|
|
|
_FIELD_TEST(esteppers);
|
|
|
|
@ -1023,223 +1019,241 @@ void MarlinSettings::postprocess() {
|
|
|
|
|
//
|
|
|
|
|
// Planner Motion
|
|
|
|
|
//
|
|
|
|
|
{
|
|
|
|
|
// Get only the number of E stepper parameters previously stored
|
|
|
|
|
// Any steppers added later are set to their defaults
|
|
|
|
|
const uint32_t def1[] = DEFAULT_MAX_ACCELERATION;
|
|
|
|
|
const float def2[] = DEFAULT_AXIS_STEPS_PER_UNIT, def3[] = DEFAULT_MAX_FEEDRATE;
|
|
|
|
|
|
|
|
|
|
// Get only the number of E stepper parameters previously stored
|
|
|
|
|
// Any steppers added later are set to their defaults
|
|
|
|
|
const uint32_t def1[] = DEFAULT_MAX_ACCELERATION;
|
|
|
|
|
const float def2[] = DEFAULT_AXIS_STEPS_PER_UNIT, def3[] = DEFAULT_MAX_FEEDRATE;
|
|
|
|
|
uint32_t tmp1[XYZ + esteppers];
|
|
|
|
|
EEPROM_READ(tmp1); // max_acceleration_mm_per_s2
|
|
|
|
|
EEPROM_READ(planner.settings.min_segment_time_us);
|
|
|
|
|
|
|
|
|
|
uint32_t tmp1[XYZ + esteppers];
|
|
|
|
|
EEPROM_READ(tmp1); // max_acceleration_mm_per_s2
|
|
|
|
|
EEPROM_READ(planner.settings.min_segment_time_us);
|
|
|
|
|
float tmp2[XYZ + esteppers], tmp3[XYZ + esteppers];
|
|
|
|
|
EEPROM_READ(tmp2); // axis_steps_per_mm
|
|
|
|
|
EEPROM_READ(tmp3); // max_feedrate_mm_s
|
|
|
|
|
if (!validating) LOOP_XYZE_N(i) {
|
|
|
|
|
const bool in = (i < esteppers + XYZ);
|
|
|
|
|
planner.settings.max_acceleration_mm_per_s2[i] = in ? tmp1[i] : def1[ALIM(i, def1)];
|
|
|
|
|
planner.settings.axis_steps_per_mm[i] = in ? tmp2[i] : def2[ALIM(i, def2)];
|
|
|
|
|
planner.settings.max_feedrate_mm_s[i] = in ? tmp3[i] : def3[ALIM(i, def3)];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
float tmp2[XYZ + esteppers], tmp3[XYZ + esteppers];
|
|
|
|
|
EEPROM_READ(tmp2); // axis_steps_per_mm
|
|
|
|
|
EEPROM_READ(tmp3); // max_feedrate_mm_s
|
|
|
|
|
if (!validating) LOOP_XYZE_N(i) {
|
|
|
|
|
const bool in = (i < esteppers + XYZ);
|
|
|
|
|
planner.settings.max_acceleration_mm_per_s2[i] = in ? tmp1[i] : def1[ALIM(i, def1)];
|
|
|
|
|
planner.settings.axis_steps_per_mm[i] = in ? tmp2[i] : def2[ALIM(i, def2)];
|
|
|
|
|
planner.settings.max_feedrate_mm_s[i] = in ? tmp3[i] : def3[ALIM(i, def3)];
|
|
|
|
|
}
|
|
|
|
|
EEPROM_READ(planner.settings.acceleration);
|
|
|
|
|
EEPROM_READ(planner.settings.retract_acceleration);
|
|
|
|
|
EEPROM_READ(planner.settings.travel_acceleration);
|
|
|
|
|
EEPROM_READ(planner.settings.min_feedrate_mm_s);
|
|
|
|
|
EEPROM_READ(planner.settings.min_travel_feedrate_mm_s);
|
|
|
|
|
|
|
|
|
|
EEPROM_READ(planner.settings.acceleration);
|
|
|
|
|
EEPROM_READ(planner.settings.retract_acceleration);
|
|
|
|
|
EEPROM_READ(planner.settings.travel_acceleration);
|
|
|
|
|
EEPROM_READ(planner.settings.min_feedrate_mm_s);
|
|
|
|
|
EEPROM_READ(planner.settings.min_travel_feedrate_mm_s);
|
|
|
|
|
#if HAS_CLASSIC_JERK
|
|
|
|
|
EEPROM_READ(planner.max_jerk);
|
|
|
|
|
#if ENABLED(JUNCTION_DEVIATION) && ENABLED(LIN_ADVANCE)
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
#else
|
|
|
|
|
for (uint8_t q = 4; q--;) EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if HAS_CLASSIC_JERK
|
|
|
|
|
EEPROM_READ(planner.max_jerk);
|
|
|
|
|
#if ENABLED(JUNCTION_DEVIATION) && ENABLED(LIN_ADVANCE)
|
|
|
|
|
#if ENABLED(JUNCTION_DEVIATION)
|
|
|
|
|
EEPROM_READ(planner.junction_deviation_mm);
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
#else
|
|
|
|
|
for (uint8_t q = 4; q--;) EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if ENABLED(JUNCTION_DEVIATION)
|
|
|
|
|
EEPROM_READ(planner.junction_deviation_mm);
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Home Offset (M206)
|
|
|
|
|
//
|
|
|
|
|
{
|
|
|
|
|
_FIELD_TEST(home_offset);
|
|
|
|
|
|
|
|
|
|
_FIELD_TEST(home_offset);
|
|
|
|
|
|
|
|
|
|
#if !HAS_HOME_OFFSET
|
|
|
|
|
float home_offset[XYZ];
|
|
|
|
|
#endif
|
|
|
|
|
EEPROM_READ(home_offset);
|
|
|
|
|
#if !HAS_HOME_OFFSET
|
|
|
|
|
float home_offset[XYZ];
|
|
|
|
|
#endif
|
|
|
|
|
EEPROM_READ(home_offset);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Hotend Offsets, if any
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
#if HAS_HOTEND_OFFSET
|
|
|
|
|
// Skip hotend 0 which must be 0
|
|
|
|
|
for (uint8_t e = 1; e < HOTENDS; e++)
|
|
|
|
|
LOOP_XYZ(i) EEPROM_READ(hotend_offset[i][e]);
|
|
|
|
|
#endif
|
|
|
|
|
{
|
|
|
|
|
#if HAS_HOTEND_OFFSET
|
|
|
|
|
// Skip hotend 0 which must be 0
|
|
|
|
|
for (uint8_t e = 1; e < HOTENDS; e++)
|
|
|
|
|
LOOP_XYZ(i) EEPROM_READ(hotend_offset[i][e]);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Global Leveling
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT)
|
|
|
|
|
EEPROM_READ(new_z_fade_height);
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
{
|
|
|
|
|
#if ENABLED(ENABLE_LEVELING_FADE_HEIGHT)
|
|
|
|
|
EEPROM_READ(new_z_fade_height);
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Mesh (Manual) Bed Leveling
|
|
|
|
|
//
|
|
|
|
|
{
|
|
|
|
|
uint8_t mesh_num_x, mesh_num_y;
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
EEPROM_READ_ALWAYS(mesh_num_x);
|
|
|
|
|
EEPROM_READ_ALWAYS(mesh_num_y);
|
|
|
|
|
|
|
|
|
|
uint8_t mesh_num_x, mesh_num_y;
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
EEPROM_READ_ALWAYS(mesh_num_x);
|
|
|
|
|
EEPROM_READ_ALWAYS(mesh_num_y);
|
|
|
|
|
|
|
|
|
|
#if ENABLED(MESH_BED_LEVELING)
|
|
|
|
|
if (!validating) mbl.z_offset = dummy;
|
|
|
|
|
if (mesh_num_x == GRID_MAX_POINTS_X && mesh_num_y == GRID_MAX_POINTS_Y) {
|
|
|
|
|
// EEPROM data fits the current mesh
|
|
|
|
|
EEPROM_READ(mbl.z_values);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
// EEPROM data is stale
|
|
|
|
|
if (!validating) mbl.reset();
|
|
|
|
|
#if ENABLED(MESH_BED_LEVELING)
|
|
|
|
|
if (!validating) mbl.z_offset = dummy;
|
|
|
|
|
if (mesh_num_x == GRID_MAX_POINTS_X && mesh_num_y == GRID_MAX_POINTS_Y) {
|
|
|
|
|
// EEPROM data fits the current mesh
|
|
|
|
|
EEPROM_READ(mbl.z_values);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
// EEPROM data is stale
|
|
|
|
|
if (!validating) mbl.reset();
|
|
|
|
|
for (uint16_t q = mesh_num_x * mesh_num_y; q--;) EEPROM_READ(dummy);
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
// MBL is disabled - skip the stored data
|
|
|
|
|
for (uint16_t q = mesh_num_x * mesh_num_y; q--;) EEPROM_READ(dummy);
|
|
|
|
|
}
|
|
|
|
|
#else
|
|
|
|
|
// MBL is disabled - skip the stored data
|
|
|
|
|
for (uint16_t q = mesh_num_x * mesh_num_y; q--;) EEPROM_READ(dummy);
|
|
|
|
|
#endif // MESH_BED_LEVELING
|
|
|
|
|
#endif // MESH_BED_LEVELING
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_FIELD_TEST(zprobe_zoffset);
|
|
|
|
|
//
|
|
|
|
|
// Probe Z Offset
|
|
|
|
|
//
|
|
|
|
|
{
|
|
|
|
|
_FIELD_TEST(zprobe_zoffset);
|
|
|
|
|
|
|
|
|
|
#if !HAS_BED_PROBE
|
|
|
|
|
float zprobe_zoffset;
|
|
|
|
|
#endif
|
|
|
|
|
EEPROM_READ(zprobe_zoffset);
|
|
|
|
|
#if !HAS_BED_PROBE
|
|
|
|
|
float zprobe_zoffset;
|
|
|
|
|
#endif
|
|
|
|
|
EEPROM_READ(zprobe_zoffset);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Planar Bed Leveling matrix
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
#if ABL_PLANAR
|
|
|
|
|
EEPROM_READ(planner.bed_level_matrix);
|
|
|
|
|
#else
|
|
|
|
|
for (uint8_t q = 9; q--;) EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
{
|
|
|
|
|
#if ABL_PLANAR
|
|
|
|
|
EEPROM_READ(planner.bed_level_matrix);
|
|
|
|
|
#else
|
|
|
|
|
for (uint8_t q = 9; q--;) EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Bilinear Auto Bed Leveling
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
uint8_t grid_max_x, grid_max_y;
|
|
|
|
|
EEPROM_READ_ALWAYS(grid_max_x); // 1 byte
|
|
|
|
|
EEPROM_READ_ALWAYS(grid_max_y); // 1 byte
|
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_BILINEAR)
|
|
|
|
|
if (grid_max_x == GRID_MAX_POINTS_X && grid_max_y == GRID_MAX_POINTS_Y) {
|
|
|
|
|
if (!validating) set_bed_leveling_enabled(false);
|
|
|
|
|
EEPROM_READ(bilinear_grid_spacing); // 2 ints
|
|
|
|
|
EEPROM_READ(bilinear_start); // 2 ints
|
|
|
|
|
EEPROM_READ(z_values); // 9 to 256 floats
|
|
|
|
|
}
|
|
|
|
|
else // EEPROM data is stale
|
|
|
|
|
#endif // AUTO_BED_LEVELING_BILINEAR
|
|
|
|
|
{
|
|
|
|
|
// Skip past disabled (or stale) Bilinear Grid data
|
|
|
|
|
int bgs[2], bs[2];
|
|
|
|
|
EEPROM_READ(bgs);
|
|
|
|
|
EEPROM_READ(bs);
|
|
|
|
|
for (uint16_t q = grid_max_x * grid_max_y; q--;) EEPROM_READ(dummy);
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
uint8_t grid_max_x, grid_max_y;
|
|
|
|
|
EEPROM_READ_ALWAYS(grid_max_x); // 1 byte
|
|
|
|
|
EEPROM_READ_ALWAYS(grid_max_y); // 1 byte
|
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_BILINEAR)
|
|
|
|
|
if (grid_max_x == GRID_MAX_POINTS_X && grid_max_y == GRID_MAX_POINTS_Y) {
|
|
|
|
|
if (!validating) set_bed_leveling_enabled(false);
|
|
|
|
|
EEPROM_READ(bilinear_grid_spacing); // 2 ints
|
|
|
|
|
EEPROM_READ(bilinear_start); // 2 ints
|
|
|
|
|
EEPROM_READ(z_values); // 9 to 256 floats
|
|
|
|
|
}
|
|
|
|
|
else // EEPROM data is stale
|
|
|
|
|
#endif // AUTO_BED_LEVELING_BILINEAR
|
|
|
|
|
{
|
|
|
|
|
// Skip past disabled (or stale) Bilinear Grid data
|
|
|
|
|
int bgs[2], bs[2];
|
|
|
|
|
EEPROM_READ(bgs);
|
|
|
|
|
EEPROM_READ(bs);
|
|
|
|
|
for (uint16_t q = grid_max_x * grid_max_y; q--;) EEPROM_READ(dummy);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Unified Bed Leveling active state
|
|
|
|
|
//
|
|
|
|
|
{
|
|
|
|
|
_FIELD_TEST(planner_leveling_active);
|
|
|
|
|
|
|
|
|
|
_FIELD_TEST(planner_leveling_active);
|
|
|
|
|
|
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL)
|
|
|
|
|
EEPROM_READ(planner.leveling_active);
|
|
|
|
|
EEPROM_READ(ubl.storage_slot);
|
|
|
|
|
#else
|
|
|
|
|
uint8_t dummyui8;
|
|
|
|
|
EEPROM_READ(dummyb);
|
|
|
|
|
EEPROM_READ(dummyui8);
|
|
|
|
|
#endif // AUTO_BED_LEVELING_UBL
|
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL)
|
|
|
|
|
EEPROM_READ(planner.leveling_active);
|
|
|
|
|
EEPROM_READ(ubl.storage_slot);
|
|
|
|
|
#else
|
|
|
|
|
bool planner_leveling_active;
|
|
|
|
|
uint8_t ubl_storage_slot;
|
|
|
|
|
EEPROM_READ(planner_leveling_active);
|
|
|
|
|
EEPROM_READ(ubl_storage_slot);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// SERVO_ANGLES
|
|
|
|
|
//
|
|
|
|
|
#if !HAS_SERVOS || DISABLED(EDITABLE_SERVO_ANGLES)
|
|
|
|
|
uint16_t servo_angles[NUM_SERVOS][2];
|
|
|
|
|
#endif
|
|
|
|
|
EEPROM_READ(servo_angles);
|
|
|
|
|
{
|
|
|
|
|
#if !HAS_SERVOS || DISABLED(EDITABLE_SERVO_ANGLES)
|
|
|
|
|
uint16_t servo_angles[NUM_SERVOS][2];
|
|
|
|
|
#endif
|
|
|
|
|
EEPROM_READ(servo_angles);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// DELTA Geometry or Dual Endstops offsets
|
|
|
|
|
//
|
|
|
|
|
{
|
|
|
|
|
#if ENABLED(DELTA)
|
|
|
|
|
|
|
|
|
|
#if ENABLED(DELTA)
|
|
|
|
|
_FIELD_TEST(delta_height);
|
|
|
|
|
|
|
|
|
|
_FIELD_TEST(delta_height);
|
|
|
|
|
EEPROM_READ(delta_height); // 1 float
|
|
|
|
|
EEPROM_READ(delta_endstop_adj); // 3 floats
|
|
|
|
|
EEPROM_READ(delta_radius); // 1 float
|
|
|
|
|
EEPROM_READ(delta_diagonal_rod); // 1 float
|
|
|
|
|
EEPROM_READ(delta_segments_per_second); // 1 float
|
|
|
|
|
EEPROM_READ(delta_calibration_radius); // 1 float
|
|
|
|
|
EEPROM_READ(delta_tower_angle_trim); // 3 floats
|
|
|
|
|
|
|
|
|
|
EEPROM_READ(delta_height); // 1 float
|
|
|
|
|
EEPROM_READ(delta_endstop_adj); // 3 floats
|
|
|
|
|
EEPROM_READ(delta_radius); // 1 float
|
|
|
|
|
EEPROM_READ(delta_diagonal_rod); // 1 float
|
|
|
|
|
EEPROM_READ(delta_segments_per_second); // 1 float
|
|
|
|
|
EEPROM_READ(delta_calibration_radius); // 1 float
|
|
|
|
|
EEPROM_READ(delta_tower_angle_trim); // 3 floats
|
|
|
|
|
#elif ENABLED(X_DUAL_ENDSTOPS) || ENABLED(Y_DUAL_ENDSTOPS) || Z_MULTI_ENDSTOPS
|
|
|
|
|
|
|
|
|
|
#elif ENABLED(X_DUAL_ENDSTOPS) || ENABLED(Y_DUAL_ENDSTOPS) || Z_MULTI_ENDSTOPS
|
|
|
|
|
_FIELD_TEST(x2_endstop_adj);
|
|
|
|
|
|
|
|
|
|
_FIELD_TEST(x2_endstop_adj);
|
|
|
|
|
#if ENABLED(X_DUAL_ENDSTOPS)
|
|
|
|
|
EEPROM_READ(endstops.x2_endstop_adj); // 1 float
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
#if ENABLED(Y_DUAL_ENDSTOPS)
|
|
|
|
|
EEPROM_READ(endstops.y2_endstop_adj); // 1 float
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
#if Z_MULTI_ENDSTOPS
|
|
|
|
|
EEPROM_READ(endstops.z2_endstop_adj); // 1 float
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
#if ENABLED(Z_TRIPLE_ENDSTOPS)
|
|
|
|
|
EEPROM_READ(endstops.z3_endstop_adj); // 1 float
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if ENABLED(X_DUAL_ENDSTOPS)
|
|
|
|
|
EEPROM_READ(endstops.x2_endstop_adj); // 1 float
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
#if ENABLED(Y_DUAL_ENDSTOPS)
|
|
|
|
|
EEPROM_READ(endstops.y2_endstop_adj); // 1 float
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
#if Z_MULTI_ENDSTOPS
|
|
|
|
|
EEPROM_READ(endstops.z2_endstop_adj); // 1 float
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
#if ENABLED(Z_TRIPLE_ENDSTOPS)
|
|
|
|
|
EEPROM_READ(endstops.z3_endstop_adj); // 1 float
|
|
|
|
|
#else
|
|
|
|
|
EEPROM_READ(dummy);
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// LCD Preheat settings
|
|
|
|
|
//
|
|
|
|
|
{
|
|
|
|
|
_FIELD_TEST(lcd_preheat_hotend_temp);
|
|
|
|
|
|
|
|
|
|
_FIELD_TEST(lcd_preheat_hotend_temp);
|
|
|
|
|
|
|
|
|
|
#if DISABLED(ULTIPANEL)
|
|
|
|
|
int16_t lcd_preheat_hotend_temp[2], lcd_preheat_bed_temp[2];
|
|
|
|
|
uint8_t lcd_preheat_fan_speed[2];
|
|
|
|
|
#endif
|
|
|
|
|
EEPROM_READ(lcd_preheat_hotend_temp); // 2 floats
|
|
|
|
|
EEPROM_READ(lcd_preheat_bed_temp); // 2 floats
|
|
|
|
|
EEPROM_READ(lcd_preheat_fan_speed); // 2 floats
|
|
|
|
|
#if DISABLED(ULTIPANEL)
|
|
|
|
|
int16_t lcd_preheat_hotend_temp[2], lcd_preheat_bed_temp[2];
|
|
|
|
|
uint8_t lcd_preheat_fan_speed[2];
|
|
|
|
|
#endif
|
|
|
|
|
EEPROM_READ(lcd_preheat_hotend_temp); // 2 floats
|
|
|
|
|
EEPROM_READ(lcd_preheat_bed_temp); // 2 floats
|
|
|
|
|
EEPROM_READ(lcd_preheat_fan_speed); // 2 floats
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
|
// Hotend PID
|
|
|
|
|