2019-05-27 09:55:05 +03:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2005-04-17 02:20:36 +04:00
# ifndef __SOUND_I2C_H
# define __SOUND_I2C_H
/*
*/
# define SND_I2C_DEVICE_ADDRTEN (1<<0) /* 10-bit I2C address */
2005-11-17 16:17:19 +03:00
struct snd_i2c_device {
2005-04-17 02:20:36 +04:00
struct list_head list ;
2005-11-17 16:17:19 +03:00
struct snd_i2c_bus * bus ; /* I2C bus */
2005-04-17 02:20:36 +04:00
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 ;
2005-11-17 16:17:19 +03:00
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 ) ;
2005-04-17 02:20:36 +04:00
} ;
2005-11-17 16:17:19 +03:00
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 */
2005-04-17 02:20:36 +04:00
char name [ 32 ] ; /* some useful label */
2006-01-16 18:31:42 +03:00
struct mutex lock_mutex ;
2005-04-17 02:20:36 +04:00
2005-11-17 16:17:19 +03:00
struct snd_i2c_bus * master ; /* master bus when SCK/SCL is shared */
2005-04-17 02:20:36 +04:00
struct list_head buses ; /* master: slave buses sharing SCK/SCL, slave: link list */
struct list_head devices ; /* attached devices to this bus */
union {
2005-11-17 16:17:19 +03:00
struct snd_i2c_bit_ops * bit ;
2005-04-17 02:20:36 +04:00
void * ops ;
} hw_ops ; /* lowlevel operations */
2015-11-29 20:25:24 +03:00
const struct snd_i2c_ops * ops ; /* midlevel operations */
2005-04-17 02:20:36 +04:00
unsigned long private_value ;
void * private_data ;
2005-11-17 16:17:19 +03:00
void ( * private_free ) ( struct snd_i2c_bus * bus ) ;
2005-04-17 02:20:36 +04:00
} ;
2005-11-17 16:17:19 +03:00
# define snd_i2c_slave_bus(n) list_entry(n, struct snd_i2c_bus, buses)
2005-04-17 02:20:36 +04:00
2005-11-17 16:17:19 +03:00
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 ) ;
2005-04-17 02:20:36 +04:00
2005-11-17 16:17:19 +03:00
static inline void snd_i2c_lock ( struct snd_i2c_bus * bus )
{
2005-04-17 02:20:36 +04:00
if ( bus - > master )
2006-01-16 18:31:42 +03:00
mutex_lock ( & bus - > master - > lock_mutex ) ;
2005-04-17 02:20:36 +04:00
else
2006-01-16 18:31:42 +03:00
mutex_lock ( & bus - > lock_mutex ) ;
2005-04-17 02:20:36 +04:00
}
2005-11-17 16:17:19 +03:00
static inline void snd_i2c_unlock ( struct snd_i2c_bus * bus )
{
2005-04-17 02:20:36 +04:00
if ( bus - > master )
2006-01-16 18:31:42 +03:00
mutex_unlock ( & bus - > master - > lock_mutex ) ;
2005-04-17 02:20:36 +04:00
else
2006-01-16 18:31:42 +03:00
mutex_unlock ( & bus - > lock_mutex ) ;
2005-04-17 02:20:36 +04:00
}
2005-11-17 16:17:19 +03:00
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 ) ;
2005-04-17 02:20:36 +04:00
# endif /* __SOUND_I2C_H */