blob: 5417944d3687758bdfbb286633457258fd88a913 [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 Delvare1359555e2007-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
Eric Miao3d03ba42010-01-01 15:43:28 +080024 const struct platform_device_id *id_entry;
Magnus Dammd7aacad2009-07-08 13:21:31 +020025
26 /* arch specific additions */
27 struct pdev_archdata archdata;
Russell Kingbbbf5082005-10-29 22:17:58 +010028};
29
Eric Miao57fee4a2009-02-04 11:52:40 +080030#define platform_get_device_id(pdev) ((pdev)->id_entry)
31
Russell Kingbbbf5082005-10-29 22:17:58 +010032#define to_platform_device(x) container_of((x), struct platform_device, dev)
33
34extern int platform_device_register(struct platform_device *);
35extern void platform_device_unregister(struct platform_device *);
36
37extern struct bus_type platform_bus_type;
38extern struct device platform_bus;
39
40extern struct resource *platform_get_resource(struct platform_device *, unsigned int, unsigned int);
41extern int platform_get_irq(struct platform_device *, unsigned int);
Linus Walleijc0afe7b2009-04-27 02:38:16 +020042extern struct resource *platform_get_resource_byname(struct platform_device *, unsigned int, const char *);
43extern int platform_get_irq_byname(struct platform_device *, const char *);
Russell Kingbbbf5082005-10-29 22:17:58 +010044extern int platform_add_devices(struct platform_device **, int);
45
Stephen Rothwellae72cdd2008-01-11 17:24:53 +110046extern struct platform_device *platform_device_register_simple(const char *, int id,
Geert Uytterhoeven0b7f1a72009-01-28 21:01:02 +010047 const struct resource *, unsigned int);
Dmitry Baryshkovd8bf2542008-09-22 14:41:40 -070048extern struct platform_device *platform_device_register_data(struct device *,
49 const char *, int, const void *, size_t);
Russell Kingbbbf5082005-10-29 22:17:58 +010050
Jean Delvare1359555e2007-09-09 12:54:16 +020051extern struct platform_device *platform_device_alloc(const char *name, int id);
Geert Uytterhoeven0b7f1a72009-01-28 21:01:02 +010052extern int platform_device_add_resources(struct platform_device *pdev,
53 const struct resource *res,
54 unsigned int num);
Scott Wood6eefd342006-12-04 14:57:19 -080055extern int platform_device_add_data(struct platform_device *pdev, const void *data, size_t size);
Russell King37c12e72005-11-05 21:19:33 +000056extern int platform_device_add(struct platform_device *pdev);
Dmitry Torokhov93ce3062005-12-10 01:36:27 -050057extern void platform_device_del(struct platform_device *pdev);
Russell King37c12e72005-11-05 21:19:33 +000058extern void platform_device_put(struct platform_device *pdev);
59
Russell King00d3dcd2005-11-09 17:23:39 +000060struct platform_driver {
61 int (*probe)(struct platform_device *);
62 int (*remove)(struct platform_device *);
63 void (*shutdown)(struct platform_device *);
64 int (*suspend)(struct platform_device *, pm_message_t state);
65 int (*resume)(struct platform_device *);
66 struct device_driver driver;
Uwe Kleine-König831fad22010-01-26 09:35:00 +010067 const struct platform_device_id *id_table;
Russell King00d3dcd2005-11-09 17:23:39 +000068};
69
70extern int platform_driver_register(struct platform_driver *);
71extern void platform_driver_unregister(struct platform_driver *);
72
David Brownellc67334f2006-11-16 23:28:47 -080073/* non-hotpluggable platform devices may use this so that probe() and
74 * its support may live in __init sections, conserving runtime memory.
75 */
76extern int platform_driver_probe(struct platform_driver *driver,
77 int (*probe)(struct platform_device *));
78
Russell King00d3dcd2005-11-09 17:23:39 +000079#define platform_get_drvdata(_dev) dev_get_drvdata(&(_dev)->dev)
80#define platform_set_drvdata(_dev,data) dev_set_drvdata(&(_dev)->dev, (data))
81
Dmitry Torokhovecdf6ce2009-12-29 20:11:20 -080082extern struct platform_device *platform_create_bundle(struct platform_driver *driver,
83 int (*probe)(struct platform_device *),
84 struct resource *res, unsigned int n_res,
85 const void *data, size_t size);
86
Magnus Damm13977092009-03-30 14:37:25 -070087/* early platform driver interface */
88struct early_platform_driver {
89 const char *class_str;
90 struct platform_driver *pdrv;
91 struct list_head list;
92 int requested_id;
Magnus Dammc60e0502009-11-27 17:38:51 +090093 char *buffer;
94 int bufsize;
Magnus Damm13977092009-03-30 14:37:25 -070095};
96
97#define EARLY_PLATFORM_ID_UNSET -2
98#define EARLY_PLATFORM_ID_ERROR -3
99
100extern int early_platform_driver_register(struct early_platform_driver *epdrv,
101 char *buf);
102extern void early_platform_add_devices(struct platform_device **devs, int num);
103
104static inline int is_early_platform_device(struct platform_device *pdev)
105{
106 return !pdev->dev.driver;
107}
108
109extern void early_platform_driver_register_all(char *class_str);
110extern int early_platform_driver_probe(char *class_str,
111 int nr_probe, int user_only);
112extern void early_platform_cleanup(void);
113
Magnus Dammc60e0502009-11-27 17:38:51 +0900114#define early_platform_init(class_string, platdrv) \
115 early_platform_init_buffer(class_string, platdrv, NULL, 0)
Magnus Damm13977092009-03-30 14:37:25 -0700116
117#ifndef MODULE
Magnus Dammc60e0502009-11-27 17:38:51 +0900118#define early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \
Magnus Damm13977092009-03-30 14:37:25 -0700119static __initdata struct early_platform_driver early_driver = { \
120 .class_str = class_string, \
Magnus Dammc60e0502009-11-27 17:38:51 +0900121 .buffer = buf, \
122 .bufsize = bufsiz, \
123 .pdrv = platdrv, \
Magnus Damm13977092009-03-30 14:37:25 -0700124 .requested_id = EARLY_PLATFORM_ID_UNSET, \
125}; \
Magnus Dammc60e0502009-11-27 17:38:51 +0900126static int __init early_platform_driver_setup_func(char *buffer) \
Magnus Damm13977092009-03-30 14:37:25 -0700127{ \
Magnus Dammc60e0502009-11-27 17:38:51 +0900128 return early_platform_driver_register(&early_driver, buffer); \
Magnus Damm13977092009-03-30 14:37:25 -0700129} \
130early_param(class_string, early_platform_driver_setup_func)
131#else /* MODULE */
Magnus Dammc60e0502009-11-27 17:38:51 +0900132#define early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \
133static inline char *early_platform_driver_setup_func(void) \
134{ \
135 return bufsiz ? buf : NULL; \
136}
Magnus Damm13977092009-03-30 14:37:25 -0700137#endif /* MODULE */
138
Russell Kingbbbf5082005-10-29 22:17:58 +0100139#endif /* _PLATFORM_DEVICE_H_ */