2005-10-06 12:06:20 +10:00
# ifndef _POWERPC_PROM_H
# define _POWERPC_PROM_H
# ifdef __KERNEL__
/*
* Definitions for talking to the Open Firmware PROM on
* Power Macintosh computers .
*
* Copyright ( C ) 1996 - 2005 Paul Mackerras .
*
* Updates for PPC64 by Peter Bergner & David Engebretsen , IBM Corp .
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation ; either version
* 2 of the License , or ( at your option ) any later version .
*/
2005-10-14 14:51:42 +10:00
# include <linux/config.h>
2005-10-06 12:06:20 +10:00
# include <linux/types.h>
# include <linux/proc_fs.h>
# include <asm/atomic.h>
/* 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
/*
* 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
{
u32 magic ; /* magic word OF_DT_HEADER */
u32 totalsize ; /* total size of DT block */
u32 off_dt_struct ; /* offset to structure */
u32 off_dt_strings ; /* offset to strings */
u32 off_mem_rsvmap ; /* offset to memory reserve map */
u32 version ; /* format version */
u32 last_comp_version ; /* last compatible version */
/* version 2 fields below */
u32 boot_cpuid_phys ; /* Physical CPU id we're booting on */
/* version 3 fields below */
u32 dt_strings_size ; /* size of the DT strings block */
} ;
typedef u32 phandle ;
typedef u32 ihandle ;
struct interrupt_info {
int line ;
int sense ; /* +ve/-ve logic, edge or level, etc. */
} ;
struct property {
char * name ;
int length ;
unsigned char * value ;
struct property * next ;
} ;
struct device_node {
char * name ;
char * type ;
phandle node ;
phandle linux_phandle ;
int n_intrs ;
struct interrupt_info * intrs ;
char * full_name ;
struct property * properties ;
2006-01-12 16:08:27 -06:00
struct property * deadprops ; /* removed properties */
2005-10-06 12:06:20 +10:00
struct device_node * parent ;
struct device_node * child ;
struct device_node * sibling ;
struct device_node * next ; /* next device of same type */
struct device_node * allnext ; /* next in list of all nodes */
struct proc_dir_entry * pde ; /* this node's proc directory */
struct kref kref ;
unsigned long _flags ;
void * data ;
} ;
extern struct device_node * of_chosen ;
/* flag descriptions */
# define OF_DYNAMIC 1 /* node and properties were allocated via kmalloc */
# define OF_IS_DYNAMIC(x) test_bit(OF_DYNAMIC, &x->_flags)
# define OF_MARK_DYNAMIC(x) set_bit(OF_DYNAMIC, &x->_flags)
# define HAVE_ARCH_DEVTREE_FIXUPS
static inline void set_node_proc_entry ( struct device_node * dn , struct proc_dir_entry * de )
{
dn - > pde = de ;
}
/* OBSOLETE: Old style node lookup */
2005-10-27 16:45:29 +10:00
extern struct device_node * find_devices ( const char * name ) ;
extern struct device_node * find_type_devices ( const char * type ) ;
extern struct device_node * find_path_device ( const char * path ) ;
extern struct device_node * find_compatible_devices ( const char * type ,
2005-10-06 12:06:20 +10:00
const char * compat ) ;
2005-10-27 16:45:29 +10:00
extern struct device_node * find_all_nodes ( void ) ;
2005-10-06 12:06:20 +10:00
/* New style node lookup */
extern struct device_node * of_find_node_by_name ( struct device_node * from ,
const char * name ) ;
2006-03-08 16:47:00 +01:00
# define for_each_node_by_name(dn, name) \
for ( dn = of_find_node_by_name ( NULL , name ) ; dn ; \
dn = of_find_node_by_name ( dn , name ) )
2005-10-06 12:06:20 +10:00
extern struct device_node * of_find_node_by_type ( struct device_node * from ,
const char * type ) ;
2006-03-08 16:47:00 +01:00
# define for_each_node_by_type(dn, type) \
for ( dn = of_find_node_by_type ( NULL , type ) ; dn ; \
dn = of_find_node_by_type ( dn , type ) )
2005-10-06 12:06:20 +10:00
extern struct device_node * of_find_compatible_node ( struct device_node * from ,
const char * type , const char * compat ) ;
extern struct device_node * of_find_node_by_path ( const char * path ) ;
extern struct device_node * of_find_node_by_phandle ( phandle handle ) ;
extern struct device_node * of_find_all_nodes ( struct device_node * prev ) ;
extern struct device_node * of_get_parent ( const struct device_node * node ) ;
extern struct device_node * of_get_next_child ( const struct device_node * node ,
struct device_node * prev ) ;
2006-01-12 16:09:29 -06:00
extern struct property * of_find_property ( struct device_node * np ,
const char * name ,
int * lenp ) ;
2005-10-06 12:06:20 +10:00
extern struct device_node * of_node_get ( struct device_node * node ) ;
extern void of_node_put ( struct device_node * node ) ;
2005-11-07 11:06:55 +11:00
/* For scanning the flat device-tree at boot time */
2006-03-28 23:15:54 +11:00
extern int __init of_scan_flat_dt ( int ( * it ) ( unsigned long node ,
const char * uname , int depth ,
void * data ) ,
void * data ) ;
extern void * __init of_get_flat_dt_prop ( unsigned long node , const char * name ,
unsigned long * size ) ;
extern int __init of_flat_dt_is_compatible ( unsigned long node , const char * name ) ;
extern unsigned long __init of_get_flat_dt_root ( void ) ;
2005-11-07 11:06:55 +11:00
2005-10-06 12:06:20 +10:00
/* For updating the device tree at runtime */
extern void of_attach_node ( struct device_node * ) ;
extern void of_detach_node ( const struct device_node * ) ;
/* Other Prototypes */
extern void finish_device_tree ( void ) ;
extern void unflatten_device_tree ( void ) ;
extern void early_init_devtree ( void * ) ;
extern int device_is_compatible ( struct device_node * device , const char * ) ;
extern int machine_is_compatible ( const char * compat ) ;
extern unsigned char * get_property ( struct device_node * node , const char * name ,
int * lenp ) ;
extern void print_properties ( struct device_node * node ) ;
extern int prom_n_addr_cells ( struct device_node * np ) ;
extern int prom_n_size_cells ( struct device_node * np ) ;
extern int prom_n_intr_cells ( struct device_node * np ) ;
extern void prom_get_irq_senses ( unsigned char * senses , int off , int max ) ;
2005-11-07 14:29:02 +11:00
extern int prom_add_property ( struct device_node * np , struct property * prop ) ;
2006-01-12 16:08:27 -06:00
extern int prom_remove_property ( struct device_node * np , struct property * prop ) ;
extern int prom_update_property ( struct device_node * np ,
struct property * newprop ,
struct property * oldprop ) ;
2005-10-06 12:06:20 +10:00
2005-10-10 22:50:37 +10:00
# ifdef CONFIG_PPC32
2005-10-06 12:06:20 +10:00
/*
* PCI < - > OF matching functions
* ( XXX should these be here ? )
*/
struct pci_bus ;
struct pci_dev ;
extern int pci_device_from_OF_node ( struct device_node * node ,
u8 * bus , u8 * devfn ) ;
extern struct device_node * pci_busdev_to_OF_node ( struct pci_bus * , int ) ;
extern struct device_node * pci_device_to_OF_node ( struct pci_dev * ) ;
extern void pci_create_OF_bus_map ( void ) ;
2005-10-10 22:50:37 +10:00
# endif
2005-10-06 12:06:20 +10:00
extern struct resource * request_OF_resource ( struct device_node * node ,
int index , const char * name_postfix ) ;
extern int release_OF_resource ( struct device_node * node , int index ) ;
2005-11-30 16:57:28 +11:00
2005-11-23 17:53:42 +11:00
/*
2005-11-30 16:57:28 +11:00
* OF address retreival & translation
*/
/* Translate an OF address block into a CPU physical address
2005-11-23 17:53:42 +11:00
*/
# define OF_BAD_ADDR ((u64)-1)
extern u64 of_translate_address ( struct device_node * np , u32 * addr ) ;
2005-11-30 16:57:28 +11:00
/* Extract an address from a device, returns the region size and
* the address space flags too . The PCI version uses a BAR number
* instead of an absolute index
*/
extern u32 * of_get_address ( struct device_node * dev , int index ,
u64 * size , unsigned int * flags ) ;
extern u32 * of_get_pci_address ( struct device_node * dev , int bar_no ,
u64 * size , unsigned int * flags ) ;
/* Get an address as a resource. Note that if your address is
* a PIO address , the conversion will fail if the physical address
* can ' t be internally converted to an IO token with
* pci_address_to_pio ( ) , that is because it ' s either called to early
* or it can ' t be matched to any host bridge IO space
*/
extern int of_address_to_resource ( struct device_node * dev , int index ,
struct resource * r ) ;
extern int of_pci_address_to_resource ( struct device_node * dev , int bar ,
struct resource * r ) ;
2005-11-23 17:53:42 +11:00
2006-05-18 18:05:15 +10:00
/* Parse the ibm,dma-window property of an OF node into the busno, phys and
* size parameters .
*/
void of_parse_dma_window ( struct device_node * dn , unsigned char * dma_window_prop ,
unsigned long * busno , unsigned long * phys , unsigned long * size ) ;
2006-02-03 19:05:47 +11:00
extern void kdump_move_device_tree ( void ) ;
2005-10-06 12:06:20 +10:00
# endif /* __KERNEL__ */
# endif /* _POWERPC_PROM_H */