ac168a03c8
* Fixing the DUE serial port assignments: Now -1 means the SAM3x USB Device emulating a serial port, and 0 means the USB to serial adapter included as a programming port * Improving the Fast IO port access implementation on Arduino DUE * Implemented EEPROM emulation on Due by storing data on the internal FLASH (with wear leveling) * Implemented a Software SPI for the ST7920 graphics display for the Arduino RAMPS for DUE, as the default one in u8glib is clocking data too fast on ARM, and the display does not understand it. * Fixing the case where the serial port selected is the USB device * Adding configuration for the Makerparts 3D printer (www.makerparts.net) * Tuned MakerParts acceleration on X and Y axis so it never loses steps. Also adjusted pulses per mm to match default hw configuration * Fine tuned Maximum acceleration for MakerParts printer * Style cleanup * Style cleanup (2) * Style fixes (3) * Fixing the DUE serial port assignments: Now -1 means the SAM3x USB Device emulating a serial port, and 0 means the USB to serial adapter included as a programming port * Improving the Fast IO port access implementation on Arduino DUE * Implemented EEPROM emulation on Due by storing data on the internal FLASH (with wear leveling) * Implemented a Software SPI for the ST7920 graphics display for the Arduino RAMPS for DUE, as the default one in u8glib is clocking data too fast on ARM, and the display does not understand it. * Fixing the case where the serial port selected is the USB device * Adding configuration for the Makerparts 3D printer (www.makerparts.net) * Tuned MakerParts acceleration on X and Y axis so it never loses steps. Also adjusted pulses per mm to match default hw configuration * Fine tuned Maximum acceleration for MakerParts printer * Style cleanup * Style changes to u8g_dev_st7920_128_64_sw_spi.cpp * Even more improvements to the FastIO HAL for DUE. Now WRITE() is 2 ASM instructions, if value is constant, and 5 cycles if value is not constant. Previously, it was 7..8 cycles * After some problems and debugging, seems we need to align the interrupt vector table to 256 bytes, otherwise, the program sometimes stops working * Moved comments out of macro, otherwise, token pasting does not properly work sometimes * Improved Software SPI implementation on DUE: Now it honors the selected speed passed to spiInit(). This allows much faster SDCARD access, improving SDCARD menus and reducing latency * Update u8g_dev_st7920_128_64_sw_spi.cpp * Disabling EEPROM over FLASH emulatiion if an I2C or SPI EEPROM is present
62 lines
1.2 KiB
C++
62 lines
1.2 KiB
C++
#ifdef ARDUINO_ARCH_SAM
|
|
|
|
#include "../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) {
|
|
do {
|
|
uint8_t c = eeprom_read_byte((unsigned char*)pos);
|
|
*value = c;
|
|
crc16(crc, &c, 1);
|
|
pos++;
|
|
value++;
|
|
} while (--size);
|
|
return false;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
#endif // EEPROM_SETTINGS
|
|
#endif // __AVR__
|