aboutsummaryrefslogtreecommitdiffstats
path: root/sound/oss/emu10k1/midi.h
blob: 2459ec929e8d06827f9b3c4761f4adc0b0172816 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/*     
 **********************************************************************
 *     midi.h
 *     Copyright 1999, 2000 Creative Labs, Inc. 
 * 
 ********************************************************************** 
 * 
 *     Date                 Author          Summary of changes 
 *     ----                 ------          ------------------ 
 *     October 20, 1999     Bertrand Lee    base code release 
 * 
 ********************************************************************** 
 * 
 *     This program is free software; you can redistribute it and/or 
 *     modify it under the terms of the GNU General Public License as 
 *     published by the Free Software Foundation; either version 2 of 
 *     the License, or (at your option) any later version. 
 * 
 *     This program is distributed in the hope that it will be useful, 
 *     but WITHOUT ANY WARRANTY; without even the implied warranty of 
 *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
 *     GNU General Public License for more details. 
 * 
 *     You should have received a copy of the GNU General Public 
 *     License along with this program; if not, write to the Free 
 *     Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, 
 *     USA. 
 * 
 ********************************************************************** 
 */ 

#ifndef _MIDI_H
#define _MIDI_H

#define FMODE_MIDI_SHIFT 3
#define FMODE_MIDI_READ  (FMODE_READ << FMODE_MIDI_SHIFT)
#define FMODE_MIDI_WRITE (FMODE_WRITE << FMODE_MIDI_SHIFT)

#define MIDIIN_STATE_STARTED 0x00000001
#define MIDIIN_STATE_STOPPED 0x00000002

#define MIDIIN_BUFLEN 1024

struct emu10k1_mididevice
{
	struct emu10k1_card *card;
	u32 mistate;
	wait_queue_head_t oWait;
	wait_queue_head_t iWait;
	s8 iBuf[MIDIIN_BUFLEN];
	u16 ird, iwr, icnt;
	struct list_head mid_hdrs;
};

/* uncomment next line to use midi port on Audigy drive */
//#define USE_AUDIGY_DRIVE_MIDI

#ifdef USE_AUDIGY_DRIVE_MIDI
#define A_MUDATA	A_MUDATA2
#define A_MUCMD		A_MUCMD2
#define A_MUSTAT	A_MUCMD2
#define A_IPR_MIDITRANSBUFEMPTY	A_IPR_MIDITRANSBUFEMPTY2
#define A_IPR_MIDIRECVBUFEMPTY	A_IPR_MIDIRECVBUFEMPTY2
#define A_INTE_MIDITXENABLE	A_INTE_MIDITXENABLE2
#define A_INTE_MIDIRXENABLE	A_INTE_MIDIRXENABLE2
#else
#define A_MUDATA	A_MUDATA1
#define A_MUCMD		A_MUCMD1
#define A_MUSTAT	A_MUCMD1
#define A_IPR_MIDITRANSBUFEMPTY	A_IPR_MIDITRANSBUFEMPTY1
#define A_IPR_MIDIRECVBUFEMPTY	A_IPR_MIDIRECVBUFEMPTY1
#define A_INTE_MIDITXENABLE	A_INTE_MIDITXENABLE1
#define A_INTE_MIDIRXENABLE	A_INTE_MIDIRXENABLE1
#endif


#endif /* _MIDI_H */