[2.0.x] PersistentStore update followup (#11549)
This commit is contained in:
		
				
					committed by
					
						
						Scott Lahteine
					
				
			
			
				
	
			
			
			
						parent
						
							846bd24eb9
						
					
				
				
					commit
					5573ef62c6
				
			@@ -1,51 +0,0 @@
 | 
			
		||||
#ifdef __AVR__
 | 
			
		||||
 | 
			
		||||
#include "../shared/persistent_store_api.h"
 | 
			
		||||
 | 
			
		||||
#include "../../inc/MarlinConfig.h"
 | 
			
		||||
 | 
			
		||||
#if ENABLED(EEPROM_SETTINGS)
 | 
			
		||||
 | 
			
		||||
namespace HAL {
 | 
			
		||||
namespace PersistentStore {
 | 
			
		||||
 | 
			
		||||
bool access_start() { return true; }
 | 
			
		||||
bool access_finish() { return true; }
 | 
			
		||||
 | 
			
		||||
bool write_data(int &pos, const uint8_t *value, uint16_t size, uint16_t *crc) {
 | 
			
		||||
  while (size--) {
 | 
			
		||||
    uint8_t * const p = (uint8_t * const)pos;
 | 
			
		||||
    uint8_t v = *value;
 | 
			
		||||
    // EEPROM has only ~100,000 write cycles,
 | 
			
		||||
    // so only write bytes that have changed!
 | 
			
		||||
    if (v != eeprom_read_byte(p)) {
 | 
			
		||||
      eeprom_write_byte(p, v);
 | 
			
		||||
      if (eeprom_read_byte(p) != v) {
 | 
			
		||||
        SERIAL_ECHO_START();
 | 
			
		||||
        SERIAL_ECHOLNPGM(MSG_ERR_EEPROM_WRITE);
 | 
			
		||||
        return true;
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    crc16(crc, &v, 1);
 | 
			
		||||
    pos++;
 | 
			
		||||
    value++;
 | 
			
		||||
  };
 | 
			
		||||
  return false;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool read_data(int &pos, uint8_t* value, uint16_t size, uint16_t *crc, const bool writing/*=true*/) {
 | 
			
		||||
  do {
 | 
			
		||||
    uint8_t c = eeprom_read_byte((unsigned char*)pos);
 | 
			
		||||
    if (writing) *value = c;
 | 
			
		||||
    crc16(crc, &c, 1);
 | 
			
		||||
    pos++;
 | 
			
		||||
    value++;
 | 
			
		||||
  } while (--size);
 | 
			
		||||
  return false;  // always assume success for AVR's
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#endif // EEPROM_SETTINGS
 | 
			
		||||
#endif // __AVR__
 | 
			
		||||
@@ -45,7 +45,7 @@
 | 
			
		||||
#if HAS_SERVOS
 | 
			
		||||
 | 
			
		||||
#include <Arduino.h>
 | 
			
		||||
#include "../servo.h"
 | 
			
		||||
#include "../shared/servo.h"
 | 
			
		||||
#include "../shared/servo_private.h"
 | 
			
		||||
 | 
			
		||||
static volatile int8_t Channel[_Nbr_16timers];              // counter for the servo being pulsed for each timer (or -1 if refresh interval)
 | 
			
		||||
@@ -158,4 +158,3 @@ void finISR(timer16_Sequence_t timer) {
 | 
			
		||||
#endif // HAS_SERVOS
 | 
			
		||||
 | 
			
		||||
#endif // ARDUINO_ARCH_SAM
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -26,8 +26,13 @@
 | 
			
		||||
 | 
			
		||||
#if ENABLED(EEPROM_SETTINGS)
 | 
			
		||||
 | 
			
		||||
#include "../../inc/MarlinConfig.h"
 | 
			
		||||
#include "../shared/persistent_store_api.h"
 | 
			
		||||
 | 
			
		||||
#if DISABLED(I2C_EEPROM) && DISABLED(SPI_EEPROM)
 | 
			
		||||
  #define E2END 0xFFF // Default to Flash emulated EEPROM size (EepromEmulation_Due.cpp)
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
extern void eeprom_flush(void);
 | 
			
		||||
 | 
			
		||||
bool PersistentStore::access_start() { return true; }
 | 
			
		||||
 
 | 
			
		||||
@@ -1,59 +0,0 @@
 | 
			
		||||
#ifdef ARDUINO_ARCH_SAM
 | 
			
		||||
 | 
			
		||||
#include "../shared/persistent_store_api.h"
 | 
			
		||||
 | 
			
		||||
#include "../../inc/MarlinConfig.h"
 | 
			
		||||
 | 
			
		||||
#if ENABLED(EEPROM_SETTINGS)
 | 
			
		||||
 | 
			
		||||
extern void eeprom_flush(void);
 | 
			
		||||
 | 
			
		||||
namespace HAL {
 | 
			
		||||
namespace PersistentStore {
 | 
			
		||||
 | 
			
		||||
bool access_start() { return true; }
 | 
			
		||||
 | 
			
		||||
bool access_finish() {
 | 
			
		||||
  #if DISABLED(I2C_EEPROM) && DISABLED(SPI_EEPROM)
 | 
			
		||||
    eeprom_flush();
 | 
			
		||||
  #endif
 | 
			
		||||
  return true;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool write_data(int &pos, const uint8_t *value, uint16_t size, uint16_t *crc) {
 | 
			
		||||
  while (size--) {
 | 
			
		||||
    uint8_t * const p = (uint8_t * const)pos;
 | 
			
		||||
    uint8_t v = *value;
 | 
			
		||||
    // EEPROM has only ~100,000 write cycles,
 | 
			
		||||
    // so only write bytes that have changed!
 | 
			
		||||
    if (v != eeprom_read_byte(p)) {
 | 
			
		||||
      eeprom_write_byte(p, v);
 | 
			
		||||
      if (eeprom_read_byte(p) != v) {
 | 
			
		||||
        SERIAL_ECHO_START();
 | 
			
		||||
        SERIAL_ECHOLNPGM(MSG_ERR_EEPROM_WRITE);
 | 
			
		||||
        return true;
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    crc16(crc, &v, 1);
 | 
			
		||||
    pos++;
 | 
			
		||||
    value++;
 | 
			
		||||
  };
 | 
			
		||||
  return false;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool read_data(int &pos, uint8_t* value, uint16_t size, uint16_t *crc, const bool writing/*=true*/) {
 | 
			
		||||
  do {
 | 
			
		||||
    uint8_t c = eeprom_read_byte((unsigned char*)pos);
 | 
			
		||||
    if (writing) *value = c;
 | 
			
		||||
    crc16(crc, &c, 1);
 | 
			
		||||
    pos++;
 | 
			
		||||
    value++;
 | 
			
		||||
  } while (--size);
 | 
			
		||||
  return false;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#endif // EEPROM_SETTINGS
 | 
			
		||||
#endif // __AVR__
 | 
			
		||||
@@ -41,6 +41,7 @@
 | 
			
		||||
#if ENABLED(EEPROM_SETTINGS)
 | 
			
		||||
 | 
			
		||||
#include "persistent_store_api.h"
 | 
			
		||||
#include "../../inc/MarlinConfig.h"
 | 
			
		||||
 | 
			
		||||
#if ENABLED(FLASH_EEPROM)
 | 
			
		||||
 | 
			
		||||
@@ -50,16 +51,12 @@ extern "C" {
 | 
			
		||||
 | 
			
		||||
#define SECTOR_START(sector)	((sector < 16) ? (sector * 0x1000) : ((sector - 14) * 0x8000))
 | 
			
		||||
#define EEPROM_SECTOR 29
 | 
			
		||||
#define EEPROM_SIZE (E2END+1)
 | 
			
		||||
#define EEPROM_SIZE (4096)
 | 
			
		||||
#define SECTOR_SIZE (32768)
 | 
			
		||||
#define EEPROM_SLOTS (SECTOR_SIZE/EEPROM_SIZE)
 | 
			
		||||
#define EEPROM_ERASE (0xff)
 | 
			
		||||
#define SLOT_ADDRESS(sector, slot) (((uint8_t *)SECTOR_START(sector)) + slot * EEPROM_SIZE)
 | 
			
		||||
 | 
			
		||||
#if EEPROM_SIZE != 4096
 | 
			
		||||
  #error "EEPROM_SIZE must match flash write size"
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
static uint8_t ram_eeprom[EEPROM_SIZE];
 | 
			
		||||
static bool eeprom_dirty = false;
 | 
			
		||||
static int current_slot = 0;
 | 
			
		||||
@@ -118,7 +115,7 @@ bool PersistentStore::access_finish() {
 | 
			
		||||
  return true;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool PersistentStore::write_data(int &pos, const uint8_t *value, uint16_t size, uint16_t *crc) {
 | 
			
		||||
bool PersistentStore::write_data(int &pos, const uint8_t *value, size_t size, uint16_t *crc) {
 | 
			
		||||
  for (int i = 0; i < size; i++) ram_eeprom[pos + i] = value[i];
 | 
			
		||||
  eeprom_dirty = true;
 | 
			
		||||
  crc16(crc, value, size);
 | 
			
		||||
@@ -126,7 +123,7 @@ bool PersistentStore::write_data(int &pos, const uint8_t *value, uint16_t size,
 | 
			
		||||
  return false;  // return true for any error
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool PersistentStore::read_data(int &pos, uint8_t* value, uint16_t size, uint16_t *crc, const bool writing/*=true*/) {
 | 
			
		||||
bool PersistentStore::read_data(int &pos, uint8_t* value, size_t size, uint16_t *crc, const bool writing/*=true*/) {
 | 
			
		||||
  const uint8_t * const buff = writing ? &value[0] : &ram_eeprom[pos];
 | 
			
		||||
  if (writing) for (int i = 0; i < size; i++) value[i] = ram_eeprom[pos + i];
 | 
			
		||||
  crc16(crc, buff, size);
 | 
			
		||||
@@ -134,6 +131,8 @@ bool PersistentStore::read_data(int &pos, uint8_t* value, uint16_t size, uint16_
 | 
			
		||||
  return false;  // return true for any error
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
size_t PersistentStore::capacity() { return EEPROM_SIZE; }
 | 
			
		||||
 | 
			
		||||
#endif // FLASH_EEPROM
 | 
			
		||||
#endif // EEPROM_SETTINGS
 | 
			
		||||
#endif // TARGET_LPC1768
 | 
			
		||||
 
 | 
			
		||||
@@ -26,6 +26,7 @@
 | 
			
		||||
 | 
			
		||||
#if ENABLED(EEPROM_SETTINGS)
 | 
			
		||||
 | 
			
		||||
#include "../../inc/MarlinConfig.h"
 | 
			
		||||
#include "persistent_store_api.h"
 | 
			
		||||
 | 
			
		||||
#if DISABLED(FLASH_EEPROM)
 | 
			
		||||
@@ -80,18 +81,18 @@ bool PersistentStore::access_finish() {
 | 
			
		||||
static void debug_rw(const bool write, int &pos, const uint8_t *value, const size_t size, const FRESULT s, const size_t total=0) {
 | 
			
		||||
  const char * const rw_str = write ? PSTR("write") : PSTR("read");
 | 
			
		||||
  SERIAL_PROTOCOLCHAR(' ');
 | 
			
		||||
  serialprint_PGM(rw_str);
 | 
			
		||||
  serialprintPGM(rw_str);
 | 
			
		||||
  SERIAL_PROTOCOLPAIR("_data(", pos);
 | 
			
		||||
  SERIAL_PROTOCOLPAIR(",", (int)value);
 | 
			
		||||
  SERIAL_PROTOCOLPAIR(",", (int)size);
 | 
			
		||||
  SERIAL_PROTOCOLLNPGM(", ...)");
 | 
			
		||||
  if (total) {
 | 
			
		||||
    SERIAL_PROTOCOLPGM(" f_");
 | 
			
		||||
    serialprint_PGM(rw_str);
 | 
			
		||||
    serialprintPGM(rw_str);
 | 
			
		||||
    SERIAL_PROTOCOLPAIR("()=", (int)s);
 | 
			
		||||
    SERIAL_PROTOCOLPAIR("\n size=", size);
 | 
			
		||||
    SERIAL_PROTOCOLPGM("\n bytes_");
 | 
			
		||||
    serialprint_PGM(write ? PSTR("written=") : PSTR("read="));
 | 
			
		||||
    serialprintPGM(write ? PSTR("written=") : PSTR("read="));
 | 
			
		||||
    SERIAL_PROTOCOLLN(total);
 | 
			
		||||
  }
 | 
			
		||||
  else
 | 
			
		||||
 
 | 
			
		||||
@@ -33,7 +33,7 @@
 | 
			
		||||
// Includes
 | 
			
		||||
// --------------------------------------------------------------------------
 | 
			
		||||
 | 
			
		||||
#include HAL_PATH(., HAL.h)
 | 
			
		||||
#include HAL_PATH(.., HAL.h)
 | 
			
		||||
#include <Wire.h>
 | 
			
		||||
 | 
			
		||||
// --------------------------------------------------------------------------
 | 
			
		||||
@@ -157,4 +157,3 @@ void eeprom_read_block(void* pos, const void* eeprom_address, size_t n) {
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#endif // ENABLED(I2C_EEPROM)
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -29,7 +29,7 @@
 | 
			
		||||
 | 
			
		||||
#if ENABLED(SPI_EEPROM)
 | 
			
		||||
 | 
			
		||||
#include HAL_PATH(., HAL.h)
 | 
			
		||||
#include HAL_PATH(.., HAL.h)
 | 
			
		||||
 | 
			
		||||
#define CMD_WREN  6   // WREN
 | 
			
		||||
#define CMD_READ  2   // WRITE
 | 
			
		||||
 
 | 
			
		||||
@@ -20,11 +20,11 @@
 | 
			
		||||
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 *
 | 
			
		||||
 */
 | 
			
		||||
#include "../inc/MarlinConfigPre.h"
 | 
			
		||||
#include "../../inc/MarlinConfigPre.h"
 | 
			
		||||
 | 
			
		||||
#if ENABLED(EEPROM_SETTINGS)
 | 
			
		||||
 | 
			
		||||
  #include "shared/persistent_store_api.h"
 | 
			
		||||
  #include "persistent_store_api.h"
 | 
			
		||||
  PersistentStore persistentStore;
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
		Reference in New Issue
	
	Block a user