⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 prom.h

📁 Linux Kernel 2.6.9 for OMAP1710
💻 H
字号:
#ifndef _PPC64_PROM_H#define _PPC64_PROM_H/* * Definitions for talking to the Open Firmware PROM on * Power Macintosh computers. * * Copyright (C) 1996 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. */#include <linux/proc_fs.h>#include <asm/atomic.h>#define PTRRELOC(x)     ((typeof(x))((unsigned long)(x) - offset))#define PTRUNRELOC(x)   ((typeof(x))((unsigned long)(x) + offset))#define RELOC(x)        (*PTRRELOC(&(x)))#define LONG_LSW(X) (((unsigned long)X) & 0xffffffff)#define LONG_MSW(X) (((unsigned long)X) >> 32)/* Definitions used by the flattened device tree */#define OF_DT_HEADER		0xd00dfeed	/* 4: version, 4: total size */#define OF_DT_BEGIN_NODE	0x1		/* Start node: full name */#define OF_DT_END_NODE		0x2		/* End node */#define OF_DT_PROP		0x3		/* Property: name off, size, content */#define OF_DT_END		0x9#define OF_DT_VERSION		1/* * 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 */};typedef u32 phandle;typedef u32 ihandle;typedef u32 phandle32;typedef u32 ihandle32;struct address_range {	unsigned long space;	unsigned long address;	unsigned long size;};struct interrupt_info {	int	line;	int	sense;		/* +ve/-ve logic, edge or level, etc. */};struct pci_address {	u32 a_hi;	u32 a_mid;	u32 a_lo;};struct isa_address {	u32 a_hi;	u32 a_lo;};struct isa_range {	struct isa_address isa_addr;	struct pci_address pci_addr;	unsigned int size;};struct pci_range32 {	struct pci_address child_addr;	unsigned int  parent_addr;  	unsigned long size; };struct pci_range64 {	struct pci_address child_addr;  	unsigned long parent_addr;        unsigned long size; };union pci_range {	struct {		struct pci_address addr;		u32 phys;		u32 size_hi;	} pci32;	struct {		struct pci_address addr;		u32 phys_hi;		u32 phys_lo;		u32 size_hi;		u32 size_lo;	} pci64;};struct of_tce_table {	phandle node;	unsigned long base;	unsigned long size;};extern struct of_tce_table of_tce_table[];struct reg_property {	unsigned long address;	unsigned long size;};struct reg_property32 {	unsigned int address;	unsigned int size;};struct reg_property64 {	unsigned long address;	unsigned long size;};struct reg_property_pmac {	unsigned int address_hi;	unsigned int address_lo;	unsigned int size;};struct translation_property {	unsigned long virt;	unsigned long size;	unsigned long phys;	unsigned int flags;};struct property {	char	*name;	int	length;	unsigned char *value;	struct property *next;};/* NOTE: the device_node contains PCI specific info for pci devices. * This perhaps could be hung off the device_node with another struct, * but for now it is directly in the node.  The phb ptr is a good * indication of a real PCI node.  Other nodes leave these fields zeroed. */struct pci_controller;struct iommu_table;struct device_node {	char	*name;	char	*type;	phandle	node;	phandle linux_phandle;	int	n_addrs;	struct	address_range *addrs;	int	n_intrs;	struct	interrupt_info *intrs;	char	*full_name;	/* PCI stuff probably doesn't belong here */	int	busno;			/* for pci devices */	int	bussubno;		/* for pci devices */	int	devfn;			/* for pci devices */#define DN_STATUS_BIST_FAILED (1<<0)	int	status;			/* Current device status (non-zero is bad) */	int	eeh_mode;		/* See eeh.h for possible EEH_MODEs */	int	eeh_config_addr;	struct  pci_controller *phb;	/* for pci devices */	struct	iommu_table *iommu_table;	/* for phb's or bridges */	struct	property *properties;	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  proc_dir_entry *name_link; /* name symlink */	struct  proc_dir_entry *addr_link; /* addr symlink */	atomic_t _users;                 /* reference count */	unsigned long _flags;};extern struct device_node *of_chosen;/* flag descriptions */#define OF_STALE   0 /* node is slated for deletion */#define OF_DYNAMIC 1 /* node and properties were allocated via kmalloc */#define OF_IS_STALE(x) test_bit(OF_STALE, &x->_flags)#define OF_MARK_STALE(x) set_bit(OF_STALE, &x->_flags)#define OF_IS_DYNAMIC(x) test_bit(OF_DYNAMIC, &x->_flags)#define OF_MARK_DYNAMIC(x) set_bit(OF_DYNAMIC, &x->_flags)/* * Until 32-bit ppc can add proc_dir_entries to its device_node * definition, we cannot refer to pde, name_link, and addr_link * in arch-independent code. */#define HAVE_ARCH_DEVTREE_FIXUPSstatic inline void set_node_proc_entry(struct device_node *dn, struct proc_dir_entry *de){	dn->pde = de;}static void inline set_node_name_link(struct device_node *dn, struct proc_dir_entry *de){	dn->name_link = de;}static void inline set_node_addr_link(struct device_node *dn, struct proc_dir_entry *de){	dn->addr_link = de;}/* OBSOLETE: Old stlye node lookup */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,						   const char *compat);extern struct device_node *find_all_nodes(void);/* New style node lookup */extern struct device_node *of_find_node_by_name(struct device_node *from,	const char *name);extern struct device_node *of_find_node_by_type(struct device_node *from,	const char *type);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);extern struct device_node *of_node_get(struct device_node *node);extern void of_node_put(struct device_node *node);/* For updating the device tree at runtime */extern int of_add_node(const char *path, struct property *proplist);extern int of_remove_node(struct device_node *np);/* Other Prototypes */extern unsigned long prom_init(unsigned long, unsigned long, unsigned long,	unsigned long, unsigned long);extern void relocate_nodes(void);extern void finish_device_tree(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);extern void prom_add_property(struct device_node* np, struct property* prop);#endif /* _PPC64_PROM_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -