|
|
@ -29,31 +29,31 @@ class MarlinSettings {
|
|
|
|
public:
|
|
|
|
public:
|
|
|
|
MarlinSettings() { }
|
|
|
|
MarlinSettings() { }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static uint16_t datasize();
|
|
|
|
|
|
|
|
|
|
|
|
static void reset();
|
|
|
|
static void reset();
|
|
|
|
static bool save();
|
|
|
|
static bool save(); // Return 'true' if data was saved
|
|
|
|
|
|
|
|
|
|
|
|
FORCE_INLINE static bool init_eeprom() {
|
|
|
|
FORCE_INLINE static bool init_eeprom() {
|
|
|
|
bool success = true;
|
|
|
|
bool success = true;
|
|
|
|
reset();
|
|
|
|
reset();
|
|
|
|
#if ENABLED(EEPROM_SETTINGS)
|
|
|
|
#if ENABLED(EEPROM_SETTINGS)
|
|
|
|
if ((success = save())) {
|
|
|
|
success = save();
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL)
|
|
|
|
#if ENABLED(EEPROM_CHITCHAT)
|
|
|
|
success = load(); // UBL uses load() to know the end of EEPROM
|
|
|
|
if (success) report();
|
|
|
|
#elif ENABLED(EEPROM_CHITCHAT)
|
|
|
|
|
|
|
|
report();
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
return success;
|
|
|
|
return success;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(EEPROM_SETTINGS)
|
|
|
|
#if ENABLED(EEPROM_SETTINGS)
|
|
|
|
static bool load();
|
|
|
|
static bool load(); // Return 'true' if data was loaded ok
|
|
|
|
|
|
|
|
static bool validate(); // Return 'true' if EEPROM data is ok
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL) // Eventually make these available if any leveling system
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL) // Eventually make these available if any leveling system
|
|
|
|
// That can store is enabled
|
|
|
|
// That can store is enabled
|
|
|
|
FORCE_INLINE static int16_t get_start_of_meshes() { return meshes_begin; }
|
|
|
|
static int16_t meshes_start_index();
|
|
|
|
FORCE_INLINE static int16_t get_end_of_meshes() { return meshes_end; }
|
|
|
|
FORCE_INLINE static int16_t meshes_end_index() { return meshes_end; }
|
|
|
|
static uint16_t calc_num_meshes();
|
|
|
|
static uint16_t calc_num_meshes();
|
|
|
|
static void store_mesh(const int8_t slot);
|
|
|
|
static void store_mesh(const int8_t slot);
|
|
|
|
static void load_mesh(const int8_t slot, void * const into=NULL);
|
|
|
|
static void load_mesh(const int8_t slot, void * const into=NULL);
|
|
|
@ -77,16 +77,18 @@ class MarlinSettings {
|
|
|
|
static void postprocess();
|
|
|
|
static void postprocess();
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(EEPROM_SETTINGS)
|
|
|
|
#if ENABLED(EEPROM_SETTINGS)
|
|
|
|
static bool eeprom_error;
|
|
|
|
|
|
|
|
|
|
|
|
static bool eeprom_error, validating;
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL) // Eventually make these available if any leveling system
|
|
|
|
#if ENABLED(AUTO_BED_LEVELING_UBL) // Eventually make these available if any leveling system
|
|
|
|
// That can store is enabled
|
|
|
|
// That can store is enabled
|
|
|
|
static int16_t meshes_begin;
|
|
|
|
|
|
|
|
const static int16_t meshes_end = E2END - 128; // 128 is a placeholder for the size of the MAT; the MAT will always
|
|
|
|
const static int16_t meshes_end = E2END - 128; // 128 is a placeholder for the size of the MAT; the MAT will always
|
|
|
|
// live at the very end of the eeprom
|
|
|
|
// live at the very end of the eeprom
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static bool _load();
|
|
|
|
|
|
|
|
static bool size_error(const uint16_t size);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|