My Marlin configs for Fabrikator Mini and CTC i3 Pro B
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

persistent_store_impl.cpp 2.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. /**
  2. * Marlin 3D Printer Firmware
  3. * Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
  4. *
  5. * Based on Sprinter and grbl.
  6. * Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
  7. *
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, either version 3 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. *
  21. */
  22. #ifdef __PLAT_LINUX__
  23. #include "../../inc/MarlinConfig.h"
  24. #if ENABLED(EEPROM_SETTINGS)
  25. #include "../shared/persistent_store_api.h"
  26. #include <stdio.h>
  27. #define LINUX_EEPROM_SIZE (E2END + 1)
  28. uint8_t buffer[LINUX_EEPROM_SIZE];
  29. char filename[] = "eeprom.dat";
  30. bool PersistentStore::access_start() {
  31. const char eeprom_erase_value = 0xFF;
  32. FILE * eeprom_file = fopen(filename, "rb");
  33. if (eeprom_file == nullptr) return false;
  34. fseek(eeprom_file, 0L, SEEK_END);
  35. std::size_t file_size = ftell(eeprom_file);
  36. if (file_size < LINUX_EEPROM_SIZE) {
  37. memset(buffer + file_size, eeprom_erase_value, LINUX_EEPROM_SIZE - file_size);
  38. }
  39. else {
  40. fseek(eeprom_file, 0L, SEEK_SET);
  41. fread(buffer, sizeof(uint8_t), sizeof(buffer), eeprom_file);
  42. }
  43. fclose(eeprom_file);
  44. return true;
  45. }
  46. bool PersistentStore::access_finish() {
  47. FILE * eeprom_file = fopen(filename, "wb");
  48. if (eeprom_file == nullptr) return false;
  49. fwrite(buffer, sizeof(uint8_t), sizeof(buffer), eeprom_file);
  50. fclose(eeprom_file);
  51. return true;
  52. }
  53. bool PersistentStore::write_data(int &pos, const uint8_t *value, size_t size, uint16_t *crc) {
  54. std::size_t bytes_written = 0;
  55. for (std::size_t i = 0; i < size; i++) {
  56. buffer[pos+i] = value[i];
  57. bytes_written ++;
  58. }
  59. crc16(crc, value, size);
  60. pos = pos + size;
  61. return (bytes_written != size); // return true for any error
  62. }
  63. bool PersistentStore::read_data(int &pos, uint8_t* value, const size_t size, uint16_t *crc, const bool writing/*=true*/) {
  64. std::size_t bytes_read = 0;
  65. if (writing) {
  66. for (std::size_t i = 0; i < size; i++) {
  67. value[i] = buffer[pos+i];
  68. bytes_read ++;
  69. }
  70. crc16(crc, value, size);
  71. }
  72. else {
  73. uint8_t temp[size];
  74. for (std::size_t i = 0; i < size; i++) {
  75. temp[i] = buffer[pos+i];
  76. bytes_read ++;
  77. }
  78. crc16(crc, temp, size);
  79. }
  80. pos = pos + size;
  81. return bytes_read != size; // return true for any error
  82. }
  83. size_t PersistentStore::capacity() { return 4096; } // 4KiB of Emulated EEPROM
  84. #endif // EEPROM_SETTINGS
  85. #endif // __PLAT_LINUX__