mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-31 03:13:59 +00:00 
			
		
		
		
	 c0dd394ca5
			
		
	
	
		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>
		
			
				
	
	
		
			74 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			74 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 */
 |