|  | /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
|  | #ifndef __SOUND_I2C_H | 
|  | #define __SOUND_I2C_H | 
|  |  | 
|  | /* | 
|  | */ | 
|  |  | 
|  | #define SND_I2C_DEVICE_ADDRTEN	(1<<0)	/* 10-bit I2C address */ | 
|  |  | 
|  | struct snd_i2c_device { | 
|  | struct list_head list; | 
|  | struct snd_i2c_bus *bus;	/* I2C bus */ | 
|  | char name[32];		/* some useful device name */ | 
|  | unsigned short flags;	/* device flags */ | 
|  | unsigned short addr;	/* device address (might be 10-bit) */ | 
|  | unsigned long private_value; | 
|  | void *private_data; | 
|  | void (*private_free)(struct snd_i2c_device *device); | 
|  | }; | 
|  |  | 
|  | #define snd_i2c_device(n) list_entry(n, struct snd_i2c_device, list) | 
|  |  | 
|  | struct snd_i2c_bit_ops { | 
|  | void (*start)(struct snd_i2c_bus *bus);	/* transfer start */ | 
|  | void (*stop)(struct snd_i2c_bus *bus);	/* transfer stop */ | 
|  | void (*direction)(struct snd_i2c_bus *bus, int clock, int data);  /* set line direction (0 = write, 1 = read) */ | 
|  | void (*setlines)(struct snd_i2c_bus *bus, int clock, int data); | 
|  | int (*getclock)(struct snd_i2c_bus *bus); | 
|  | int (*getdata)(struct snd_i2c_bus *bus, int ack); | 
|  | }; | 
|  |  | 
|  | struct snd_i2c_ops { | 
|  | int (*sendbytes)(struct snd_i2c_device *device, unsigned char *bytes, int count); | 
|  | int (*readbytes)(struct snd_i2c_device *device, unsigned char *bytes, int count); | 
|  | int (*probeaddr)(struct snd_i2c_bus *bus, unsigned short addr); | 
|  | }; | 
|  |  | 
|  | struct snd_i2c_bus { | 
|  | struct snd_card *card;	/* card which I2C belongs to */ | 
|  | char name[32];		/* some useful label */ | 
|  |  | 
|  | struct mutex lock_mutex; | 
|  |  | 
|  | struct snd_i2c_bus *master;	/* master bus when SCK/SCL is shared */ | 
|  | struct list_head buses;	/* master: slave buses sharing SCK/SCL, slave: link list */ | 
|  |  | 
|  | struct list_head devices; /* attached devices to this bus */ | 
|  |  | 
|  | union { | 
|  | struct snd_i2c_bit_ops *bit; | 
|  | void *ops; | 
|  | } hw_ops;		/* lowlevel operations */ | 
|  | const struct snd_i2c_ops *ops;	/* midlevel operations */ | 
|  |  | 
|  | unsigned long private_value; | 
|  | void *private_data; | 
|  | void (*private_free)(struct snd_i2c_bus *bus); | 
|  | }; | 
|  |  | 
|  | #define snd_i2c_slave_bus(n) list_entry(n, struct snd_i2c_bus, buses) | 
|  |  | 
|  | int snd_i2c_bus_create(struct snd_card *card, const char *name, | 
|  | struct snd_i2c_bus *master, struct snd_i2c_bus **ri2c); | 
|  | int snd_i2c_device_create(struct snd_i2c_bus *bus, const char *name, | 
|  | unsigned char addr, struct snd_i2c_device **rdevice); | 
|  | int snd_i2c_device_free(struct snd_i2c_device *device); | 
|  |  | 
|  | static inline void snd_i2c_lock(struct snd_i2c_bus *bus) | 
|  | { | 
|  | if (bus->master) | 
|  | mutex_lock(&bus->master->lock_mutex); | 
|  | else | 
|  | mutex_lock(&bus->lock_mutex); | 
|  | } | 
|  |  | 
|  | static inline void snd_i2c_unlock(struct snd_i2c_bus *bus) | 
|  | { | 
|  | if (bus->master) | 
|  | mutex_unlock(&bus->master->lock_mutex); | 
|  | else | 
|  | mutex_unlock(&bus->lock_mutex); | 
|  | } | 
|  |  | 
|  | int snd_i2c_sendbytes(struct snd_i2c_device *device, unsigned char *bytes, int count); | 
|  | int snd_i2c_readbytes(struct snd_i2c_device *device, unsigned char *bytes, int count); | 
|  | int snd_i2c_probeaddr(struct snd_i2c_bus *bus, unsigned short addr); | 
|  |  | 
|  | #endif /* __SOUND_I2C_H */ |