2010-03-05 02:46:12 +08:00
|
|
|
#ifndef __USBMIXER_H
|
|
|
|
#define __USBMIXER_H
|
|
|
|
|
2010-03-12 04:13:22 +08:00
|
|
|
struct usb_mixer_interface {
|
|
|
|
struct snd_usb_audio *chip;
|
2011-08-04 21:56:28 +08:00
|
|
|
struct usb_host_interface *hostif;
|
2010-03-12 04:13:22 +08: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 04:13:25 +08:00
|
|
|
/* the usb audio specification version this interface complies to */
|
|
|
|
int protocol;
|
|
|
|
|
2010-03-12 04:13:22 +08: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 15:09:01 +08: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 04:13:22 +08: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 */
|
2012-11-29 06:55:35 +08:00
|
|
|
unsigned int idx_off; /* Control index offset */
|
2010-05-31 19:35:37 +08:00
|
|
|
unsigned int ch_readonly;
|
|
|
|
unsigned int master_readonly;
|
2010-03-12 04:13:22 +08:00
|
|
|
int channels;
|
|
|
|
int val_type;
|
|
|
|
int min, max, res;
|
|
|
|
int dBmin, dBmax;
|
|
|
|
int cached;
|
|
|
|
int cache_val[MAX_CHANNELS];
|
|
|
|
u8 initialized;
|
2014-11-13 02:07:00 +08:00
|
|
|
void *private_data;
|
2010-03-12 04:13:22 +08:00
|
|
|
};
|
|
|
|
|
2010-03-05 02:46:12 +08:00
|
|
|
int snd_usb_create_mixer(struct snd_usb_audio *chip, int ctrlif,
|
|
|
|
int ignore_error);
|
2014-10-31 18:24:32 +08:00
|
|
|
void snd_usb_mixer_disconnect(struct usb_mixer_interface *mixer);
|
2010-03-05 02:46:12 +08:00
|
|
|
|
2010-03-12 04:13:22 +08: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);
|
2010-03-05 02:46:12 +08:00
|
|
|
|
2011-05-25 15:09:00 +08:00
|
|
|
int snd_usb_mixer_add_control(struct usb_mixer_interface *mixer,
|
|
|
|
struct snd_kcontrol *kctl);
|
|
|
|
|
2012-04-24 02:24:24 +08:00
|
|
|
int snd_usb_mixer_vol_tlv(struct snd_kcontrol *kcontrol, int op_flag,
|
|
|
|
unsigned int size, unsigned int __user *_tlv);
|
|
|
|
|
2014-01-20 23:51:16 +08:00
|
|
|
#ifdef CONFIG_PM
|
|
|
|
int snd_usb_mixer_suspend(struct usb_mixer_interface *mixer);
|
|
|
|
int snd_usb_mixer_resume(struct usb_mixer_interface *mixer, bool reset_resume);
|
|
|
|
#endif
|
|
|
|
|
2014-11-13 02:07:01 +08:00
|
|
|
int snd_usb_set_cur_mix_value(struct usb_mixer_elem_info *cval, int channel,
|
|
|
|
int index, int value);
|
|
|
|
|
|
|
|
int snd_usb_get_cur_mix_value(struct usb_mixer_elem_info *cval,
|
|
|
|
int channel, int index, int *value);
|
|
|
|
|
|
|
|
extern void snd_usb_mixer_elem_free(struct snd_kcontrol *kctl);
|
|
|
|
|
2010-03-05 02:46:12 +08:00
|
|
|
#endif /* __USBMIXER_H */
|