platform_device.h 7.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14
/*
 * platform_device.h - generic, centralized driver model
 *
 * Copyright (c) 2001-2003 Patrick Mochel <mochel@osdl.org>
 *
 * This file is released under the GPLv2
 *
 * See Documentation/driver-model/ for more information.
 */

#ifndef _PLATFORM_DEVICE_H_
#define _PLATFORM_DEVICE_H_

#include <linux/device.h>
15
#include <linux/mod_devicetable.h>
16

17 18
struct mfd_cell;

19 20
struct platform_device {
	const char	* name;
21
	int		id;
22 23 24
	struct device	dev;
	u32		num_resources;
	struct resource	* resource;
25

26
	const struct platform_device_id	*id_entry;
27

28 29 30
	/* MFD cell pointer */
	struct mfd_cell *mfd_cell;

31 32
	/* arch specific additions */
	struct pdev_archdata	archdata;
33 34
};

35 36
#define platform_get_device_id(pdev)	((pdev)->id_entry)

37 38 39 40 41 42 43 44 45 46
#define to_platform_device(x) container_of((x), struct platform_device, dev)

extern int platform_device_register(struct platform_device *);
extern void platform_device_unregister(struct platform_device *);

extern struct bus_type platform_bus_type;
extern struct device platform_bus;

extern struct resource *platform_get_resource(struct platform_device *, unsigned int, unsigned int);
extern int platform_get_irq(struct platform_device *, unsigned int);
47 48
extern struct resource *platform_get_resource_byname(struct platform_device *, unsigned int, const char *);
extern int platform_get_irq_byname(struct platform_device *, const char *);
49 50
extern int platform_add_devices(struct platform_device **, int);

51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
extern struct platform_device *platform_device_register_resndata(
		struct device *parent, const char *name, int id,
		const struct resource *res, unsigned int num,
		const void *data, size_t size);

/**
 * platform_device_register_simple - add a platform-level device and its resources
 * @name: base name of the device we're adding
 * @id: instance id
 * @res: set of resources that needs to be allocated for the device
 * @num: number of resources
 *
 * This function creates a simple platform device that requires minimal
 * resource and memory management. Canned release function freeing memory
 * allocated for the device allows drivers using such devices to be
 * unloaded without waiting for the last reference to the device to be
 * dropped.
 *
 * This interface is primarily intended for use with legacy drivers which
 * probe hardware directly.  Because such drivers create sysfs device nodes
 * themselves, rather than letting system infrastructure handle such device
 * enumeration tasks, they don't fully conform to the Linux driver model.
 * In particular, when such drivers are built as modules, they can't be
 * "hotplugged".
 *
 * Returns &struct platform_device pointer on success, or ERR_PTR() on error.
 */
static inline struct platform_device *platform_device_register_simple(
		const char *name, int id,
		const struct resource *res, unsigned int num)
{
	return platform_device_register_resndata(NULL, name, id,
			res, num, NULL, 0);
}

/**
 * platform_device_register_data - add a platform-level device with platform-specific data
 * @parent: parent device for the device we're adding
 * @name: base name of the device we're adding
 * @id: instance id
 * @data: platform specific data for this platform device
 * @size: size of platform specific data
 *
 * This function creates a simple platform device that requires minimal
 * resource and memory management. Canned release function freeing memory
 * allocated for the device allows drivers using such devices to be
 * unloaded without waiting for the last reference to the device to be
 * dropped.
 *
 * Returns &struct platform_device pointer on success, or ERR_PTR() on error.
 */
static inline struct platform_device *platform_device_register_data(
		struct device *parent, const char *name, int id,
		const void *data, size_t size)
{
	return platform_device_register_resndata(parent, name, id,
			NULL, 0, data, size);
}
109

110
extern struct platform_device *platform_device_alloc(const char *name, int id);
111 112 113
extern int platform_device_add_resources(struct platform_device *pdev,
					 const struct resource *res,
					 unsigned int num);
114
extern int platform_device_add_data(struct platform_device *pdev, const void *data, size_t size);
115
extern int platform_device_add(struct platform_device *pdev);
116
extern void platform_device_del(struct platform_device *pdev);
117 118
extern void platform_device_put(struct platform_device *pdev);

R
Russell King 已提交
119 120 121 122 123 124 125
struct platform_driver {
	int (*probe)(struct platform_device *);
	int (*remove)(struct platform_device *);
	void (*shutdown)(struct platform_device *);
	int (*suspend)(struct platform_device *, pm_message_t state);
	int (*resume)(struct platform_device *);
	struct device_driver driver;
126
	const struct platform_device_id *id_table;
R
Russell King 已提交
127 128 129 130 131
};

extern int platform_driver_register(struct platform_driver *);
extern void platform_driver_unregister(struct platform_driver *);

132 133 134 135 136 137
/* non-hotpluggable platform devices may use this so that probe() and
 * its support may live in __init sections, conserving runtime memory.
 */
extern int platform_driver_probe(struct platform_driver *driver,
		int (*probe)(struct platform_device *));

138 139 140 141 142 143 144 145 146
static inline void *platform_get_drvdata(const struct platform_device *pdev)
{
	return dev_get_drvdata(&pdev->dev);
}

static inline void platform_set_drvdata(struct platform_device *pdev, void *data)
{
	dev_set_drvdata(&pdev->dev, data);
}
R
Russell King 已提交
147

148 149 150 151 152
extern struct platform_device *platform_create_bundle(struct platform_driver *driver,
					int (*probe)(struct platform_device *),
					struct resource *res, unsigned int n_res,
					const void *data, size_t size);

153 154 155
extern const struct dev_pm_ops * platform_bus_get_pm_ops(void);
extern void platform_bus_set_pm_ops(const struct dev_pm_ops *pm);

M
Magnus Damm 已提交
156 157 158 159 160 161
/* early platform driver interface */
struct early_platform_driver {
	const char *class_str;
	struct platform_driver *pdrv;
	struct list_head list;
	int requested_id;
162 163
	char *buffer;
	int bufsize;
M
Magnus Damm 已提交
164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182
};

#define EARLY_PLATFORM_ID_UNSET -2
#define EARLY_PLATFORM_ID_ERROR -3

extern int early_platform_driver_register(struct early_platform_driver *epdrv,
					  char *buf);
extern void early_platform_add_devices(struct platform_device **devs, int num);

static inline int is_early_platform_device(struct platform_device *pdev)
{
	return !pdev->dev.driver;
}

extern void early_platform_driver_register_all(char *class_str);
extern int early_platform_driver_probe(char *class_str,
				       int nr_probe, int user_only);
extern void early_platform_cleanup(void);

183 184
#define early_platform_init(class_string, platdrv)		\
	early_platform_init_buffer(class_string, platdrv, NULL, 0)
M
Magnus Damm 已提交
185 186

#ifndef MODULE
187
#define early_platform_init_buffer(class_string, platdrv, buf, bufsiz)	\
M
Magnus Damm 已提交
188 189
static __initdata struct early_platform_driver early_driver = {		\
	.class_str = class_string,					\
190 191 192
	.buffer = buf,							\
	.bufsize = bufsiz,						\
	.pdrv = platdrv,						\
M
Magnus Damm 已提交
193 194
	.requested_id = EARLY_PLATFORM_ID_UNSET,			\
};									\
195
static int __init early_platform_driver_setup_func(char *buffer)	\
M
Magnus Damm 已提交
196
{									\
197
	return early_platform_driver_register(&early_driver, buffer);	\
M
Magnus Damm 已提交
198 199 200
}									\
early_param(class_string, early_platform_driver_setup_func)
#else /* MODULE */
201 202 203 204 205
#define early_platform_init_buffer(class_string, platdrv, buf, bufsiz)	\
static inline char *early_platform_driver_setup_func(void)		\
{									\
	return bufsiz ? buf : NULL;					\
}
M
Magnus Damm 已提交
206 207
#endif /* MODULE */

208
#endif /* _PLATFORM_DEVICE_H_ */