rom_layout.h 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /*
  2. * SPDX-FileCopyrightText: 2020-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_WIFI 1
  12. #define SUPPORT_BTDM 1
  13. #define SUPPORT_USB_DWCOTG 1
  14. /* Structure and functions for returning ROM global layout
  15. *
  16. * This is for address symbols defined in the linker script, which may change during ECOs.
  17. */
  18. typedef struct {
  19. void *dram0_stack_shared_mem_start;
  20. void *dram0_rtos_reserved_start;
  21. void *stack_sentry;
  22. void *stack;
  23. void *stack_sentry_app;
  24. void *stack_app;
  25. /* BTDM data */
  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_end_btdm_rom;
  33. void *data_start_interface_btdm;
  34. void *data_end_interface_btdm;
  35. void *bss_start_interface_btdm;
  36. void *bss_end_interface_btdm;
  37. #endif
  38. /* Other DRAM ranges */
  39. #if SUPPORT_BTDM || SUPPORT_WIFI
  40. void *dram_start_phyrom;
  41. void *dram_end_phyrom;
  42. #endif
  43. #if SUPPORT_WIFI
  44. void *dram_start_coexist;
  45. void *dram_end_coexist;
  46. void *dram_start_net80211;
  47. void *dram_end_net80211;
  48. void *dram_start_pp;
  49. void *dram_end_pp;
  50. void *data_start_interface_coexist;
  51. void *data_end_interface_coexist;
  52. void *bss_start_interface_coexist;
  53. void *bss_end_interface_coexist;
  54. void *data_start_interface_net80211;
  55. void *data_end_interface_net80211;
  56. void *bss_start_interface_net80211;
  57. void *bss_end_interface_net80211;
  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_USB_DWCOTG
  64. void *dram_start_usb_dwcotg_rom;
  65. void *dram_end_usb_dwcotg_rom;
  66. #else
  67. //Two reserved members are defined here, so the structure will not be broken,
  68. //please keep in mind that there is no memory can be released between
  69. //dram_start_usb_reserved_rom ~ dram_end_usb_reserved_rom.
  70. void *dram_start_usb_reserved_rom;
  71. void *dram_end_usb_reserved_rom;
  72. #endif
  73. void *dram_start_uart_rom;
  74. void *dram_end_uart_rom;
  75. } ets_rom_layout_t;
  76. extern const ets_rom_layout_t * const ets_rom_layout_p;
  77. #ifdef __cplusplus
  78. }
  79. #endif