c0dd394ca5
This list used was by only two platforms with all other platforms defining an own list of valid bus id's to pass to of_platform_bus_probe. This patch: i) copies the default list to the two platforms that depended on it (powerpc) ii) remove the usage of of_default_bus_ids in of_platform_bus_probe iii) removes the definition of the list from all architectures that defined it Passing a NULL 'matches' parameter to of_platform_bus_probe is still valid; the function returns no error in that case as the NULL value is equivalent to an empty list. Signed-off-by: Jonas Bonn <jonas@southpole.se> [grant.likely@secretlab.ca: added __initdata annotations, warn on and return error on missing match table, and fix whitespace errors] Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
73 lines
2.4 KiB
C
73 lines
2.4 KiB
C
#ifndef _LINUX_OF_PLATFORM_H
|
|
#define _LINUX_OF_PLATFORM_H
|
|
/*
|
|
* Copyright (C) 2006 Benjamin Herrenschmidt, IBM Corp.
|
|
* <benh@kernel.crashing.org>
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version
|
|
* 2 of the License, or (at your option) any later version.
|
|
*
|
|
*/
|
|
|
|
#ifdef CONFIG_OF_DEVICE
|
|
#include <linux/module.h>
|
|
#include <linux/device.h>
|
|
#include <linux/mod_devicetable.h>
|
|
#include <linux/pm.h>
|
|
#include <linux/of_device.h>
|
|
#include <linux/platform_device.h>
|
|
|
|
/*
|
|
* An of_platform_driver driver is attached to a basic of_device on
|
|
* the "platform bus" (platform_bus_type).
|
|
*/
|
|
struct of_platform_driver
|
|
{
|
|
int (*probe)(struct platform_device* dev,
|
|
const struct of_device_id *match);
|
|
int (*remove)(struct platform_device* dev);
|
|
|
|
int (*suspend)(struct platform_device* dev, pm_message_t state);
|
|
int (*resume)(struct platform_device* dev);
|
|
int (*shutdown)(struct platform_device* dev);
|
|
|
|
struct device_driver driver;
|
|
struct platform_driver platform_driver;
|
|
};
|
|
#define to_of_platform_driver(drv) \
|
|
container_of(drv,struct of_platform_driver, driver)
|
|
|
|
extern int of_register_driver(struct of_platform_driver *drv,
|
|
struct bus_type *bus);
|
|
extern void of_unregister_driver(struct of_platform_driver *drv);
|
|
|
|
/* Platform drivers register/unregister */
|
|
extern int of_register_platform_driver(struct of_platform_driver *drv);
|
|
extern void of_unregister_platform_driver(struct of_platform_driver *drv);
|
|
|
|
extern struct platform_device *of_device_alloc(struct device_node *np,
|
|
const char *bus_id,
|
|
struct device *parent);
|
|
extern struct platform_device *of_find_device_by_node(struct device_node *np);
|
|
|
|
extern int of_bus_type_init(struct bus_type *bus, const char *name);
|
|
|
|
#if !defined(CONFIG_SPARC) /* SPARC has its own device registration method */
|
|
/* Platform devices and busses creation */
|
|
extern struct platform_device *of_platform_device_create(struct device_node *np,
|
|
const char *bus_id,
|
|
struct device *parent);
|
|
|
|
/* pseudo "matches" value to not do deep probe */
|
|
#define OF_NO_DEEP_PROBE ((struct of_device_id *)-1)
|
|
|
|
extern int of_platform_bus_probe(struct device_node *root,
|
|
const struct of_device_id *matches,
|
|
struct device *parent);
|
|
#endif /* !CONFIG_SPARC */
|
|
|
|
#endif /* CONFIG_OF_DEVICE */
|
|
|
|
#endif /* _LINUX_OF_PLATFORM_H */
|