ota.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. #define MODULE "ota"
  2. #define DEBUG 1
  3. #include "common.h"
  4. #include "fw.h"
  5. #include <esp_ota_ops.h>
  6. #define BUFFER_SIZE 4096
  7. static int esp_err_to_fwupdate(int err)
  8. {
  9. switch (err) {
  10. case ESP_OK:
  11. return Z_OK;
  12. case ESP_ERR_NO_MEM:
  13. return Z_MEM_ERROR;
  14. case ESP_ERR_NOT_FOUND:
  15. return FWUPDATE_ERR_ESP_NO_PARTITION;
  16. case ESP_ERR_INVALID_ARG:
  17. case ESP_ERR_OTA_PARTITION_CONFLICT:
  18. case ESP_ERR_OTA_SELECT_INFO_INVALID:
  19. case ESP_ERR_OTA_ROLLBACK_INVALID_STATE:
  20. return FWUPDATE_ERR_ESP_BAD_OTA;
  21. case ESP_ERR_FLASH_OP_TIMEOUT:
  22. case ESP_ERR_FLASH_OP_FAIL:
  23. return FWUPDATE_ERR_ESP_FLASH_FAILED;
  24. case ESP_ERR_OTA_VALIDATE_FAILED:
  25. return FWUPDATE_ERR_ESP_BAD_DATA;
  26. default:
  27. return FWUPDATE_ERR_UNKNOWN;
  28. }
  29. }
  30. int esp_update(read_func_t read_func, token_t token, size_t size)
  31. {
  32. const esp_partition_t *partition;
  33. int err = ESP_FAIL;
  34. esp_ota_handle_t handle;
  35. bool ota_started = false;
  36. int len;
  37. char *buf = NULL;
  38. buf = malloc(BUFFER_SIZE);
  39. if (!buf) {
  40. err = ESP_ERR_NO_MEM;
  41. goto fail;
  42. }
  43. partition = esp_ota_get_next_update_partition(NULL);
  44. if (!partition) {
  45. err = ESP_ERR_NOT_FOUND;
  46. goto fail;
  47. }
  48. MSG("starting ESP OTA update, total %zu bytes\n", size);
  49. err = esp_ota_begin(partition, size, &handle);
  50. if (err)
  51. goto fail;
  52. ota_started = true;
  53. size_t left = size;
  54. while (left) {
  55. size_t chunk = left;
  56. if (chunk > BUFFER_SIZE)
  57. chunk = BUFFER_SIZE;
  58. len = read_func(token, buf, chunk);
  59. if (len <= 0)
  60. break;
  61. left -= len;
  62. MSG("writing %d bytes, %zu left\r", len, left);
  63. err = esp_ota_write(handle, buf, len);
  64. CMSG("\n");
  65. if (err)
  66. goto fail;
  67. }
  68. if (left) {
  69. MSG("short input data, aborting update\n");
  70. err = ESP_ERR_OTA_VALIDATE_FAILED;
  71. goto fail;
  72. }
  73. MSG("finalizing flash update\n");
  74. err = esp_ota_end(handle);
  75. if (err)
  76. goto fail;
  77. free(buf);
  78. buf = NULL;
  79. MSG("setting boot partition\n");
  80. err = esp_ota_set_boot_partition(partition);
  81. fail:
  82. err = esp_err_to_fwupdate(err);
  83. if (err) {
  84. MSG("failure: error %d\n", err);
  85. if (ota_started)
  86. esp_ota_abort(handle);
  87. }
  88. if (buf)
  89. free(buf);
  90. return err;
  91. }