2007-03-27 01:11:24 +08:00
|
|
|
#ifndef CAIAQ_DEVICE_H
|
|
|
|
#define CAIAQ_DEVICE_H
|
|
|
|
|
|
|
|
#include "../usbaudio.h"
|
|
|
|
|
|
|
|
#define USB_VID_NATIVEINSTRUMENTS 0x17cc
|
|
|
|
|
2010-03-22 20:13:37 +08:00
|
|
|
#define USB_PID_RIGKONTROL2 0x1969
|
|
|
|
#define USB_PID_RIGKONTROL3 0x1940
|
|
|
|
#define USB_PID_KORECONTROLLER 0x4711
|
|
|
|
#define USB_PID_KORECONTROLLER2 0x4712
|
|
|
|
#define USB_PID_AK1 0x0815
|
|
|
|
#define USB_PID_AUDIO2DJ 0x041c
|
|
|
|
#define USB_PID_AUDIO4DJ 0x0839
|
|
|
|
#define USB_PID_AUDIO8DJ 0x1978
|
|
|
|
#define USB_PID_SESSIONIO 0x1915
|
|
|
|
#define USB_PID_GUITARRIGMOBILE 0x0d8d
|
|
|
|
#define USB_PID_TRAKTORKONTROLX1 0x2305
|
2010-09-10 17:04:57 +08:00
|
|
|
#define USB_PID_TRAKTORKONTROLS4 0xbaff
|
2010-09-01 16:23:46 +08:00
|
|
|
#define USB_PID_TRAKTORAUDIO2 0x041d
|
2007-03-27 01:11:24 +08:00
|
|
|
|
|
|
|
#define EP1_BUFSIZE 64
|
2010-03-22 20:13:37 +08:00
|
|
|
#define EP4_BUFSIZE 512
|
2007-03-27 01:11:24 +08:00
|
|
|
#define CAIAQ_USB_STR_LEN 0xff
|
|
|
|
#define MAX_STREAMS 32
|
|
|
|
|
|
|
|
//#define SND_USB_CAIAQ_DEBUG
|
|
|
|
|
|
|
|
#define MODNAME "snd-usb-caiaq"
|
|
|
|
#define log(x...) snd_printk(KERN_WARNING MODNAME" log: " x)
|
|
|
|
|
|
|
|
#ifdef SND_USB_CAIAQ_DEBUG
|
|
|
|
#define debug(x...) snd_printk(KERN_WARNING MODNAME " debug: " x)
|
|
|
|
#else
|
|
|
|
#define debug(x...) do { } while(0)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define EP1_CMD_GET_DEVICE_INFO 0x1
|
|
|
|
#define EP1_CMD_READ_ERP 0x2
|
|
|
|
#define EP1_CMD_READ_ANALOG 0x3
|
|
|
|
#define EP1_CMD_READ_IO 0x4
|
|
|
|
#define EP1_CMD_WRITE_IO 0x5
|
|
|
|
#define EP1_CMD_MIDI_READ 0x6
|
|
|
|
#define EP1_CMD_MIDI_WRITE 0x7
|
|
|
|
#define EP1_CMD_AUDIO_PARAMS 0x9
|
|
|
|
#define EP1_CMD_AUTO_MSG 0xb
|
2007-11-22 18:40:04 +08:00
|
|
|
#define EP1_CMD_DIMM_LEDS 0xc
|
2007-03-27 01:11:24 +08:00
|
|
|
|
|
|
|
struct caiaq_device_spec {
|
|
|
|
unsigned short fw_version;
|
|
|
|
unsigned char hw_subtype;
|
|
|
|
unsigned char num_erp;
|
|
|
|
unsigned char num_analog_in;
|
|
|
|
unsigned char num_digital_in;
|
|
|
|
unsigned char num_digital_out;
|
|
|
|
unsigned char num_analog_audio_out;
|
|
|
|
unsigned char num_analog_audio_in;
|
|
|
|
unsigned char num_digital_audio_out;
|
|
|
|
unsigned char num_digital_audio_in;
|
|
|
|
unsigned char num_midi_out;
|
|
|
|
unsigned char num_midi_in;
|
|
|
|
unsigned char data_alignment;
|
|
|
|
} __attribute__ ((packed));
|
|
|
|
|
|
|
|
struct snd_usb_caiaq_cb_info;
|
|
|
|
|
|
|
|
struct snd_usb_caiaqdev {
|
|
|
|
struct snd_usb_audio chip;
|
|
|
|
|
|
|
|
struct urb ep1_in_urb;
|
|
|
|
struct urb midi_out_urb;
|
|
|
|
struct urb **data_urbs_in;
|
|
|
|
struct urb **data_urbs_out;
|
|
|
|
struct snd_usb_caiaq_cb_info *data_cb_info;
|
2007-11-21 23:45:23 +08:00
|
|
|
|
2007-03-27 01:11:24 +08:00
|
|
|
unsigned char ep1_in_buf[EP1_BUFSIZE];
|
|
|
|
unsigned char ep1_out_buf[EP1_BUFSIZE];
|
|
|
|
unsigned char midi_out_buf[EP1_BUFSIZE];
|
|
|
|
|
|
|
|
struct caiaq_device_spec spec;
|
|
|
|
spinlock_t spinlock;
|
|
|
|
wait_queue_head_t ep1_wait_queue;
|
|
|
|
wait_queue_head_t prepare_wait_queue;
|
|
|
|
int spec_received, audio_parm_answer;
|
2009-01-08 22:32:56 +08:00
|
|
|
int midi_out_active;
|
2007-11-21 23:45:23 +08:00
|
|
|
|
2007-03-27 01:11:24 +08:00
|
|
|
char vendor_name[CAIAQ_USB_STR_LEN];
|
|
|
|
char product_name[CAIAQ_USB_STR_LEN];
|
|
|
|
|
|
|
|
int n_streams, n_audio_in, n_audio_out;
|
|
|
|
int streaming, first_packet, output_running;
|
|
|
|
int audio_in_buf_pos[MAX_STREAMS];
|
|
|
|
int audio_out_buf_pos[MAX_STREAMS];
|
|
|
|
int period_in_count[MAX_STREAMS];
|
|
|
|
int period_out_count[MAX_STREAMS];
|
2009-03-18 18:03:53 +08:00
|
|
|
int input_panic, output_panic, warned;
|
2007-03-27 01:11:24 +08:00
|
|
|
char *audio_in_buf, *audio_out_buf;
|
2009-03-18 18:03:54 +08:00
|
|
|
unsigned int samplerates, bpp;
|
2011-08-14 17:31:16 +08:00
|
|
|
unsigned long outurb_active_mask;
|
2007-03-27 01:11:24 +08:00
|
|
|
|
|
|
|
struct snd_pcm_substream *sub_playback[MAX_STREAMS];
|
|
|
|
struct snd_pcm_substream *sub_capture[MAX_STREAMS];
|
|
|
|
|
2007-11-22 18:40:04 +08:00
|
|
|
/* Controls */
|
2010-09-10 17:04:57 +08:00
|
|
|
unsigned char control_state[256];
|
|
|
|
unsigned char ep8_out_buf[2];
|
2007-11-22 18:40:04 +08:00
|
|
|
|
2007-03-27 01:11:24 +08:00
|
|
|
/* Linux input */
|
|
|
|
#ifdef CONFIG_SND_USB_CAIAQ_INPUT
|
|
|
|
struct input_dev *input_dev;
|
2007-11-21 23:45:23 +08:00
|
|
|
char phys[64]; /* physical device path */
|
2010-09-10 17:04:57 +08:00
|
|
|
unsigned short keycode[128];
|
2010-03-22 20:13:37 +08:00
|
|
|
struct urb *ep4_in_urb;
|
|
|
|
unsigned char ep4_in_buf[EP4_BUFSIZE];
|
2007-03-27 01:11:24 +08:00
|
|
|
#endif
|
2007-11-21 23:45:23 +08:00
|
|
|
|
2007-03-27 01:11:24 +08:00
|
|
|
/* ALSA */
|
|
|
|
struct snd_pcm *pcm;
|
|
|
|
struct snd_pcm_hardware pcm_info;
|
|
|
|
struct snd_rawmidi *rmidi;
|
|
|
|
struct snd_rawmidi_substream *midi_receive_substream;
|
|
|
|
struct snd_rawmidi_substream *midi_out_substream;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct snd_usb_caiaq_cb_info {
|
|
|
|
struct snd_usb_caiaqdev *dev;
|
|
|
|
int index;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define caiaqdev(c) ((struct snd_usb_caiaqdev*)(c)->private_data)
|
|
|
|
|
|
|
|
int snd_usb_caiaq_set_audio_params (struct snd_usb_caiaqdev *dev, int rate, int depth, int bbp);
|
|
|
|
int snd_usb_caiaq_set_auto_msg (struct snd_usb_caiaqdev *dev, int digital, int analog, int erp);
|
2007-11-22 18:40:04 +08:00
|
|
|
int snd_usb_caiaq_send_command(struct snd_usb_caiaqdev *dev,
|
|
|
|
unsigned char command,
|
|
|
|
const unsigned char *buffer,
|
|
|
|
int len);
|
2007-03-27 01:11:24 +08:00
|
|
|
|
|
|
|
#endif /* CAIAQ_DEVICE_H */
|