@ -345,14 +345,15 @@ void MarlinSettings::postprocess() {
# if ENABLED(EEPROM_SETTINGS)
# if ENABLED(EEPROM_SETTINGS)
# include "../HAL/persistent_store_api.h"
# include "../HAL/persistent_store_api.h"
PersistentStore persistentStore ;
# define DUMMY_PID_VALUE 3000.0f
# define DUMMY_PID_VALUE 3000.0f
# define EEPROM_START() int eeprom_index = EEPROM_OFFSET; HAL::PersistentStore:: access_start()
# define EEPROM_START() int eeprom_index = EEPROM_OFFSET; persistentStore. access_start()
# define EEPROM_FINISH() HAL::PersistentStore:: access_finish()
# define EEPROM_FINISH() persistentStore. access_finish()
# define EEPROM_SKIP(VAR) eeprom_index += sizeof(VAR)
# define EEPROM_SKIP(VAR) eeprom_index += sizeof(VAR)
# define EEPROM_WRITE(VAR) HAL::PersistentStore:: write_data(eeprom_index, (uint8_t*)&VAR, sizeof(VAR), &working_crc)
# define EEPROM_WRITE(VAR) persistentStore. write_data(eeprom_index, (uint8_t*)&VAR, sizeof(VAR), &working_crc)
# define EEPROM_READ(VAR) HAL::PersistentStore:: read_data(eeprom_index, (uint8_t*)&VAR, sizeof(VAR), &working_crc, !validating)
# define EEPROM_READ(VAR) persistentStore. read_data(eeprom_index, (uint8_t*)&VAR, sizeof(VAR), &working_crc, !validating)
# define EEPROM_READ_ALWAYS(VAR) HAL::PersistentStore:: read_data(eeprom_index, (uint8_t*)&VAR, sizeof(VAR), &working_crc)
# define EEPROM_READ_ALWAYS(VAR) persistentStore. read_data(eeprom_index, (uint8_t*)&VAR, sizeof(VAR), &working_crc)
# define EEPROM_ASSERT(TST,ERR) if (!(TST)) do{ SERIAL_ERROR_START_P(port); SERIAL_ERRORLNPGM_P(port, ERR); eeprom_error = true; }while(0)
# define EEPROM_ASSERT(TST,ERR) if (!(TST)) do{ SERIAL_ERROR_START_P(port); SERIAL_ERRORLNPGM_P(port, ERR); eeprom_error = true; }while(0)
# if ENABLED(DEBUG_EEPROM_READWRITE)
# if ENABLED(DEBUG_EEPROM_READWRITE)
@ -1607,6 +1608,10 @@ void MarlinSettings::postprocess() {
}
}
# endif
# endif
const uint16_t MarlinSettings : : meshes_end = persistentStore . capacity ( ) - 129 ; // 128 (+1 because of the change to capacity rather than last valid address)
// is a placeholder for the size of the MAT; the MAT will always
// live at the very end of the eeprom
uint16_t MarlinSettings : : meshes_start_index ( ) {
uint16_t MarlinSettings : : meshes_start_index ( ) {
return ( datasize ( ) + EEPROM_OFFSET + 32 ) & 0xFFF8 ; // Pad the end of configuration data so it can float up
return ( datasize ( ) + EEPROM_OFFSET + 32 ) & 0xFFF8 ; // Pad the end of configuration data so it can float up
// or down a little bit without disrupting the mesh data
// or down a little bit without disrupting the mesh data
@ -1627,7 +1632,7 @@ void MarlinSettings::postprocess() {
if ( ! WITHIN ( slot , 0 , a - 1 ) ) {
if ( ! WITHIN ( slot , 0 , a - 1 ) ) {
# if ENABLED(EEPROM_CHITCHAT)
# if ENABLED(EEPROM_CHITCHAT)
ubl_invalid_slot ( a ) ;
ubl_invalid_slot ( a ) ;
SERIAL_PROTOCOLPAIR ( " E2END= " , E2END ) ;
SERIAL_PROTOCOLPAIR ( " E2END= " , persistentStore. capacity ( ) - 1 ) ;
SERIAL_PROTOCOLPAIR ( " meshes_end= " , meshes_end ) ;
SERIAL_PROTOCOLPAIR ( " meshes_end= " , meshes_end ) ;
SERIAL_PROTOCOLLNPAIR ( " slot= " , slot ) ;
SERIAL_PROTOCOLLNPAIR ( " slot= " , slot ) ;
SERIAL_EOL ( ) ;
SERIAL_EOL ( ) ;
@ -1638,9 +1643,9 @@ void MarlinSettings::postprocess() {
int pos = mesh_slot_offset ( slot ) ;
int pos = mesh_slot_offset ( slot ) ;
uint16_t crc = 0 ;
uint16_t crc = 0 ;
HAL: : PersistentStore : : access_start ( ) ;
persistentStore. access_start ( ) ;
const bool status = HAL: : PersistentStore : : write_data ( pos , ( uint8_t * ) & ubl . z_values , sizeof ( ubl . z_values ) , & crc ) ;
const bool status = persistentStore. write_data ( pos , ( uint8_t * ) & ubl . z_values , sizeof ( ubl . z_values ) , & crc ) ;
HAL: : PersistentStore : : access_finish ( ) ;
persistentStore. access_finish ( ) ;
if ( status )
if ( status )
SERIAL_PROTOCOLPGM ( " ?Unable to save mesh data. \n " ) ;
SERIAL_PROTOCOLPGM ( " ?Unable to save mesh data. \n " ) ;
@ -1676,9 +1681,9 @@ void MarlinSettings::postprocess() {
uint16_t crc = 0 ;
uint16_t crc = 0 ;
uint8_t * const dest = into ? ( uint8_t * ) into : ( uint8_t * ) & ubl . z_values ;
uint8_t * const dest = into ? ( uint8_t * ) into : ( uint8_t * ) & ubl . z_values ;
HAL: : PersistentStore : : access_start ( ) ;
persistentStore. access_start ( ) ;
const uint16_t status = HAL: : PersistentStore : : read_data ( pos , dest , sizeof ( ubl . z_values ) , & crc ) ;
const uint16_t status = persistentStore. read_data ( pos , dest , sizeof ( ubl . z_values ) , & crc ) ;
HAL: : PersistentStore : : access_finish ( ) ;
persistentStore. access_finish ( ) ;
if ( status )
if ( status )
SERIAL_PROTOCOLPGM ( " ?Unable to load mesh data. \n " ) ;
SERIAL_PROTOCOLPGM ( " ?Unable to load mesh data. \n " ) ;