xref: /kernel/linux/linux-6.6/sound/usb/caiaq/device.h (revision 62306a36)
162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci#ifndef CAIAQ_DEVICE_H
362306a36Sopenharmony_ci#define CAIAQ_DEVICE_H
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci#include "../usbaudio.h"
662306a36Sopenharmony_ci
762306a36Sopenharmony_ci#define USB_VID_NATIVEINSTRUMENTS 0x17cc
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#define USB_PID_RIGKONTROL2		0x1969
1062306a36Sopenharmony_ci#define USB_PID_RIGKONTROL3		0x1940
1162306a36Sopenharmony_ci#define USB_PID_KORECONTROLLER		0x4711
1262306a36Sopenharmony_ci#define USB_PID_KORECONTROLLER2		0x4712
1362306a36Sopenharmony_ci#define USB_PID_AK1			0x0815
1462306a36Sopenharmony_ci#define USB_PID_AUDIO2DJ		0x041c
1562306a36Sopenharmony_ci#define USB_PID_AUDIO4DJ		0x0839
1662306a36Sopenharmony_ci#define USB_PID_AUDIO8DJ		0x1978
1762306a36Sopenharmony_ci#define USB_PID_SESSIONIO		0x1915
1862306a36Sopenharmony_ci#define USB_PID_GUITARRIGMOBILE		0x0d8d
1962306a36Sopenharmony_ci#define USB_PID_TRAKTORKONTROLX1	0x2305
2062306a36Sopenharmony_ci#define USB_PID_TRAKTORKONTROLS4	0xbaff
2162306a36Sopenharmony_ci#define USB_PID_TRAKTORAUDIO2		0x041d
2262306a36Sopenharmony_ci#define USB_PID_MASCHINECONTROLLER  0x0808
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci#define EP1_BUFSIZE 64
2562306a36Sopenharmony_ci#define EP4_BUFSIZE 512
2662306a36Sopenharmony_ci#define CAIAQ_USB_STR_LEN 0xff
2762306a36Sopenharmony_ci#define MAX_STREAMS 32
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci#define MODNAME "snd-usb-caiaq"
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci#define EP1_CMD_GET_DEVICE_INFO	0x1
3262306a36Sopenharmony_ci#define EP1_CMD_READ_ERP	0x2
3362306a36Sopenharmony_ci#define EP1_CMD_READ_ANALOG	0x3
3462306a36Sopenharmony_ci#define EP1_CMD_READ_IO		0x4
3562306a36Sopenharmony_ci#define EP1_CMD_WRITE_IO	0x5
3662306a36Sopenharmony_ci#define EP1_CMD_MIDI_READ	0x6
3762306a36Sopenharmony_ci#define EP1_CMD_MIDI_WRITE	0x7
3862306a36Sopenharmony_ci#define EP1_CMD_AUDIO_PARAMS	0x9
3962306a36Sopenharmony_ci#define EP1_CMD_AUTO_MSG	0xb
4062306a36Sopenharmony_ci#define EP1_CMD_DIMM_LEDS       0xc
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_cistruct caiaq_device_spec {
4362306a36Sopenharmony_ci	unsigned short fw_version;
4462306a36Sopenharmony_ci	unsigned char hw_subtype;
4562306a36Sopenharmony_ci	unsigned char num_erp;
4662306a36Sopenharmony_ci	unsigned char num_analog_in;
4762306a36Sopenharmony_ci	unsigned char num_digital_in;
4862306a36Sopenharmony_ci	unsigned char num_digital_out;
4962306a36Sopenharmony_ci	unsigned char num_analog_audio_out;
5062306a36Sopenharmony_ci	unsigned char num_analog_audio_in;
5162306a36Sopenharmony_ci	unsigned char num_digital_audio_out;
5262306a36Sopenharmony_ci	unsigned char num_digital_audio_in;
5362306a36Sopenharmony_ci	unsigned char num_midi_out;
5462306a36Sopenharmony_ci	unsigned char num_midi_in;
5562306a36Sopenharmony_ci	unsigned char data_alignment;
5662306a36Sopenharmony_ci} __attribute__ ((packed));
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_cistruct snd_usb_caiaq_cb_info;
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_cistruct snd_usb_caiaqdev {
6162306a36Sopenharmony_ci	struct snd_usb_audio chip;
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ci	struct urb ep1_in_urb;
6462306a36Sopenharmony_ci	struct urb midi_out_urb;
6562306a36Sopenharmony_ci	struct urb **data_urbs_in;
6662306a36Sopenharmony_ci	struct urb **data_urbs_out;
6762306a36Sopenharmony_ci	struct snd_usb_caiaq_cb_info *data_cb_info;
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ci	unsigned char ep1_in_buf[EP1_BUFSIZE];
7062306a36Sopenharmony_ci	unsigned char ep1_out_buf[EP1_BUFSIZE];
7162306a36Sopenharmony_ci	unsigned char midi_out_buf[EP1_BUFSIZE];
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci	struct caiaq_device_spec spec;
7462306a36Sopenharmony_ci	spinlock_t spinlock;
7562306a36Sopenharmony_ci	wait_queue_head_t ep1_wait_queue;
7662306a36Sopenharmony_ci	wait_queue_head_t prepare_wait_queue;
7762306a36Sopenharmony_ci	int spec_received, audio_parm_answer;
7862306a36Sopenharmony_ci	int midi_out_active;
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci	char vendor_name[CAIAQ_USB_STR_LEN];
8162306a36Sopenharmony_ci	char product_name[CAIAQ_USB_STR_LEN];
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_ci	int n_streams, n_audio_in, n_audio_out;
8462306a36Sopenharmony_ci	int streaming, first_packet, output_running;
8562306a36Sopenharmony_ci	int audio_in_buf_pos[MAX_STREAMS];
8662306a36Sopenharmony_ci	int audio_out_buf_pos[MAX_STREAMS];
8762306a36Sopenharmony_ci	int period_in_count[MAX_STREAMS];
8862306a36Sopenharmony_ci	int period_out_count[MAX_STREAMS];
8962306a36Sopenharmony_ci	int input_panic, output_panic, warned;
9062306a36Sopenharmony_ci	char *audio_in_buf, *audio_out_buf;
9162306a36Sopenharmony_ci	unsigned int samplerates, bpp;
9262306a36Sopenharmony_ci	unsigned long outurb_active_mask;
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_ci	struct snd_pcm_substream *sub_playback[MAX_STREAMS];
9562306a36Sopenharmony_ci	struct snd_pcm_substream *sub_capture[MAX_STREAMS];
9662306a36Sopenharmony_ci
9762306a36Sopenharmony_ci	/* Controls */
9862306a36Sopenharmony_ci	unsigned char control_state[256];
9962306a36Sopenharmony_ci	unsigned char ep8_out_buf[2];
10062306a36Sopenharmony_ci
10162306a36Sopenharmony_ci	/* Linux input */
10262306a36Sopenharmony_ci#ifdef CONFIG_SND_USB_CAIAQ_INPUT
10362306a36Sopenharmony_ci	struct input_dev *input_dev;
10462306a36Sopenharmony_ci	char phys[64];			/* physical device path */
10562306a36Sopenharmony_ci	unsigned short keycode[128];
10662306a36Sopenharmony_ci	struct urb *ep4_in_urb;
10762306a36Sopenharmony_ci	unsigned char ep4_in_buf[EP4_BUFSIZE];
10862306a36Sopenharmony_ci#endif
10962306a36Sopenharmony_ci
11062306a36Sopenharmony_ci	/* ALSA */
11162306a36Sopenharmony_ci	struct snd_pcm *pcm;
11262306a36Sopenharmony_ci	struct snd_pcm_hardware pcm_info;
11362306a36Sopenharmony_ci	struct snd_rawmidi *rmidi;
11462306a36Sopenharmony_ci	struct snd_rawmidi_substream *midi_receive_substream;
11562306a36Sopenharmony_ci	struct snd_rawmidi_substream *midi_out_substream;
11662306a36Sopenharmony_ci};
11762306a36Sopenharmony_ci
11862306a36Sopenharmony_cistruct snd_usb_caiaq_cb_info {
11962306a36Sopenharmony_ci	struct snd_usb_caiaqdev *cdev;
12062306a36Sopenharmony_ci	int index;
12162306a36Sopenharmony_ci};
12262306a36Sopenharmony_ci
12362306a36Sopenharmony_ci#define caiaqdev(c) ((struct snd_usb_caiaqdev*)(c)->private_data)
12462306a36Sopenharmony_ci#define caiaqdev_to_dev(d)	(d->chip.card->dev)
12562306a36Sopenharmony_ci
12662306a36Sopenharmony_ciint snd_usb_caiaq_set_audio_params (struct snd_usb_caiaqdev *cdev, int rate, int depth, int bbp);
12762306a36Sopenharmony_ciint snd_usb_caiaq_set_auto_msg (struct snd_usb_caiaqdev *cdev, int digital, int analog, int erp);
12862306a36Sopenharmony_ciint snd_usb_caiaq_send_command(struct snd_usb_caiaqdev *cdev,
12962306a36Sopenharmony_ci			       unsigned char command,
13062306a36Sopenharmony_ci			       const unsigned char *buffer,
13162306a36Sopenharmony_ci			       int len);
13262306a36Sopenharmony_ciint snd_usb_caiaq_send_command_bank(struct snd_usb_caiaqdev *cdev,
13362306a36Sopenharmony_ci			       unsigned char command,
13462306a36Sopenharmony_ci			       unsigned char bank,
13562306a36Sopenharmony_ci			       const unsigned char *buffer,
13662306a36Sopenharmony_ci			       int len);
13762306a36Sopenharmony_ci
13862306a36Sopenharmony_ci#endif /* CAIAQ_DEVICE_H */
139