6
6
* SPDX-License-Identifier: Apache-2.0
7
7
*/
8
8
9
- #define DT_DRV_COMPAT fixed_partitions
10
-
11
9
#include <zephyr/device.h>
12
10
#include <zephyr/kernel.h>
13
11
#include <zephyr/storage/flash_map.h>
14
12
15
13
#if CONFIG_FLASH_MAP_LABELS
16
- #define FLASH_AREA_FOO (part ) \
14
+ #define FLASH_AREA_FOO (part , mtd_from_partition ) \
17
15
{.fa_id = DT_FIXED_PARTITION_ID(part), \
18
16
.fa_off = DT_REG_ADDR(part), \
19
- .fa_dev = DEVICE_DT_GET(DT_MTD_FROM_FIXED_PARTITION (part)), \
17
+ .fa_dev = DEVICE_DT_GET(mtd_from_partition (part)), \
20
18
.fa_size = DT_REG_SIZE(part), \
21
19
.fa_label = DT_PROP_OR(part, label, NULL), },
22
20
#else
23
- #define FLASH_AREA_FOO (part ) \
21
+ #define FLASH_AREA_FOO (part , mtd_from_partition ) \
24
22
{.fa_id = DT_FIXED_PARTITION_ID(part), \
25
23
.fa_off = DT_REG_ADDR(part), \
26
- .fa_dev = DEVICE_DT_GET(DT_MTD_FROM_FIXED_PARTITION (part)), \
24
+ .fa_dev = DEVICE_DT_GET(mtd_from_partition (part)), \
27
25
.fa_size = DT_REG_SIZE(part), },
28
26
#endif
29
27
30
28
#define FLASH_AREA_FOOO (part ) \
31
- COND_CODE_1(DT_NODE_HAS_STATUS_OKAY(DT_MTD_FROM_FIXED_PARTITION(part)), \
32
- (FLASH_AREA_FOO(part)), ())
29
+ COND_CODE_1(DT_NODE_HAS_COMPAT(DT_PARENT(part), fixed_partitions), (\
30
+ COND_CODE_1(DT_NODE_HAS_STATUS_OKAY(DT_MTD_FROM_FIXED_PARTITION(part)), \
31
+ (FLASH_AREA_FOO(part, DT_MTD_FROM_FIXED_PARTITION)), ())), ( \
32
+ COND_CODE_1(DT_NODE_HAS_STATUS_OKAY(DT_MTD_FROM_FIXED_SUBPARTITION(part)), \
33
+ (FLASH_AREA_FOO(part, DT_MTD_FROM_FIXED_SUBPARTITION)), ())))
33
34
34
- #define FOREACH_PARTITION (n ) DT_FOREACH_CHILD(DT_DRV_INST(n) , FLASH_AREA_FOOO)
35
+ #define FOREACH_PARTITION (n ) DT_FOREACH_CHILD(n , FLASH_AREA_FOOO)
35
36
36
37
/* We iterate over all compatible 'fixed-partitions' nodes and
37
38
* use DT_FOREACH_CHILD to iterate over all the partitions for that
38
39
* 'fixed-partitions' node. This way we build a global partition map
39
40
*/
40
41
const struct flash_area default_flash_map [] = {
41
- DT_INST_FOREACH_STATUS_OKAY ( FOREACH_PARTITION )
42
+ DT_FOREACH_STATUS_OKAY ( fixed_partitions , FOREACH_PARTITION )
42
43
};
43
44
44
45
const int flash_map_entries = ARRAY_SIZE (default_flash_map );
@@ -61,3 +62,18 @@ const struct flash_area *flash_map = default_flash_map;
61
62
62
63
#define FOR_EACH_PARTITION_TABLE (table ) DT_FOREACH_CHILD(table, DEFINE_PARTITION)
63
64
DT_FOREACH_STATUS_OKAY (fixed_partitions , FOR_EACH_PARTITION_TABLE )
65
+
66
+ #define DEFINE_SUB_PARTITION (part ) DEFINE_SUB_PARTITION_1(part, DT_DEP_ORD(part))
67
+ #define DEFINE_SUB_PARTITION_1 (part , ord ) \
68
+ COND_CODE_1(DT_NODE_HAS_STATUS_OKAY(DT_MTD_FROM_FIXED_SUBPARTITION(part)), \
69
+ (DEFINE_SUB_PARTITION_0(part, ord)), ())
70
+ #define DEFINE_SUB_PARTITION_0 (part , ord ) \
71
+ const struct flash_area DT_CAT(global_fixed_subpartition_ORD_, ord) = { \
72
+ .fa_id = DT_FIXED_PARTITION_ID(part), \
73
+ .fa_off = DT_REG_ADDR(part), \
74
+ .fa_dev = DEVICE_DT_GET(DT_MTD_FROM_FIXED_SUBPARTITION(part)), \
75
+ .fa_size = DT_REG_SIZE(part), \
76
+ };
77
+
78
+ #define FOR_EACH_SUB_PARTITION_TABLE (table ) DT_FOREACH_CHILD(table, DEFINE_SUB_PARTITION)
79
+ DT_FOREACH_STATUS_OKAY (fixed_subpartitions , FOR_EACH_SUB_PARTITION_TABLE )
0 commit comments