Blame view

include/linux/of_fdt.h 4.62 KB
d8678b587   Grant Likely   of: add common he...
1
2
3
4
5
6
7
8
9
10
11
12
13
  /*
   * Definitions for working with the Flattened Device Tree data format
   *
   * Copyright 2009 Benjamin Herrenschmidt, IBM Corp
   * benh@kernel.crashing.org
   *
   * This program is free software; you can redistribute it and/or
   * modify it under the terms of the GNU General Public License
   * version 2 as published by the Free Software Foundation.
   */
  
  #ifndef _LINUX_OF_FDT_H
  #define _LINUX_OF_FDT_H
8482f5680   Grant Likely   of: merge of_*_fl...
14
15
  #include <linux/types.h>
  #include <linux/init.h>
d8678b587   Grant Likely   of: add common he...
16
17
18
19
20
21
22
23
24
25
  /* Definitions used by the flattened device tree */
  #define OF_DT_HEADER		0xd00dfeed	/* marker */
  #define OF_DT_BEGIN_NODE	0x1		/* Start of node, full name */
  #define OF_DT_END_NODE		0x2		/* End node */
  #define OF_DT_PROP		0x3		/* Property: name off, size,
  						 * content */
  #define OF_DT_NOP		0x4		/* nop */
  #define OF_DT_END		0x9
  
  #define OF_DT_VERSION		0x10
d45d94f67   Grant Likely   of: merge struct ...
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
  #ifndef __ASSEMBLY__
  /*
   * This is what gets passed to the kernel by prom_init or kexec
   *
   * The dt struct contains the device tree structure, full pathes and
   * property contents. The dt strings contain a separate block with just
   * the strings for the property names, and is fully page aligned and
   * self contained in a page, so that it can be kept around by the kernel,
   * each property name appears only once in this page (cheap compression)
   *
   * the mem_rsvmap contains a map of reserved ranges of physical memory,
   * passing it here instead of in the device-tree itself greatly simplifies
   * the job of everybody. It's just a list of u64 pairs (base/size) that
   * ends when size is 0
   */
  struct boot_param_header {
087f79c48   Jeremy Kerr   of/flattree: endi...
42
43
44
45
46
47
48
  	__be32	magic;			/* magic word OF_DT_HEADER */
  	__be32	totalsize;		/* total size of DT block */
  	__be32	off_dt_struct;		/* offset to structure */
  	__be32	off_dt_strings;		/* offset to strings */
  	__be32	off_mem_rsvmap;		/* offset to memory reserve map */
  	__be32	version;		/* format version */
  	__be32	last_comp_version;	/* last compatible version */
d45d94f67   Grant Likely   of: merge struct ...
49
  	/* version 2 fields below */
087f79c48   Jeremy Kerr   of/flattree: endi...
50
  	__be32	boot_cpuid_phys;	/* Physical CPU id we're booting on */
d45d94f67   Grant Likely   of: merge struct ...
51
  	/* version 3 fields below */
087f79c48   Jeremy Kerr   of/flattree: endi...
52
  	__be32	dt_strings_size;	/* size of the DT strings block */
d45d94f67   Grant Likely   of: merge struct ...
53
  	/* version 17 fields below */
087f79c48   Jeremy Kerr   of/flattree: endi...
54
  	__be32	dt_struct_size;		/* size of the DT structure block */
d45d94f67   Grant Likely   of: merge struct ...
55
  };
cf32eb89c   Grant Likely   of/flattree: make...
56
  #if defined(CONFIG_OF_FLATTREE)
9706a36e3   Stephen Neuendorffer   of/flattree: Add ...
57

a08174873   Grant Likely   of/flattree: forw...
58
  struct device_node;
9706a36e3   Stephen Neuendorffer   of/flattree: Add ...
59
60
61
62
63
64
65
66
67
  /* For scanning an arbitrary device-tree at any time */
  extern char *of_fdt_get_string(struct boot_param_header *blob, u32 offset);
  extern void *of_fdt_get_property(struct boot_param_header *blob,
  				 unsigned long node,
  				 const char *name,
  				 unsigned long *size);
  extern int of_fdt_is_compatible(struct boot_param_header *blob,
  				unsigned long node,
  				const char *compat);
a4f740cf3   Grant Likely   of/flattree: Add ...
68
  extern int of_fdt_match(struct boot_param_header *blob, unsigned long node,
7b482c836   Uwe Kleine-König   ARM/of: allow *ma...
69
  			const char *const *compat);
fe1404235   Stephen Neuendorffer   of/flattree: Refa...
70
71
  extern void of_fdt_unflatten_tree(unsigned long *blob,
  			       struct device_node **mynodes);
9706a36e3   Stephen Neuendorffer   of/flattree: Add ...
72

e169cfbef   Grant Likely   of/flattree: merg...
73
  /* TBD: Temporary export of fdt globals - remove when code fully merged */
f00abd949   Grant Likely   of/flattree: Merg...
74
75
  extern int __initdata dt_root_addr_cells;
  extern int __initdata dt_root_size_cells;
e169cfbef   Grant Likely   of/flattree: merg...
76
  extern struct boot_param_header *initial_boot_params;
8482f5680   Grant Likely   of: merge of_*_fl...
77
  /* For scanning the flat device-tree at boot time */
e169cfbef   Grant Likely   of/flattree: merg...
78
  extern char *find_flat_dt_string(u32 offset);
31a6a87df   Grant Likely   of/flattree: remo...
79
80
81
82
83
84
  extern int of_scan_flat_dt(int (*it)(unsigned long node, const char *uname,
  				     int depth, void *data),
  			   void *data);
  extern void *of_get_flat_dt_prop(unsigned long node, const char *name,
  				 unsigned long *size);
  extern int of_flat_dt_is_compatible(unsigned long node, const char *name);
7b482c836   Uwe Kleine-König   ARM/of: allow *ma...
85
  extern int of_flat_dt_match(unsigned long node, const char *const *matches);
31a6a87df   Grant Likely   of/flattree: remo...
86
  extern unsigned long of_get_flat_dt_root(void);
32c97689c   Grant Likely   of/flattree: Elim...
87

86e032213   Grant Likely   of/flattree: merg...
88
89
  extern int early_init_dt_scan_chosen(unsigned long node, const char *uname,
  				     int depth, void *data);
f7b3a8355   Grant Likely   of/flattree: Merg...
90
  extern void early_init_dt_check_for_initrd(unsigned long node);
51975db0b   Grant Likely   of/flattree: merg...
91
92
93
  extern int early_init_dt_scan_memory(unsigned long node, const char *uname,
  				     int depth, void *data);
  extern void early_init_dt_add_memory_arch(u64 base, u64 size);
fe55c1844   Grant Likely   Revert "dt: add o...
94
  extern void * early_init_dt_alloc_memory_arch(u64 size, u64 align);
2e89e685a   Jeremy Kerr   of: use __be32 fo...
95
  extern u64 dt_mem_next_cell(int s, __be32 **cellp);
8482f5680   Grant Likely   of: merge of_*_fl...
96

1406bc2f5   Jeremy Kerr   of/flattree: use ...
97
98
99
100
101
102
103
104
105
  /*
   * If BLK_DEV_INITRD, the fdt early init code will call this function,
   * to be provided by the arch code. start and end are specified as
   * physical addresses.
   */
  #ifdef CONFIG_BLK_DEV_INITRD
  extern void early_init_dt_setup_initrd_arch(unsigned long start,
  					    unsigned long end);
  #endif
f00abd949   Grant Likely   of/flattree: Merg...
106
107
108
  /* Early flat tree scan hooks */
  extern int early_init_dt_scan_root(unsigned long node, const char *uname,
  				   int depth, void *data);
82b2928c9   Grant Likely   of: merge other m...
109
  /* Other Prototypes */
82b2928c9   Grant Likely   of: merge other m...
110
111
  extern void unflatten_device_tree(void);
  extern void early_init_devtree(void *);
8bfe9b5c3   Grant Likely   of/flattree: Make...
112
113
  #else /* CONFIG_OF_FLATTREE */
  static inline void unflatten_device_tree(void) {}
cf32eb89c   Grant Likely   of/flattree: make...
114
  #endif /* CONFIG_OF_FLATTREE */
82b2928c9   Grant Likely   of: merge other m...
115

d45d94f67   Grant Likely   of: merge struct ...
116
  #endif /* __ASSEMBLY__ */
d8678b587   Grant Likely   of: add common he...
117
  #endif /* _LINUX_OF_FDT_H */