rom_layout.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. /*
  2. * SPDX-FileCopyrightText: 2022-2023 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #pragma once
  7. #include <stdint.h>
  8. #ifdef __cplusplus
  9. extern "C" {
  10. #endif
  11. #define SUPPORT_BTDM 0
  12. #define SUPPORT_BTBB 0
  13. #define SUPPORT_WIFI 1
  14. #define SUPPORT_USB_DWCOTG 0
  15. #define SUPPORT_COEXIST 1
  16. #define SUPPORT_MBEDTLS 0
  17. /* Structure and functions for returning ROM global layout
  18. *
  19. * This is for address symbols defined in the linker script, which may change during ECOs.
  20. */
  21. typedef struct {
  22. void *dram0_stack_shared_mem_start;
  23. void *dram0_rtos_reserved_start;
  24. void *stack_sentry;
  25. void *stack;
  26. #if SUPPORT_BTDM
  27. void *data_start_btdm;
  28. void *data_end_btdm;
  29. void *bss_start_btdm;
  30. void *bss_end_btdm;
  31. void *data_start_btdm_rom;
  32. void *data_start_interface_btdm;
  33. void *data_end_interface_btdm;
  34. void *bss_start_interface_btdm;
  35. void *bss_end_interface_btdm;
  36. #endif
  37. #if SUPPORT_BTBB
  38. void *dram_start_btbbrom;
  39. void *dram_end_btbbrom;
  40. #endif
  41. #if SUPPORT_BTDM || SUPPORT_WIFI
  42. void *dram_start_phyrom;
  43. void *dram_end_phyrom;
  44. #endif
  45. #if SUPPORT_WIFI
  46. void *dram_start_net80211;
  47. void *dram_end_net80211;
  48. void *data_start_interface_net80211;
  49. void *data_end_interface_net80211;
  50. void *bss_start_interface_net80211;
  51. void *bss_end_interface_net80211;
  52. void *dram_start_pp;
  53. void *dram_end_pp;
  54. void *data_start_interface_pp;
  55. void *data_end_interface_pp;
  56. void *bss_start_interface_pp;
  57. void *bss_end_interface_pp;
  58. #endif
  59. #if SUPPORT_COEXIST
  60. void *dram_start_coexist;
  61. void *dram_end_coexist;
  62. void *data_start_interface_coexist;
  63. void *data_end_interface_coexist;
  64. void *bss_start_interface_coexist;
  65. void *bss_end_interface_coexist;
  66. #endif
  67. #if SUPPORT_MBEDTLS
  68. void *dram_start_mbedtls_rom;
  69. void *dram_end_mbedtls_rom;
  70. #endif
  71. #if SUPPORT_USB_DWCOTG
  72. void *dram_start_usb_dwcotg_rom;
  73. void *dram_end_usb_dwcotg_rom;
  74. #else
  75. //Two reserved members are defined here, so the structure will not be broken,
  76. //please keep in mind that there is no memory can be released between
  77. //dram_start_usb_reserved_rom ~ dram_end_usb_reserved_rom.
  78. void *dram_start_usb_reserved_rom;
  79. void *dram_end_usb_reserved_rom;
  80. #endif
  81. void *dram_start_uart_rom;
  82. void *dram_end_uart_rom;
  83. } ets_rom_layout_t;
  84. extern const ets_rom_layout_t *const ets_rom_layout_p;
  85. #ifdef __cplusplus
  86. }
  87. #endif