rom_layout.h 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * SPDX-FileCopyrightText: 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 0
  14. #define SUPPORT_USB_DWCOTG 1
  15. #define SUPPORT_COEXIST 0
  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 (CORE_NUM == 2)
  27. void *stack_sentry_app;
  28. void *stack_app;
  29. #endif
  30. #if SUPPORT_BTDM
  31. void *data_start_btdm;
  32. void *data_end_btdm;
  33. void *bss_start_btdm;
  34. void *bss_end_btdm;
  35. void *data_start_btdm_rom;
  36. void *data_start_interface_btdm;
  37. void *data_end_interface_btdm;
  38. void *bss_start_interface_btdm;
  39. void *bss_end_interface_btdm;
  40. #endif
  41. #if SUPPORT_BTBB
  42. void *dram_start_btbbrom;
  43. void *dram_end_btbbrom;
  44. #endif
  45. #if SUPPORT_BTDM || SUPPORT_WIFI
  46. void *dram_start_phyrom;
  47. void *dram_end_phyrom;
  48. #endif
  49. #if SUPPORT_WIFI
  50. void *dram_start_net80211;
  51. void *dram_end_net80211;
  52. void *data_start_interface_net80211;
  53. void *data_end_interface_net80211;
  54. void *bss_start_interface_net80211;
  55. void *bss_end_interface_net80211;
  56. void *dram_start_pp;
  57. void *dram_end_pp;
  58. void *data_start_interface_pp;
  59. void *data_end_interface_pp;
  60. void *bss_start_interface_pp;
  61. void *bss_end_interface_pp;
  62. #endif
  63. #if SUPPORT_COEXIST
  64. void *dram_start_coexist;
  65. void *dram_end_coexist;
  66. void *data_start_interface_coexist;
  67. void *data_end_interface_coexist;
  68. void *bss_start_interface_coexist;
  69. void *bss_end_interface_coexist;
  70. #endif
  71. #if SUPPORT_MBEDTLS
  72. void *dram_start_mbedtls_rom;
  73. void *dram_end_mbedtls_rom;
  74. #endif
  75. #if SUPPORT_USB_DWCOTG
  76. void *dram_start_usb_dwcotg_rom;
  77. void *dram_end_usb_dwcotg_rom;
  78. #endif
  79. void *dram_start_uart_rom;
  80. void *dram_end_uart_rom;
  81. } ets_rom_layout_t;
  82. extern const ets_rom_layout_t *const ets_rom_layout_p;
  83. #ifdef __cplusplus
  84. }
  85. #endif