blob: 212da17d06afa66fb07749b6498aa4f3d4f6f727 [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,
Jean Delvare1359555e2007-09-09 12:54:16 +020047 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);
Russell King37c12e72005-11-05 21:19:33 +000052extern int platform_device_add_resources(struct platform_device *pdev, struct resource *res, unsigned int num);
Scott Wood6eefd342006-12-04 14:57:19 -080053extern int platform_device_add_data(struct platform_device *pdev, const void *data, size_t size);
Russell King37c12e72005-11-05 21:19:33 +000054extern int platform_device_add(struct platform_device *pdev);
Dmitry Torokhov93ce3062005-12-10 01:36:27 -050055extern void platform_device_del(struct platform_device *pdev);
Russell King37c12e72005-11-05 21:19:33 +000056extern void platform_device_put(struct platform_device *pdev);
57
Russell King00d3dcd2005-11-09 17:23:39 +000058struct platform_driver {
59 int (*probe)(struct platform_device *);
60 int (*remove)(struct platform_device *);
61 void (*shutdown)(struct platform_device *);
62 int (*suspend)(struct platform_device *, pm_message_t state);
63 int (*resume)(struct platform_device *);
64 struct device_driver driver;
Uwe Kleine-König831fad22010-01-26 09:35:00 +010065 const struct platform_device_id *id_table;
Russell King00d3dcd2005-11-09 17:23:39 +000066};
67
68extern int platform_driver_register(struct platform_driver *);
69extern void platform_driver_unregister(struct platform_driver *);
70
David Brownellc67334f2006-11-16 23:28:47 -080071/* non-hotpluggable platform devices may use this so that probe() and
72 * its support may live in __init sections, conserving runtime memory.
73 */
74extern int platform_driver_probe(struct platform_driver *driver,
75 int (*probe)(struct platform_device *));
76
Russell King00d3dcd2005-11-09 17:23:39 +000077#define platform_get_drvdata(_dev) dev_get_drvdata(&(_dev)->dev)
78#define platform_set_drvdata(_dev,data) dev_set_drvdata(&(_dev)->dev, (data))
79
Dmitry Torokhovecdf6ce2009-12-29 20:11:20 -080080extern struct platform_device *platform_create_bundle(struct platform_driver *driver,
81 int (*probe)(struct platform_device *),
82 struct resource *res, unsigned int n_res,
83 const void *data, size_t size);
84
Magnus Damm13977092009-03-30 14:37:25 -070085/* early platform driver interface */
86struct early_platform_driver {
87 const char *class_str;
88 struct platform_driver *pdrv;
89 struct list_head list;
90 int requested_id;
Magnus Dammc60e0502009-11-27 17:38:51 +090091 char *buffer;
92 int bufsize;
Magnus Damm13977092009-03-30 14:37:25 -070093};
94
95#define EARLY_PLATFORM_ID_UNSET -2
96#define EARLY_PLATFORM_ID_ERROR -3
97
98extern int early_platform_driver_register(struct early_platform_driver *epdrv,
99 char *buf);
100extern void early_platform_add_devices(struct platform_device **devs, int num);
101
102static inline int is_early_platform_device(struct platform_device *pdev)
103{
104 return !pdev->dev.driver;
105}
106
107extern void early_platform_driver_register_all(char *class_str);
108extern int early_platform_driver_probe(char *class_str,
109 int nr_probe, int user_only);
110extern void early_platform_cleanup(void);
111
Magnus Dammc60e0502009-11-27 17:38:51 +0900112#define early_platform_init(class_string, platdrv) \
113 early_platform_init_buffer(class_string, platdrv, NULL, 0)
Magnus Damm13977092009-03-30 14:37:25 -0700114
115#ifndef MODULE
Magnus Dammc60e0502009-11-27 17:38:51 +0900116#define early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \
Magnus Damm13977092009-03-30 14:37:25 -0700117static __initdata struct early_platform_driver early_driver = { \
118 .class_str = class_string, \
Magnus Dammc60e0502009-11-27 17:38:51 +0900119 .buffer = buf, \
120 .bufsize = bufsiz, \
121 .pdrv = platdrv, \
Magnus Damm13977092009-03-30 14:37:25 -0700122 .requested_id = EARLY_PLATFORM_ID_UNSET, \
123}; \
Magnus Dammc60e0502009-11-27 17:38:51 +0900124static int __init early_platform_driver_setup_func(char *buffer) \
Magnus Damm13977092009-03-30 14:37:25 -0700125{ \
Magnus Dammc60e0502009-11-27 17:38:51 +0900126 return early_platform_driver_register(&early_driver, buffer); \
Magnus Damm13977092009-03-30 14:37:25 -0700127} \
128early_param(class_string, early_platform_driver_setup_func)
129#else /* MODULE */
Magnus Dammc60e0502009-11-27 17:38:51 +0900130#define early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \
131static inline char *early_platform_driver_setup_func(void) \
132{ \
133 return bufsiz ? buf : NULL; \
134}
Magnus Damm13977092009-03-30 14:37:25 -0700135#endif /* MODULE */
136
Russell Kingbbbf5082005-10-29 22:17:58 +0100137#endif /* _PLATFORM_DEVICE_H_ */