1*cd60bc56SAndroid Build Coastguard Worker /* SPDX-License-Identifier: (GPL-2.0-or-later OR BSD-2-Clause) */ 2*cd60bc56SAndroid Build Coastguard Worker #ifndef FDT_H 3*cd60bc56SAndroid Build Coastguard Worker #define FDT_H 4*cd60bc56SAndroid Build Coastguard Worker /* 5*cd60bc56SAndroid Build Coastguard Worker * libfdt - Flat Device Tree manipulation 6*cd60bc56SAndroid Build Coastguard Worker * Copyright (C) 2006 David Gibson, IBM Corporation. 7*cd60bc56SAndroid Build Coastguard Worker * Copyright 2012 Kim Phillips, Freescale Semiconductor. 8*cd60bc56SAndroid Build Coastguard Worker */ 9*cd60bc56SAndroid Build Coastguard Worker 10*cd60bc56SAndroid Build Coastguard Worker #ifndef __ASSEMBLY__ 11*cd60bc56SAndroid Build Coastguard Worker 12*cd60bc56SAndroid Build Coastguard Worker struct fdt_header { 13*cd60bc56SAndroid Build Coastguard Worker fdt32_t magic; /* magic word FDT_MAGIC */ 14*cd60bc56SAndroid Build Coastguard Worker fdt32_t totalsize; /* total size of DT block */ 15*cd60bc56SAndroid Build Coastguard Worker fdt32_t off_dt_struct; /* offset to structure */ 16*cd60bc56SAndroid Build Coastguard Worker fdt32_t off_dt_strings; /* offset to strings */ 17*cd60bc56SAndroid Build Coastguard Worker fdt32_t off_mem_rsvmap; /* offset to memory reserve map */ 18*cd60bc56SAndroid Build Coastguard Worker fdt32_t version; /* format version */ 19*cd60bc56SAndroid Build Coastguard Worker fdt32_t last_comp_version; /* last compatible version */ 20*cd60bc56SAndroid Build Coastguard Worker 21*cd60bc56SAndroid Build Coastguard Worker /* version 2 fields below */ 22*cd60bc56SAndroid Build Coastguard Worker fdt32_t boot_cpuid_phys; /* Which physical CPU id we're 23*cd60bc56SAndroid Build Coastguard Worker booting on */ 24*cd60bc56SAndroid Build Coastguard Worker /* version 3 fields below */ 25*cd60bc56SAndroid Build Coastguard Worker fdt32_t size_dt_strings; /* size of the strings block */ 26*cd60bc56SAndroid Build Coastguard Worker 27*cd60bc56SAndroid Build Coastguard Worker /* version 17 fields below */ 28*cd60bc56SAndroid Build Coastguard Worker fdt32_t size_dt_struct; /* size of the structure block */ 29*cd60bc56SAndroid Build Coastguard Worker }; 30*cd60bc56SAndroid Build Coastguard Worker 31*cd60bc56SAndroid Build Coastguard Worker struct fdt_reserve_entry { 32*cd60bc56SAndroid Build Coastguard Worker fdt64_t address; 33*cd60bc56SAndroid Build Coastguard Worker fdt64_t size; 34*cd60bc56SAndroid Build Coastguard Worker }; 35*cd60bc56SAndroid Build Coastguard Worker 36*cd60bc56SAndroid Build Coastguard Worker struct fdt_node_header { 37*cd60bc56SAndroid Build Coastguard Worker fdt32_t tag; 38*cd60bc56SAndroid Build Coastguard Worker char name[]; 39*cd60bc56SAndroid Build Coastguard Worker }; 40*cd60bc56SAndroid Build Coastguard Worker 41*cd60bc56SAndroid Build Coastguard Worker struct fdt_property { 42*cd60bc56SAndroid Build Coastguard Worker fdt32_t tag; 43*cd60bc56SAndroid Build Coastguard Worker fdt32_t len; 44*cd60bc56SAndroid Build Coastguard Worker fdt32_t nameoff; 45*cd60bc56SAndroid Build Coastguard Worker char data[]; 46*cd60bc56SAndroid Build Coastguard Worker }; 47*cd60bc56SAndroid Build Coastguard Worker 48*cd60bc56SAndroid Build Coastguard Worker #endif /* !__ASSEMBLY */ 49*cd60bc56SAndroid Build Coastguard Worker 50*cd60bc56SAndroid Build Coastguard Worker #define FDT_MAGIC 0xd00dfeed /* 4: version, 4: total size */ 51*cd60bc56SAndroid Build Coastguard Worker #define FDT_TAGSIZE sizeof(fdt32_t) 52*cd60bc56SAndroid Build Coastguard Worker 53*cd60bc56SAndroid Build Coastguard Worker #define FDT_BEGIN_NODE 0x1 /* Start node: full name */ 54*cd60bc56SAndroid Build Coastguard Worker #define FDT_END_NODE 0x2 /* End node */ 55*cd60bc56SAndroid Build Coastguard Worker #define FDT_PROP 0x3 /* Property: name off, 56*cd60bc56SAndroid Build Coastguard Worker size, content */ 57*cd60bc56SAndroid Build Coastguard Worker #define FDT_NOP 0x4 /* nop */ 58*cd60bc56SAndroid Build Coastguard Worker #define FDT_END 0x9 59*cd60bc56SAndroid Build Coastguard Worker 60*cd60bc56SAndroid Build Coastguard Worker #define FDT_V1_SIZE (7*sizeof(fdt32_t)) 61*cd60bc56SAndroid Build Coastguard Worker #define FDT_V2_SIZE (FDT_V1_SIZE + sizeof(fdt32_t)) 62*cd60bc56SAndroid Build Coastguard Worker #define FDT_V3_SIZE (FDT_V2_SIZE + sizeof(fdt32_t)) 63*cd60bc56SAndroid Build Coastguard Worker #define FDT_V16_SIZE FDT_V3_SIZE 64*cd60bc56SAndroid Build Coastguard Worker #define FDT_V17_SIZE (FDT_V16_SIZE + sizeof(fdt32_t)) 65*cd60bc56SAndroid Build Coastguard Worker 66*cd60bc56SAndroid Build Coastguard Worker #endif /* FDT_H */ 67