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