1 /* SPDX-License-Identifier: GPL-2.0-or-later * 1 /* SPDX-License-Identifier: GPL-2.0-or-later */ 2 /* 2 /* 3 * i2c-smbus.h - SMBus extensions to the I2C p 3 * i2c-smbus.h - SMBus extensions to the I2C protocol 4 * 4 * 5 * Copyright (C) 2010-2019 Jean Delvare <jdelv 5 * Copyright (C) 2010-2019 Jean Delvare <jdelvare@suse.de> 6 */ 6 */ 7 7 8 #ifndef _LINUX_I2C_SMBUS_H 8 #ifndef _LINUX_I2C_SMBUS_H 9 #define _LINUX_I2C_SMBUS_H 9 #define _LINUX_I2C_SMBUS_H 10 10 11 #include <linux/i2c.h> 11 #include <linux/i2c.h> 12 #include <linux/spinlock.h> 12 #include <linux/spinlock.h> 13 #include <linux/workqueue.h> 13 #include <linux/workqueue.h> 14 14 15 15 16 /** 16 /** 17 * i2c_smbus_alert_setup - platform data for t 17 * i2c_smbus_alert_setup - platform data for the smbus_alert i2c client 18 * @irq: IRQ number, if the smbus_alert driver 18 * @irq: IRQ number, if the smbus_alert driver should take care of interrupt 19 * handling 19 * handling 20 * 20 * 21 * If irq is not specified, the smbus_alert dr 21 * If irq is not specified, the smbus_alert driver doesn't take care of 22 * interrupt handling. In that case it is up t 22 * interrupt handling. In that case it is up to the I2C bus driver to either 23 * handle the interrupts or to poll for alerts 23 * handle the interrupts or to poll for alerts. 24 */ 24 */ 25 struct i2c_smbus_alert_setup { 25 struct i2c_smbus_alert_setup { 26 int irq; 26 int irq; 27 }; 27 }; 28 28 29 struct i2c_client *i2c_new_smbus_alert_device( 29 struct i2c_client *i2c_new_smbus_alert_device(struct i2c_adapter *adapter, 30 30 struct i2c_smbus_alert_setup *setup); 31 int i2c_handle_smbus_alert(struct i2c_client * 31 int i2c_handle_smbus_alert(struct i2c_client *ara); 32 32 33 #if IS_ENABLED(CONFIG_I2C_SMBUS) && IS_ENABLED 33 #if IS_ENABLED(CONFIG_I2C_SMBUS) && IS_ENABLED(CONFIG_I2C_SLAVE) 34 struct i2c_client *i2c_new_slave_host_notify_d 34 struct i2c_client *i2c_new_slave_host_notify_device(struct i2c_adapter *adapter); 35 void i2c_free_slave_host_notify_device(struct 35 void i2c_free_slave_host_notify_device(struct i2c_client *client); 36 #else 36 #else 37 static inline struct i2c_client *i2c_new_slave 37 static inline struct i2c_client *i2c_new_slave_host_notify_device(struct i2c_adapter *adapter) 38 { 38 { 39 return ERR_PTR(-ENOSYS); 39 return ERR_PTR(-ENOSYS); 40 } 40 } 41 static inline void i2c_free_slave_host_notify_ 41 static inline void i2c_free_slave_host_notify_device(struct i2c_client *client) 42 { 42 { 43 } 43 } 44 #endif 44 #endif 45 45 46 #if IS_ENABLED(CONFIG_I2C_SMBUS) && IS_ENABLED 46 #if IS_ENABLED(CONFIG_I2C_SMBUS) && IS_ENABLED(CONFIG_DMI) 47 void i2c_register_spd(struct i2c_adapter *adap 47 void i2c_register_spd(struct i2c_adapter *adap); 48 #else 48 #else 49 static inline void i2c_register_spd(struct i2c 49 static inline void i2c_register_spd(struct i2c_adapter *adap) { } 50 #endif 50 #endif 51 51 52 #endif /* _LINUX_I2C_SMBUS_H */ 52 #endif /* _LINUX_I2C_SMBUS_H */ 53 53
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.