blob: 8dc5123b63057f3e16ca400847477282a993e892 [file] [log] [blame]
Russell Kingbbbf5082005-10-29 22:17:58 +01001/*
2 * platform_device.h - generic, centralized driver model
3 *
4 * Copyright (c) 2001-2003 Patrick Mochel <mochel@osdl.org>
5 *
6 * This file is released under the GPLv2
7 *
8 * See Documentation/driver-model/ for more information.
9 */
10
11#ifndef _PLATFORM_DEVICE_H_
12#define _PLATFORM_DEVICE_H_
13
14#include <linux/device.h>
Eric Miao57fee4a2009-02-04 11:52:40 +080015#include <linux/mod_devicetable.h>
Russell Kingbbbf5082005-10-29 22:17:58 +010016
17struct platform_device {
18 const char * name;
Jean Delvare13595552007-09-09 12:54:16 +020019 int id;
Russell Kingbbbf5082005-10-29 22:17:58 +010020 struct device dev;
21 u32 num_resources;
22 struct resource * resource;
Eric Miao57fee4a2009-02-04 11:52:40 +080023
24 struct platform_device_id *id_entry;
Russell Kingbbbf5082005-10-29 22:17:58 +010025};
26
Eric Miao57fee4a2009-02-04 11:52:40 +080027#define platform_get_device_id(pdev) ((pdev)->id_entry)
28
Russell Kingbbbf5082005-10-29 22:17:58 +010029#define to_platform_device(x) container_of((x), struct platform_device, dev)
30
31extern int platform_device_register(struct platform_device *);
32extern void platform_device_unregister(struct platform_device *);
33
34extern struct bus_type platform_bus_type;
35extern struct device platform_bus;
36
37extern struct resource *platform_get_resource(struct platform_device *, unsigned int, unsigned int);
38extern int platform_get_irq(struct platform_device *, unsigned int);
Linus Walleijc0afe7b2009-04-27 02:38:16 +020039extern struct resource *platform_get_resource_byname(struct platform_device *, unsigned int, const char *);
40extern int platform_get_irq_byname(struct platform_device *, const char *);
Russell Kingbbbf5082005-10-29 22:17:58 +010041extern int platform_add_devices(struct platform_device **, int);
42
Stephen Rothwellae72cdd2008-01-11 17:24:53 +110043extern struct platform_device *platform_device_register_simple(const char *, int id,
Jean Delvare13595552007-09-09 12:54:16 +020044 struct resource *, unsigned int);
Dmitry Baryshkovd8bf2542008-09-22 14:41:40 -070045extern struct platform_device *platform_device_register_data(struct device *,
46 const char *, int, const void *, size_t);
Russell Kingbbbf5082005-10-29 22:17:58 +010047
Jean Delvare13595552007-09-09 12:54:16 +020048extern struct platform_device *platform_device_alloc(const char *name, int id);
Russell King37c12e72005-11-05 21:19:33 +000049extern int platform_device_add_resources(struct platform_device *pdev, struct resource *res, unsigned int num);
Scott Wood6eefd342006-12-04 14:57:19 -080050extern int platform_device_add_data(struct platform_device *pdev, const void *data, size_t size);
Russell King37c12e72005-11-05 21:19:33 +000051extern int platform_device_add(struct platform_device *pdev);
Dmitry Torokhov93ce3062005-12-10 01:36:27 -050052extern void platform_device_del(struct platform_device *pdev);
Russell King37c12e72005-11-05 21:19:33 +000053extern void platform_device_put(struct platform_device *pdev);
54
Russell King00d3dcd2005-11-09 17:23:39 +000055struct platform_driver {
56 int (*probe)(struct platform_device *);
57 int (*remove)(struct platform_device *);
58 void (*shutdown)(struct platform_device *);
59 int (*suspend)(struct platform_device *, pm_message_t state);
David Brownell386415d2006-09-03 13:16:45 -070060 int (*suspend_late)(struct platform_device *, pm_message_t state);
61 int (*resume_early)(struct platform_device *);
Russell King00d3dcd2005-11-09 17:23:39 +000062 int (*resume)(struct platform_device *);
63 struct device_driver driver;
Eric Miao57fee4a2009-02-04 11:52:40 +080064 struct platform_device_id *id_table;
Russell King00d3dcd2005-11-09 17:23:39 +000065};
66
67extern int platform_driver_register(struct platform_driver *);
68extern void platform_driver_unregister(struct platform_driver *);
69
David Brownellc67334f2006-11-16 23:28:47 -080070/* non-hotpluggable platform devices may use this so that probe() and
71 * its support may live in __init sections, conserving runtime memory.
72 */
73extern int platform_driver_probe(struct platform_driver *driver,
74 int (*probe)(struct platform_device *));
75
Russell King00d3dcd2005-11-09 17:23:39 +000076#define platform_get_drvdata(_dev) dev_get_drvdata(&(_dev)->dev)
77#define platform_set_drvdata(_dev,data) dev_set_drvdata(&(_dev)->dev, (data))
78
Magnus Damm13977092009-03-30 14:37:25 -070079/* early platform driver interface */
80struct early_platform_driver {
81 const char *class_str;
82 struct platform_driver *pdrv;
83 struct list_head list;
84 int requested_id;
85};
86
87#define EARLY_PLATFORM_ID_UNSET -2
88#define EARLY_PLATFORM_ID_ERROR -3
89
90extern int early_platform_driver_register(struct early_platform_driver *epdrv,
91 char *buf);
92extern void early_platform_add_devices(struct platform_device **devs, int num);
93
94static inline int is_early_platform_device(struct platform_device *pdev)
95{
96 return !pdev->dev.driver;
97}
98
99extern void early_platform_driver_register_all(char *class_str);
100extern int early_platform_driver_probe(char *class_str,
101 int nr_probe, int user_only);
102extern void early_platform_cleanup(void);
103
104
105#ifndef MODULE
106#define early_platform_init(class_string, platform_driver) \
107static __initdata struct early_platform_driver early_driver = { \
108 .class_str = class_string, \
109 .pdrv = platform_driver, \
110 .requested_id = EARLY_PLATFORM_ID_UNSET, \
111}; \
112static int __init early_platform_driver_setup_func(char *buf) \
113{ \
114 return early_platform_driver_register(&early_driver, buf); \
115} \
116early_param(class_string, early_platform_driver_setup_func)
117#else /* MODULE */
118#define early_platform_init(class_string, platform_driver)
119#endif /* MODULE */
120
Russell Kingbbbf5082005-10-29 22:17:58 +0100121#endif /* _PLATFORM_DEVICE_H_ */