Partition.cpp 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /*
  2. * SPDX-FileCopyrightText: 2015-2023 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #include "esp_log.h"
  7. #include "Partition.h"
  8. #include <inttypes.h>
  9. static const char *TAG = "wl_partition";
  10. Partition::Partition(const esp_partition_t *partition)
  11. {
  12. this->partition = partition;
  13. }
  14. size_t Partition::get_flash_size()
  15. {
  16. return this->partition->size;
  17. }
  18. esp_err_t Partition::erase_sector(size_t sector)
  19. {
  20. esp_err_t result = ESP_OK;
  21. result = erase_range(sector * SPI_FLASH_SEC_SIZE, SPI_FLASH_SEC_SIZE);
  22. return result;
  23. }
  24. esp_err_t Partition::erase_range(size_t start_address, size_t size)
  25. {
  26. esp_err_t result = esp_partition_erase_range(this->partition, start_address, size);
  27. if (result == ESP_OK) {
  28. ESP_LOGV(TAG, "erase_range - start_address=0x%08" PRIx32 ", size=0x%08" PRIx32 ", result=0x%08x", (uint32_t) start_address, (uint32_t) size, result);
  29. } else {
  30. ESP_LOGE(TAG, "erase_range - start_address=0x%08" PRIx32 ", size=0x%08" PRIx32 ", result=0x%08x", (uint32_t) start_address, (uint32_t) size, result);
  31. }
  32. return result;
  33. }
  34. esp_err_t Partition::write(size_t dest_addr, const void *src, size_t size)
  35. {
  36. esp_err_t result = ESP_OK;
  37. result = esp_partition_write(this->partition, dest_addr, src, size);
  38. return result;
  39. }
  40. esp_err_t Partition::read(size_t src_addr, void *dest, size_t size)
  41. {
  42. esp_err_t result = ESP_OK;
  43. result = esp_partition_read(this->partition, src_addr, dest, size);
  44. return result;
  45. }
  46. size_t Partition::get_sector_size()
  47. {
  48. return SPI_FLASH_SEC_SIZE;
  49. }
  50. bool Partition::is_readonly()
  51. {
  52. return this->partition->readonly;
  53. }
  54. Partition::~Partition()
  55. {
  56. }