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