diff options
Diffstat (limited to 'include/linux/device.h')
| -rw-r--r-- | include/linux/device.h | 256 | 
1 files changed, 249 insertions, 7 deletions
diff --git a/include/linux/device.h b/include/linux/device.h index 6717adee33f0..297239a08bb7 100644 --- a/include/linux/device.h +++ b/include/linux/device.h @@ -164,16 +164,102 @@ void subsys_dev_iter_init(struct subsys_dev_iter *iter,  struct device *subsys_dev_iter_next(struct subsys_dev_iter *iter);  void subsys_dev_iter_exit(struct subsys_dev_iter *iter); +int device_match_name(struct device *dev, const void *name);  int device_match_of_node(struct device *dev, const void *np); +int device_match_fwnode(struct device *dev, const void *fwnode); +int device_match_devt(struct device *dev, const void *pdevt); +int device_match_acpi_dev(struct device *dev, const void *adev); +int device_match_any(struct device *dev, const void *unused);  int bus_for_each_dev(struct bus_type *bus, struct device *start, void *data,  		     int (*fn)(struct device *dev, void *data));  struct device *bus_find_device(struct bus_type *bus, struct device *start,  			       const void *data,  			       int (*match)(struct device *dev, const void *data)); -struct device *bus_find_device_by_name(struct bus_type *bus, -				       struct device *start, -				       const char *name); +/** + * bus_find_device_by_name - device iterator for locating a particular device + * of a specific name. + * @bus: bus type + * @start: Device to begin with + * @name: name of the device to match + */ +static inline struct device *bus_find_device_by_name(struct bus_type *bus, +						     struct device *start, +						     const char *name) +{ +	return bus_find_device(bus, start, name, device_match_name); +} + +/** + * bus_find_device_by_of_node : device iterator for locating a particular device + * matching the of_node. + * @bus: bus type + * @np: of_node of the device to match. + */ +static inline struct device * +bus_find_device_by_of_node(struct bus_type *bus, const struct device_node *np) +{ +	return bus_find_device(bus, NULL, np, device_match_of_node); +} + +/** + * bus_find_device_by_fwnode : device iterator for locating a particular device + * matching the fwnode. + * @bus: bus type + * @fwnode: fwnode of the device to match. + */ +static inline struct device * +bus_find_device_by_fwnode(struct bus_type *bus, const struct fwnode_handle *fwnode) +{ +	return bus_find_device(bus, NULL, fwnode, device_match_fwnode); +} + +/** + * bus_find_device_by_devt : device iterator for locating a particular device + * matching the device type. + * @bus: bus type + * @devt: device type of the device to match. + */ +static inline struct device *bus_find_device_by_devt(struct bus_type *bus, +						     dev_t devt) +{ +	return bus_find_device(bus, NULL, &devt, device_match_devt); +} + +/** + * bus_find_next_device - Find the next device after a given device in a + * given bus. + * @bus: bus type + * @cur: device to begin the search with. + */ +static inline struct device * +bus_find_next_device(struct bus_type *bus,struct device *cur) +{ +	return bus_find_device(bus, cur, NULL, device_match_any); +} + +#ifdef CONFIG_ACPI +struct acpi_device; + +/** + * bus_find_device_by_acpi_dev : device iterator for locating a particular device + * matching the ACPI COMPANION device. + * @bus: bus type + * @adev: ACPI COMPANION device to match. + */ +static inline struct device * +bus_find_device_by_acpi_dev(struct bus_type *bus, const struct acpi_device *adev) +{ +	return bus_find_device(bus, NULL, adev, device_match_acpi_dev); +} +#else +static inline struct device * +bus_find_device_by_acpi_dev(struct bus_type *bus, const void *adev) +{ +	return NULL; +} +#endif +  struct device *subsys_find_device_by_id(struct bus_type *bus, unsigned int id,  					struct device *hint);  int bus_for_each_drv(struct bus_type *bus, struct device_driver *start, @@ -262,6 +348,8 @@ enum probe_type {   * @resume:	Called to bring a device from sleep mode.   * @groups:	Default attributes that get created by the driver core   *		automatically. + * @dev_groups:	Additional attributes attached to device instance once the + *		it is bound to the driver.   * @pm:		Power management operations of the device which matched   *		this driver.   * @coredump:	Called when sysfs entry is written to. The device driver @@ -296,6 +384,7 @@ struct device_driver {  	int (*suspend) (struct device *dev, pm_message_t state);  	int (*resume) (struct device *dev);  	const struct attribute_group **groups; +	const struct attribute_group **dev_groups;  	const struct dev_pm_ops *pm;  	void (*coredump) (struct device *dev); @@ -342,6 +431,83 @@ struct device *driver_find_device(struct device_driver *drv,  				  struct device *start, const void *data,  				  int (*match)(struct device *dev, const void *data)); +/** + * driver_find_device_by_name - device iterator for locating a particular device + * of a specific name. + * @drv: the driver we're iterating + * @name: name of the device to match + */ +static inline struct device *driver_find_device_by_name(struct device_driver *drv, +							const char *name) +{ +	return driver_find_device(drv, NULL, name, device_match_name); +} + +/** + * driver_find_device_by_of_node- device iterator for locating a particular device + * by of_node pointer. + * @drv: the driver we're iterating + * @np: of_node pointer to match. + */ +static inline struct device * +driver_find_device_by_of_node(struct device_driver *drv, +			      const struct device_node *np) +{ +	return driver_find_device(drv, NULL, np, device_match_of_node); +} + +/** + * driver_find_device_by_fwnode- device iterator for locating a particular device + * by fwnode pointer. + * @drv: the driver we're iterating + * @fwnode: fwnode pointer to match. + */ +static inline struct device * +driver_find_device_by_fwnode(struct device_driver *drv, +			     const struct fwnode_handle *fwnode) +{ +	return driver_find_device(drv, NULL, fwnode, device_match_fwnode); +} + +/** + * driver_find_device_by_devt- device iterator for locating a particular device + * by devt. + * @drv: the driver we're iterating + * @devt: devt pointer to match. + */ +static inline struct device *driver_find_device_by_devt(struct device_driver *drv, +							dev_t devt) +{ +	return driver_find_device(drv, NULL, &devt, device_match_devt); +} + +static inline struct device *driver_find_next_device(struct device_driver *drv, +						     struct device *start) +{ +	return driver_find_device(drv, start, NULL, device_match_any); +} + +#ifdef CONFIG_ACPI +/** + * driver_find_device_by_acpi_dev : device iterator for locating a particular + * device matching the ACPI_COMPANION device. + * @drv: the driver we're iterating + * @adev: ACPI_COMPANION device to match. + */ +static inline struct device * +driver_find_device_by_acpi_dev(struct device_driver *drv, +			       const struct acpi_device *adev) +{ +	return driver_find_device(drv, NULL, adev, device_match_acpi_dev); +} +#else +static inline struct device * +driver_find_device_by_acpi_dev(struct device_driver *drv, const void *adev) +{ +	return NULL; +} +#endif +  void driver_deferred_probe_add(struct device *dev);  int driver_deferred_probe_check_state(struct device *dev);  int driver_deferred_probe_check_state_continue(struct device *dev); @@ -471,6 +637,76 @@ extern struct device *class_find_device(struct class *class,  					struct device *start, const void *data,  					int (*match)(struct device *, const void *)); +/** + * class_find_device_by_name - device iterator for locating a particular device + * of a specific name. + * @class: class type + * @name: name of the device to match + */ +static inline struct device *class_find_device_by_name(struct class *class, +						       const char *name) +{ +	return class_find_device(class, NULL, name, device_match_name); +} + +/** + * class_find_device_by_of_node : device iterator for locating a particular device + * matching the of_node. + * @class: class type + * @np: of_node of the device to match. + */ +static inline struct device * +class_find_device_by_of_node(struct class *class, const struct device_node *np) +{ +	return class_find_device(class, NULL, np, device_match_of_node); +} + +/** + * class_find_device_by_fwnode : device iterator for locating a particular device + * matching the fwnode. + * @class: class type + * @fwnode: fwnode of the device to match. + */ +static inline struct device * +class_find_device_by_fwnode(struct class *class, +			    const struct fwnode_handle *fwnode) +{ +	return class_find_device(class, NULL, fwnode, device_match_fwnode); +} + +/** + * class_find_device_by_devt : device iterator for locating a particular device + * matching the device type. + * @class: class type + * @devt: device type of the device to match. + */ +static inline struct device *class_find_device_by_devt(struct class *class, +						       dev_t devt) +{ +	return class_find_device(class, NULL, &devt, device_match_devt); +} + +#ifdef CONFIG_ACPI +struct acpi_device; +/** + * class_find_device_by_acpi_dev : device iterator for locating a particular + * device matching the ACPI_COMPANION device. + * @class: class type + * @adev: ACPI_COMPANION device to match. + */ +static inline struct device * +class_find_device_by_acpi_dev(struct class *class, const struct acpi_device *adev) +{ +	return class_find_device(class, NULL, adev, device_match_acpi_dev); +} +#else +static inline struct device * +class_find_device_by_acpi_dev(struct class *class, const void *adev) +{ +	return NULL; +} +#endif +  struct class_attribute {  	struct attribute attr;  	ssize_t (*show)(struct class *class, struct class_attribute *attr, @@ -778,10 +1014,14 @@ struct device_connection {  	struct list_head	list;  }; +typedef void *(*devcon_match_fn_t)(struct device_connection *con, int ep, +				   void *data); + +void *fwnode_connection_find_match(struct fwnode_handle *fwnode, +				   const char *con_id, void *data, +				   devcon_match_fn_t match);  void *device_connection_find_match(struct device *dev, const char *con_id, -				void *data, -				void *(*match)(struct device_connection *con, -					       int ep, void *data)); +				   void *data, devcon_match_fn_t match);  struct device *device_connection_find(struct device *dev, const char *con_id); @@ -833,12 +1073,13 @@ enum device_link_state {  /*   * Device link flags.   * - * STATELESS: The core won't track the presence of supplier/consumer drivers. + * STATELESS: The core will not remove this link automatically.   * AUTOREMOVE_CONSUMER: Remove the link automatically on consumer driver unbind.   * PM_RUNTIME: If set, the runtime PM framework will use this link.   * RPM_ACTIVE: Run pm_runtime_get_sync() on the supplier during link creation.   * AUTOREMOVE_SUPPLIER: Remove the link automatically on supplier driver unbind.   * AUTOPROBE_CONSUMER: Probe consumer driver automatically after supplier binds. + * MANAGED: The core tracks presence of supplier/consumer drivers (internal).   */  #define DL_FLAG_STATELESS		BIT(0)  #define DL_FLAG_AUTOREMOVE_CONSUMER	BIT(1) @@ -846,6 +1087,7 @@ enum device_link_state {  #define DL_FLAG_RPM_ACTIVE		BIT(3)  #define DL_FLAG_AUTOREMOVE_SUPPLIER	BIT(4)  #define DL_FLAG_AUTOPROBE_CONSUMER	BIT(5) +#define DL_FLAG_MANAGED			BIT(6)  /**   * struct device_link - Device link representation.  |