diff options
Diffstat (limited to 'include/linux/i2c.h')
| -rw-r--r-- | include/linux/i2c.h | 26 | 
1 files changed, 25 insertions, 1 deletions
| diff --git a/include/linux/i2c.h b/include/linux/i2c.h index 6422eef428c4..b2109c522dec 100644 --- a/include/linux/i2c.h +++ b/include/linux/i2c.h @@ -30,6 +30,7 @@  #include <linux/device.h>	/* for struct device */  #include <linux/sched.h>	/* for completion */  #include <linux/mutex.h> +#include <linux/irqdomain.h>		/* for Host Notify IRQ */  #include <linux/of.h>		/* for struct device_node */  #include <linux/swab.h>		/* for swab16 */  #include <uapi/linux/i2c.h> @@ -135,7 +136,8 @@ enum i2c_alert_protocol {   * struct i2c_driver - represent an I2C device driver   * @class: What kind of i2c device we instantiate (for detect)   * @attach_adapter: Callback for bus addition (deprecated) - * @probe: Callback for device binding + * @probe: Callback for device binding - soon to be deprecated + * @probe_new: New callback for device binding   * @remove: Callback for device unbinding   * @shutdown: Callback for device shutdown   * @alert: Alert callback, for example for the SMBus alert protocol @@ -178,6 +180,11 @@ struct i2c_driver {  	int (*probe)(struct i2c_client *, const struct i2c_device_id *);  	int (*remove)(struct i2c_client *); +	/* New driver model interface to aid the seamless removal of the +	 * current probe()'s, more commonly unused than used second parameter. +	 */ +	int (*probe_new)(struct i2c_client *); +  	/* driver model interfaces that don't relate to enumeration  */  	void (*shutdown)(struct i2c_client *); @@ -243,6 +250,8 @@ struct i2c_client {  extern struct i2c_client *i2c_verify_client(struct device *dev);  extern struct i2c_adapter *i2c_verify_adapter(struct device *dev); +extern const struct i2c_device_id *i2c_match_id(const struct i2c_device_id *id, +					const struct i2c_client *client);  static inline struct i2c_client *kobj_to_i2c_client(struct kobject *kobj)  { @@ -567,6 +576,8 @@ struct i2c_adapter {  	struct i2c_bus_recovery_info *bus_recovery_info;  	const struct i2c_adapter_quirks *quirks; + +	struct irq_domain *host_notify_domain;  };  #define to_i2c_adapter(d) container_of(d, struct i2c_adapter, dev) @@ -739,6 +750,7 @@ static inline u8 i2c_8bit_addr_from_msg(const struct i2c_msg *msg)  	return (msg->addr << 1) | (msg->flags & I2C_M_RD ? 1 : 0);  } +int i2c_handle_smbus_host_notify(struct i2c_adapter *adap, unsigned short addr);  /**   * module_i2c_driver() - Helper macro for registering a modular I2C driver   * @__i2c_driver: i2c_driver struct @@ -774,6 +786,10 @@ extern struct i2c_adapter *of_find_i2c_adapter_by_node(struct device_node *node)  /* must call i2c_put_adapter() when done with returned i2c_adapter device */  struct i2c_adapter *of_get_i2c_adapter_by_node(struct device_node *node); +extern const struct of_device_id +*i2c_of_match_device(const struct of_device_id *matches, +		     struct i2c_client *client); +  #else  static inline struct i2c_client *of_find_i2c_device_by_node(struct device_node *node) @@ -790,6 +806,14 @@ static inline struct i2c_adapter *of_get_i2c_adapter_by_node(struct device_node  {  	return NULL;  } + +static inline const struct of_device_id +*i2c_of_match_device(const struct of_device_id *matches, +		     struct i2c_client *client) +{ +	return NULL; +} +  #endif /* CONFIG_OF */  #if IS_ENABLED(CONFIG_ACPI) |