The discovered bit in PGCCSR register indicates if the device has been
[linux-2.6/next.git] / drivers / staging / line6 / driver.h
blob553192f49317dff756dc82adc8e7b9211a0eda57
1 /*
2 * Line6 Linux USB driver - 0.9.1beta
4 * Copyright (C) 2004-2010 Markus Grabner (grabner@icg.tugraz.at)
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License as
8 * published by the Free Software Foundation, version 2.
12 #ifndef DRIVER_H
13 #define DRIVER_H
15 #include <linux/spinlock.h>
16 #include <linux/usb.h>
17 #include <sound/core.h>
19 #include "midi.h"
21 #define DRIVER_NAME "line6usb"
23 #if defined(CONFIG_LINE6_USB_DUMP_CTRL) || defined(CONFIG_LINE6_USB_DUMP_MIDI) || defined(CONFIG_LINE6_USB_DUMP_PCM)
24 #define CONFIG_LINE6_USB_DUMP_ANY
25 #endif
27 #define LINE6_TIMEOUT 1
28 #define LINE6_MAX_DEVICES 8
29 #define LINE6_BUFSIZE_LISTEN 32
30 #define LINE6_MESSAGE_MAXLEN 256
33 Line6 MIDI control commands
35 #define LINE6_PARAM_CHANGE 0xb0
36 #define LINE6_PROGRAM_CHANGE 0xc0
37 #define LINE6_SYSEX_BEGIN 0xf0
38 #define LINE6_SYSEX_END 0xf7
39 #define LINE6_RESET 0xff
42 MIDI channel for messages initiated by the host
43 (and eventually echoed back by the device)
45 #define LINE6_CHANNEL_HOST 0x00
48 MIDI channel for messages initiated by the device
50 #define LINE6_CHANNEL_DEVICE 0x02
52 #define LINE6_CHANNEL_UNKNOWN 5 /* don't know yet what this is good for */
54 #define LINE6_CHANNEL_MASK 0x0f
56 #ifdef CONFIG_LINE6_USB_DEBUG
57 #define DEBUG_MESSAGES(x) (x)
58 #else
59 #define DEBUG_MESSAGES(x)
60 #endif
62 #define MISSING_CASE \
63 printk(KERN_ERR "line6usb driver bug: missing case in %s:%d\n", \
64 __FILE__, __LINE__)
66 #define CHECK_RETURN(x) \
67 do { \
68 err = x; \
69 if (err < 0) \
70 return err; \
71 } while (0)
73 #define CHECK_STARTUP_PROGRESS(x, n) \
74 do { \
75 if ((x) >= (n)) \
76 return; \
77 x = (n); \
78 } while (0)
80 extern const unsigned char line6_midi_id[3];
81 extern struct usb_line6 *line6_devices[LINE6_MAX_DEVICES];
83 static const int SYSEX_DATA_OFS = sizeof(line6_midi_id) + 3;
84 static const int SYSEX_EXTRA_SIZE = sizeof(line6_midi_id) + 4;
86 /**
87 Common properties of Line6 devices.
89 struct line6_properties {
90 /**
91 Card id string (maximum 16 characters).
92 This can be used to address the device in ALSA programs as
93 "default:CARD=<id>"
95 const char *id;
97 /**
98 Card short name (maximum 32 characters).
100 const char *name;
103 Bit identifying this device in the line6usb driver.
105 int device_bit;
108 Bit vector defining this device's capabilities in the
109 line6usb driver.
111 int capabilities;
115 Common data shared by all Line6 devices.
116 Corresponds to a pair of USB endpoints.
118 struct usb_line6 {
120 USB device.
122 struct usb_device *usbdev;
125 Product id.
127 int product;
130 Properties.
132 const struct line6_properties *properties;
135 Interface number.
137 int interface_number;
140 Interval (ms).
142 int interval;
145 Maximum size of USB packet.
147 int max_packet_size;
150 Device representing the USB interface.
152 struct device *ifcdev;
155 Line6 sound card data structure.
156 Each device has at least MIDI or PCM.
158 struct snd_card *card;
161 Line6 PCM device data structure.
163 struct snd_line6_pcm *line6pcm;
166 Line6 MIDI device data structure.
168 struct snd_line6_midi *line6midi;
171 USB endpoint for listening to control commands.
173 int ep_control_read;
176 USB endpoint for writing control commands.
178 int ep_control_write;
181 URB for listening to PODxt Pro control endpoint.
183 struct urb *urb_listen;
186 Buffer for listening to PODxt Pro control endpoint.
188 unsigned char *buffer_listen;
191 Buffer for message to be processed.
193 unsigned char *buffer_message;
196 Length of message to be processed.
198 int message_length;
201 extern char *line6_alloc_sysex_buffer(struct usb_line6 *line6, int code1,
202 int code2, int size);
203 extern ssize_t line6_nop_read(struct device *dev,
204 struct device_attribute *attr, char *buf);
205 extern ssize_t line6_nop_write(struct device *dev,
206 struct device_attribute *attr,
207 const char *buf, size_t count);
208 extern int line6_read_data(struct usb_line6 *line6, int address, void *data,
209 size_t datalen);
210 extern int line6_read_serial_number(struct usb_line6 *line6,
211 int *serial_number);
212 extern int line6_send_program(struct usb_line6 *line6, int value);
213 extern int line6_send_raw_message(struct usb_line6 *line6, const char *buffer,
214 int size);
215 extern int line6_send_raw_message_async(struct usb_line6 *line6,
216 const char *buffer, int size);
217 extern int line6_send_sysex_message(struct usb_line6 *line6,
218 const char *buffer, int size);
219 extern int line6_send_sysex_message_async(struct usb_line6 *line6,
220 const char *buffer, int size);
221 extern ssize_t line6_set_raw(struct device *dev, struct device_attribute *attr,
222 const char *buf, size_t count);
223 extern void line6_start_timer(struct timer_list *timer, unsigned int msecs,
224 void (*function) (unsigned long),
225 unsigned long data);
226 extern int line6_transmit_parameter(struct usb_line6 *line6, int param,
227 int value);
228 extern int line6_version_request_async(struct usb_line6 *line6);
229 extern int line6_write_data(struct usb_line6 *line6, int address, void *data,
230 size_t datalen);
232 #ifdef CONFIG_LINE6_USB_DUMP_ANY
233 extern void line6_write_hexdump(struct usb_line6 *line6, char dir,
234 const unsigned char *buffer, int size);
235 #endif
237 #endif