blob: 71ff887ca44ee6eccfc83416554b556f61a6231c [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
24 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 Torokhov93ce30612005-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;
Eric Miao57fee4a2009-02-04 11:52:40 +080065 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
Magnus Damm13977092009-03-30 14:37:25 -070080/* early platform driver interface */
81struct early_platform_driver {
82 const char *class_str;
83 struct platform_driver *pdrv;
84 struct list_head list;
85 int requested_id;
Magnus Dammc60e0502009-11-27 17:38:51 +090086 char *buffer;
87 int bufsize;
Magnus Damm13977092009-03-30 14:37:25 -070088};
89
90#define EARLY_PLATFORM_ID_UNSET -2
91#define EARLY_PLATFORM_ID_ERROR -3
92
93extern int early_platform_driver_register(struct early_platform_driver *epdrv,
94 char *buf);
95extern void early_platform_add_devices(struct platform_device **devs, int num);
96
97static inline int is_early_platform_device(struct platform_device *pdev)
98{
99 return !pdev->dev.driver;
100}
101
102extern void early_platform_driver_register_all(char *class_str);
103extern int early_platform_driver_probe(char *class_str,
104 int nr_probe, int user_only);
105extern void early_platform_cleanup(void);
106
Magnus Dammc60e0502009-11-27 17:38:51 +0900107#define early_platform_init(class_string, platdrv) \
108 early_platform_init_buffer(class_string, platdrv, NULL, 0)
Magnus Damm13977092009-03-30 14:37:25 -0700109
110#ifndef MODULE
Magnus Dammc60e0502009-11-27 17:38:51 +0900111#define early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \
Magnus Damm13977092009-03-30 14:37:25 -0700112static __initdata struct early_platform_driver early_driver = { \
113 .class_str = class_string, \
Magnus Dammc60e0502009-11-27 17:38:51 +0900114 .buffer = buf, \
115 .bufsize = bufsiz, \
116 .pdrv = platdrv, \
Magnus Damm13977092009-03-30 14:37:25 -0700117 .requested_id = EARLY_PLATFORM_ID_UNSET, \
118}; \
Magnus Dammc60e0502009-11-27 17:38:51 +0900119static int __init early_platform_driver_setup_func(char *buffer) \
Magnus Damm13977092009-03-30 14:37:25 -0700120{ \
Magnus Dammc60e0502009-11-27 17:38:51 +0900121 return early_platform_driver_register(&early_driver, buffer); \
Magnus Damm13977092009-03-30 14:37:25 -0700122} \
123early_param(class_string, early_platform_driver_setup_func)
124#else /* MODULE */
Magnus Dammc60e0502009-11-27 17:38:51 +0900125#define early_platform_init_buffer(class_string, platdrv, buf, bufsiz) \
126static inline char *early_platform_driver_setup_func(void) \
127{ \
128 return bufsiz ? buf : NULL; \
129}
Magnus Damm13977092009-03-30 14:37:25 -0700130#endif /* MODULE */
131
Russell Kingbbbf5082005-10-29 22:17:58 +0100132#endif /* _PLATFORM_DEVICE_H_ */