luat_malloc_idf5.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. // 这个文件包含 系统heap和lua heap的默认实现
  2. #include <stdlib.h>
  3. #include <string.h>//add for memset
  4. #include "bget.h"
  5. #include "luat_malloc.h"
  6. #include "esp_system.h"
  7. #include "esp_attr.h"
  8. #define LUAT_LOG_TAG "vmheap"
  9. #include "luat_log.h"
  10. //-----------------------------------------------------------------------------
  11. #ifndef LUAT_HEAP_SIZE
  12. #if defined(CONFIG_IDF_TARGET_ESP32C3) || defined(CONFIG_IDF_TARGET_ESP32S3)
  13. #if defined(LUAT_USE_NIMBLE) || defined(LUAT_USE_TLS)
  14. #define LUAT_HEAP_SIZE (96*1024)
  15. #else
  16. #define LUAT_HEAP_SIZE (128*1024)
  17. #endif
  18. #elif defined(CONFIG_IDF_TARGET_ESP32C2)
  19. #define LUAT_HEAP_SIZE (68*1024)
  20. #else
  21. #define LUAT_HEAP_SIZE (64*1024)
  22. #endif
  23. #endif // LUAT_HEAP_SIZE
  24. static uint8_t vmheap[LUAT_HEAP_SIZE];
  25. #if LUAT_USE_MEMORY_OPTIMIZATION_CODE_MMAP
  26. static uint32_t heap_addr_start = (uint32_t) vmheap;
  27. static uint32_t heap_addr_end = (uint32_t) vmheap + LUAT_HEAP_SIZE;
  28. #endif
  29. //------------------------------------------------
  30. // 管理系统内存
  31. void* luat_heap_malloc(size_t len) {
  32. return malloc(len);
  33. }
  34. void luat_heap_free(void* ptr) {
  35. free(ptr);
  36. }
  37. void* luat_heap_realloc(void* ptr, size_t len) {
  38. return realloc(ptr, len);
  39. }
  40. void* luat_heap_calloc(size_t count, size_t _size) {
  41. return calloc(count, _size);
  42. }
  43. //------------------------------------------------
  44. //------------------------------------------------
  45. // ---------- 管理 LuaVM所使用的内存----------------
  46. #if 1
  47. void* IRAM_ATTR luat_heap_alloc(void *ud, void *ptr, size_t osize, size_t nsize) {
  48. if (ptr == NULL && nsize == 0)
  49. return NULL;
  50. #if LUAT_USE_MEMORY_OPTIMIZATION_CODE_MMAP
  51. if (ptr != NULL && nsize == 0) {
  52. uint32_t addr = (uint32_t) ptr;
  53. if (addr < heap_addr_start || addr > heap_addr_end) {
  54. //LLOGD("skip ROM free %p", ptr);
  55. return NULL;
  56. }
  57. }
  58. #endif
  59. if (nsize)
  60. {
  61. void* ptmp = bgetr(ptr, nsize);
  62. if(ptmp == NULL && osize >= nsize)
  63. {
  64. return ptr;
  65. }
  66. return ptmp;
  67. }
  68. brel(ptr);
  69. return NULL;
  70. }
  71. void luat_meminfo_luavm(size_t *total, size_t *used, size_t *max_used) {
  72. long curalloc, totfree, maxfree;
  73. unsigned long nget, nrel;
  74. bstats(&curalloc, &totfree, &maxfree, &nget, &nrel);
  75. *used = curalloc;
  76. *max_used = bstatsmaxget();
  77. *total = curalloc + totfree;
  78. }
  79. #else
  80. #include "heap_tlsf.h"
  81. static tlsf_t vm_tlfs;
  82. void* luat_heap_alloc(void *ud, void *ptr, size_t osize, size_t nsize) {
  83. if (ptr == NULL && nsize == 0)
  84. return NULL;
  85. #if LUAT_USE_MEMORY_OPTIMIZATION_CODE_MMAP
  86. if (ptr != NULL && nsize == 0) {
  87. uint32_t addr = (uint32_t) ptr;
  88. if (addr < heap_addr_start || addr > heap_addr_end) {
  89. LLOGD("skip ROM free %p", ptr);
  90. return NULL;
  91. }
  92. }
  93. #endif
  94. return tlsf_realloc(ptr, nsize);
  95. }
  96. void luat_meminfo_luavm(size_t *total, size_t *used, size_t *max_used) {
  97. *total = 0;
  98. *used = 0;
  99. *max_used = 0;
  100. }
  101. #endif
  102. #include "esp_system.h"
  103. #include "esp_heap_caps.h"
  104. #include "esp_psram.h"
  105. void luat_meminfo_sys(size_t *total, size_t *used, size_t *max_used)
  106. {
  107. *total = heap_caps_get_total_size(MALLOC_CAP_DEFAULT);
  108. *used = *total - heap_caps_get_free_size(MALLOC_CAP_DEFAULT);
  109. *max_used = *total - heap_caps_get_minimum_free_size(MALLOC_CAP_DEFAULT);
  110. }
  111. void luat_heap_init(void)
  112. {
  113. #ifdef LUAT_USE_PSRAM
  114. size_t t = esp_psram_get_size();
  115. LLOGD("Found %d kbyte PSRAM", t / 1024);
  116. size_t psram_sz = 0;
  117. #define LUAT_HEAP_PSRAM_SIZE (4 * 1024 * 1024)
  118. if (t > 0)
  119. {
  120. psram_sz = t / 2 ; // 默认占一半
  121. char* ptr = heap_caps_malloc(psram_sz, MALLOC_CAP_SPIRAM);
  122. if (ptr) {
  123. LLOGD("Use %d kbyte PSRAM for Lua VM", t / 1024 / 2);
  124. #if LUAT_USE_MEMORY_OPTIMIZATION_CODE_MMAP
  125. heap_addr_start = (uint32_t)ptr;
  126. heap_addr_end = (uint32_t)ptr + psram_sz;
  127. #endif
  128. bpool(ptr, psram_sz);
  129. }
  130. else {
  131. LLOGE("PSRAM malloc FAILED, fallback to Non-PSRAM mode");
  132. bpool(vmheap, LUAT_HEAP_SIZE);
  133. }
  134. }
  135. else
  136. {
  137. bpool(vmheap, LUAT_HEAP_SIZE);
  138. }
  139. #else
  140. bpool(vmheap, LUAT_HEAP_SIZE);
  141. #endif
  142. // LLOGD("vm heap range %08X %08X", heap_addr_start, heap_addr_end);
  143. }