2010-03-05 01:46:12 +07:00
|
|
|
#ifndef __USBMIXER_H
|
|
|
|
#define __USBMIXER_H
|
|
|
|
|
2010-03-12 03:13:22 +07:00
|
|
|
struct usb_mixer_interface {
|
|
|
|
struct snd_usb_audio *chip;
|
2011-08-04 20:56:28 +07:00
|
|
|
struct usb_host_interface *hostif;
|
2010-03-12 03:13:22 +07:00
|
|
|
struct list_head list;
|
|
|
|
unsigned int ignore_ctl_error;
|
|
|
|
struct urb *urb;
|
|
|
|
/* array[MAX_ID_ELEMS], indexed by unit id */
|
|
|
|
struct usb_mixer_elem_info **id_elems;
|
|
|
|
|
2010-03-12 03:13:25 +07:00
|
|
|
/* the usb audio specification version this interface complies to */
|
|
|
|
int protocol;
|
|
|
|
|
2010-03-12 03:13:22 +07:00
|
|
|
/* Sound Blaster remote control stuff */
|
|
|
|
const struct rc_config *rc_cfg;
|
|
|
|
u32 rc_code;
|
|
|
|
wait_queue_head_t rc_waitq;
|
|
|
|
struct urb *rc_urb;
|
|
|
|
struct usb_ctrlrequest *rc_setup_packet;
|
|
|
|
u8 rc_buffer[6];
|
|
|
|
|
|
|
|
u8 audigy2nx_leds[3];
|
|
|
|
u8 xonar_u1_status;
|
|
|
|
};
|
|
|
|
|
2011-05-25 14:09:01 +07:00
|
|
|
#define MAX_CHANNELS 16 /* max logical channels */
|
|
|
|
|
|
|
|
enum {
|
|
|
|
USB_MIXER_BOOLEAN,
|
|
|
|
USB_MIXER_INV_BOOLEAN,
|
|
|
|
USB_MIXER_S8,
|
|
|
|
USB_MIXER_U8,
|
|
|
|
USB_MIXER_S16,
|
|
|
|
USB_MIXER_U16,
|
|
|
|
};
|
2010-03-12 03:13:22 +07:00
|
|
|
|
|
|
|
struct usb_mixer_elem_info {
|
|
|
|
struct usb_mixer_interface *mixer;
|
|
|
|
struct usb_mixer_elem_info *next_id_elem; /* list of controls with same id */
|
|
|
|
struct snd_ctl_elem_id *elem_id;
|
|
|
|
unsigned int id;
|
|
|
|
unsigned int control; /* CS or ICN (high byte) */
|
|
|
|
unsigned int cmask; /* channel mask bitmap: 0 = master */
|
2010-05-31 18:35:37 +07:00
|
|
|
unsigned int ch_readonly;
|
|
|
|
unsigned int master_readonly;
|
2010-03-12 03:13:22 +07:00
|
|
|
int channels;
|
|
|
|
int val_type;
|
|
|
|
int min, max, res;
|
|
|
|
int dBmin, dBmax;
|
|
|
|
int cached;
|
|
|
|
int cache_val[MAX_CHANNELS];
|
|
|
|
u8 initialized;
|
|
|
|
};
|
|
|
|
|
2010-03-05 01:46:12 +07:00
|
|
|
int snd_usb_create_mixer(struct snd_usb_audio *chip, int ctrlif,
|
|
|
|
int ignore_error);
|
|
|
|
void snd_usb_mixer_disconnect(struct list_head *p);
|
|
|
|
|
2010-03-12 03:13:22 +07:00
|
|
|
void snd_usb_mixer_notify_id(struct usb_mixer_interface *mixer, int unitid);
|
|
|
|
|
|
|
|
int snd_usb_mixer_set_ctl_value(struct usb_mixer_elem_info *cval,
|
|
|
|
int request, int validx, int value_set);
|
2011-03-11 19:19:43 +07:00
|
|
|
void snd_usb_mixer_inactivate(struct usb_mixer_interface *mixer);
|
|
|
|
int snd_usb_mixer_activate(struct usb_mixer_interface *mixer);
|
2010-03-05 01:46:12 +07:00
|
|
|
|
2011-05-25 14:09:00 +07:00
|
|
|
int snd_usb_mixer_add_control(struct usb_mixer_interface *mixer,
|
|
|
|
struct snd_kcontrol *kctl);
|
|
|
|
|
2012-04-24 01:24:24 +07:00
|
|
|
int snd_usb_mixer_vol_tlv(struct snd_kcontrol *kcontrol, int op_flag,
|
|
|
|
unsigned int size, unsigned int __user *_tlv);
|
|
|
|
|
2010-03-05 01:46:12 +07:00
|
|
|
#endif /* __USBMIXER_H */
|