2 * Definitions for building a device tree by calling into the
5 * Copyright (C) 2010 Andres Salomon <dilinger@queued.net>
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version
10 * 2 of the License, or (at your option) any later version.
13 #ifndef _LINUX_OF_PDT_H
14 #define _LINUX_OF_PDT_H
16 /* overridable operations for calling into the PROM */
19 * buf should be 32 bytes; return 0 on success.
20 * If prev is NULL, the first property will be returned.
22 int (*nextprop)(phandle node, char *prev, char *buf);
24 /* for both functions, return proplen on success; -1 on error */
25 int (*getproplen)(phandle node, const char *prop);
26 int (*getproperty)(phandle node, const char *prop, char *buf,
29 /* phandles are 0 if no child or sibling exists */
30 phandle (*getchild)(phandle parent);
31 phandle (*getsibling)(phandle node);
33 /* return 0 on success; fill in 'len' with number of bytes in path */
34 int (*pkg2path)(phandle node, char *buf, const int buflen, int *len);
37 extern void *prom_early_alloc(unsigned long size);
39 /* for building the device tree */
40 extern void of_pdt_build_devicetree(phandle root_node, struct of_pdt_ops *ops);
42 extern void (*of_pdt_build_more)(struct device_node *dp,
43 struct device_node ***nextp);
45 #endif /* _LINUX_OF_PDT_H */