of_platform.h 3.7 KB
Newer Older
S
Stephen Rothwell 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
#ifndef _LINUX_OF_PLATFORM_H
#define _LINUX_OF_PLATFORM_H
/*
 *    Copyright (C) 2006 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
 *  as published by the Free Software Foundation; either version
 *  2 of the License, or (at your option) any later version.
 *
 */

14
#ifdef CONFIG_OF_DEVICE
S
Stephen Rothwell 已提交
15 16 17 18
#include <linux/device.h>
#include <linux/mod_devicetable.h>
#include <linux/pm.h>
#include <linux/of_device.h>
19
#include <linux/platform_device.h>
S
Stephen Rothwell 已提交
20

21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
/**
 * struct of_dev_auxdata - lookup table entry for device names & platform_data
 * @compatible: compatible value of node to match against node
 * @phys_addr: Start address of registers to match against node
 * @name: Name to assign for matching nodes
 * @platform_data: platform_data to assign for matching nodes
 *
 * This lookup table allows the caller of of_platform_populate() to override
 * the names of devices when creating devices from the device tree.  The table
 * should be terminated with an empty entry.  It also allows the platform_data
 * pointer to be set.
 *
 * The reason for this functionality is that some Linux infrastructure uses
 * the device name to look up a specific device, but the Linux-specific names
 * are not encoded into the device tree, so the kernel needs to provide specific
 * values.
 *
 * Note: Using an auxdata lookup table should be considered a last resort when
 * converting a platform to use the DT.  Normally the automatically generated
 * device name will not matter, and drivers should obtain data from the device
 * node instead of from an anonymouns platform_data pointer.
 */
struct of_dev_auxdata {
	char *compatible;
	resource_size_t phys_addr;
	char *name;
	void *platform_data;
};

/* Macro to simplify populating a lookup table */
#define OF_DEV_AUXDATA(_compat,_phys,_name,_pdata) \
	{ .compatible = _compat, .phys_addr = _phys, .name = _name, \
	  .platform_data = _pdata }

55 56 57 58
/**
 * of_platform_driver - Legacy of-aware driver for platform devices.
 *
 * An of_platform_driver driver is attached to a basic platform_device on
59
 * the ibm ebus (ibmebus_bus_type).
S
Stephen Rothwell 已提交
60 61 62
 */
struct of_platform_driver
{
63
	int	(*probe)(struct platform_device* dev,
S
Stephen Rothwell 已提交
64
			 const struct of_device_id *match);
65
	int	(*remove)(struct platform_device* dev);
S
Stephen Rothwell 已提交
66

67 68 69
	int	(*suspend)(struct platform_device* dev, pm_message_t state);
	int	(*resume)(struct platform_device* dev);
	int	(*shutdown)(struct platform_device* dev);
S
Stephen Rothwell 已提交
70 71 72 73 74 75

	struct device_driver	driver;
};
#define	to_of_platform_driver(drv) \
	container_of(drv,struct of_platform_driver, driver)

76 77
extern const struct of_device_id of_default_bus_match_table[];

78
/* Platform drivers register/unregister */
79
extern struct platform_device *of_device_alloc(struct device_node *np,
80 81
					 const char *bus_id,
					 struct device *parent);
82
extern struct platform_device *of_find_device_by_node(struct device_node *np);
S
Stephen Rothwell 已提交
83

84
#ifdef CONFIG_OF_ADDRESS /* device reg helpers depend on OF_ADDRESS */
85
/* Platform devices and busses creation */
86
extern struct platform_device *of_platform_device_create(struct device_node *np,
87 88 89 90 91 92
						   const char *bus_id,
						   struct device *parent);

extern int of_platform_bus_probe(struct device_node *root,
				 const struct of_device_id *matches,
				 struct device *parent);
93 94
extern int of_platform_populate(struct device_node *root,
				const struct of_device_id *matches,
95
				const struct of_dev_auxdata *lookup,
96
				struct device *parent);
97 98 99 100 101 102 103 104 105
#else
static inline int of_platform_populate(struct device_node *root,
					const struct of_device_id *matches,
					const struct of_dev_auxdata *lookup,
					struct device *parent)
{
	return -ENODEV;
}
#endif /* !CONFIG_OF_ADDRESS */
106

107
#endif /* CONFIG_OF_DEVICE */
S
Stephen Rothwell 已提交
108

S
Stephen Rothwell 已提交
109
#endif	/* _LINUX_OF_PLATFORM_H */