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.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /**
  2. * Marlin 3D Printer Firmware
  3. * Copyright (C) 2019 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. uint8_t buffer[E2END];
  28. char filename[] = "eeprom.dat";
  29. bool PersistentStore::access_start() {
  30. const char eeprom_erase_value = 0xFF;
  31. FILE * eeprom_file = fopen(filename, "rb");
  32. if (eeprom_file == NULL) return false;
  33. fseek(eeprom_file, 0L, SEEK_END);
  34. std::size_t file_size = ftell(eeprom_file);
  35. if (file_size < E2END) {
  36. memset(buffer + file_size, eeprom_erase_value, E2END - file_size);
  37. }
  38. else {
  39. fseek(eeprom_file, 0L, SEEK_SET);
  40. fread(buffer, sizeof(uint8_t), sizeof(buffer), eeprom_file);
  41. }
  42. fclose(eeprom_file);
  43. return true;
  44. }
  45. bool PersistentStore::access_finish() {
  46. FILE * eeprom_file = fopen(filename, "wb");
  47. if (eeprom_file == NULL) return false;
  48. fwrite(buffer, sizeof(uint8_t), sizeof(buffer), eeprom_file);
  49. fclose(eeprom_file);
  50. return true;
  51. }
  52. bool PersistentStore::write_data(int &pos, const uint8_t *value, const size_t size, uint16_t *crc) {
  53. std::size_t bytes_written = 0;
  54. for (std::size_t i = 0; i < size; i++) {
  55. buffer[pos+i] = value[i];
  56. bytes_written ++;
  57. }
  58. crc16(crc, value, size);
  59. pos = pos + size;
  60. return (bytes_written != size); // return true for any error
  61. }
  62. bool PersistentStore::read_data(int &pos, uint8_t* value, const size_t size, uint16_t *crc, const bool writing/*=true*/) {
  63. std::size_t bytes_read = 0;
  64. if (writing) {
  65. for (std::size_t i = 0; i < size; i++) {
  66. value[i] = buffer[pos+i];
  67. bytes_read ++;
  68. }
  69. crc16(crc, value, size);
  70. }
  71. else {
  72. uint8_t temp[size];
  73. for (std::size_t i = 0; i < size; i++) {
  74. temp[i] = buffer[pos+i];
  75. bytes_read ++;
  76. }
  77. crc16(crc, temp, size);
  78. }
  79. pos = pos + size;
  80. return bytes_read != size; // return true for any error
  81. }
  82. size_t PersistentStore::capacity() { return 4096; } // 4KiB of Emulated EEPROM
  83. #endif // EEPROM_SETTINGS
  84. #endif // __PLAT_LINUX__