test_malloc.c 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /*
  2. Generic test for malloc/free
  3. */
  4. #include <esp_types.h>
  5. #include <stdio.h>
  6. #include "rom/ets_sys.h"
  7. #include "freertos/FreeRTOS.h"
  8. #include "freertos/task.h"
  9. #include "freertos/semphr.h"
  10. #include "freertos/queue.h"
  11. #include "freertos/xtensa_api.h"
  12. #include "unity.h"
  13. #include "soc/uart_reg.h"
  14. #include "soc/dport_reg.h"
  15. #include "soc/io_mux_reg.h"
  16. static int tryAllocMem() {
  17. int **mem;
  18. int i, noAllocated, j;
  19. mem=malloc(sizeof(int)*1024);
  20. if (!mem) return 0;
  21. for (i=0; i<1024; i++) {
  22. mem[i]=malloc(1024);
  23. if (mem[i]==NULL) break;
  24. for (j=0; j<1024/4; j++) mem[i][j]=(0xdeadbeef);
  25. }
  26. noAllocated=i;
  27. for (i=0; i<noAllocated; i++) {
  28. for (j=0; j<1024/4; j++) {
  29. TEST_ASSERT(mem[i][j]==(0xdeadbeef));
  30. }
  31. free(mem[i]);
  32. }
  33. free(mem);
  34. return noAllocated;
  35. }
  36. TEST_CASE("Malloc/overwrite, then free all available DRAM", "[freertos]")
  37. {
  38. int m1=0, m2=0;
  39. m1=tryAllocMem();
  40. m2=tryAllocMem();
  41. printf("Could allocate %dK on first try, %dK on 2nd try.\n", m1, m2);
  42. TEST_ASSERT(m1==m2);
  43. }