Merge tag 'for-linus-2019-10-26' of git://git.kernel.dk/linux-block
[platform/kernel/linux-rpi.git] / include / sound / emux_synth.h
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
2 #ifndef __SOUND_EMUX_SYNTH_H
3 #define __SOUND_EMUX_SYNTH_H
4
5 /*
6  *  Defines for the Emu-series WaveTable chip
7  *
8  *  Copyright (C) 2000 Takashi Iwai <tiwai@suse.de>
9  */
10
11 #include <sound/seq_kernel.h>
12 #include <sound/seq_device.h>
13 #include <sound/soundfont.h>
14 #include <sound/seq_midi_emul.h>
15 #include <sound/seq_oss.h>
16 #include <sound/emux_legacy.h>
17 #include <sound/seq_virmidi.h>
18
19 /*
20  * compile flags
21  */
22 #define SNDRV_EMUX_USE_RAW_EFFECT
23
24 struct snd_emux;
25 struct snd_emux_port;
26 struct snd_emux_voice;
27 struct snd_emux_effect_table;
28
29 /*
30  * operators
31  */
32 struct snd_emux_operators {
33         struct module *owner;
34         struct snd_emux_voice *(*get_voice)(struct snd_emux *emu,
35                                             struct snd_emux_port *port);
36         int (*prepare)(struct snd_emux_voice *vp);
37         void (*trigger)(struct snd_emux_voice *vp);
38         void (*release)(struct snd_emux_voice *vp);
39         void (*update)(struct snd_emux_voice *vp, int update);
40         void (*terminate)(struct snd_emux_voice *vp);
41         void (*free_voice)(struct snd_emux_voice *vp);
42         void (*reset)(struct snd_emux *emu, int ch);
43         /* the first parameters are struct snd_emux */
44         int (*sample_new)(struct snd_emux *emu, struct snd_sf_sample *sp,
45                           struct snd_util_memhdr *hdr,
46                           const void __user *data, long count);
47         int (*sample_free)(struct snd_emux *emu, struct snd_sf_sample *sp,
48                            struct snd_util_memhdr *hdr);
49         void (*sample_reset)(struct snd_emux *emu);
50         int (*load_fx)(struct snd_emux *emu, int type, int arg,
51                        const void __user *data, long count);
52         void (*sysex)(struct snd_emux *emu, char *buf, int len, int parsed,
53                       struct snd_midi_channel_set *chset);
54 #if IS_ENABLED(CONFIG_SND_SEQUENCER_OSS)
55         int (*oss_ioctl)(struct snd_emux *emu, int cmd, int p1, int p2);
56 #endif
57 };
58
59
60 /*
61  * constant values
62  */
63 #define SNDRV_EMUX_MAX_PORTS            32      /* max # of sequencer ports */
64 #define SNDRV_EMUX_MAX_VOICES           64      /* max # of voices */
65 #define SNDRV_EMUX_MAX_MULTI_VOICES     16      /* max # of playable voices
66                                                  * simultineously
67                                                  */
68
69 /*
70  * flags
71  */
72 #define SNDRV_EMUX_ACCEPT_ROM           (1<<0)
73
74 /*
75  * emuX wavetable
76  */
77 struct snd_emux {
78
79         struct snd_card *card;  /* assigned card */
80
81         /* following should be initialized before registration */
82         int max_voices;         /* Number of voices */
83         int mem_size;           /* memory size (in byte) */
84         int num_ports;          /* number of ports to be created */
85         int pitch_shift;        /* pitch shift value (for Emu10k1) */
86         struct snd_emux_operators ops;  /* operators */
87         void *hw;               /* hardware */
88         unsigned long flags;    /* other conditions */
89         int midi_ports;         /* number of virtual midi devices */
90         int midi_devidx;        /* device offset of virtual midi */
91         unsigned int linear_panning: 1; /* panning is linear (sbawe = 1, emu10k1 = 0) */
92         int hwdep_idx;          /* hwdep device index */
93         struct snd_hwdep *hwdep;        /* hwdep device */
94
95         /* private */
96         int num_voices;         /* current number of voices */
97         struct snd_sf_list *sflist;     /* root of SoundFont list */
98         struct snd_emux_voice *voices;  /* Voices (EMU 'channel') */
99         int use_time;   /* allocation counter */
100         spinlock_t voice_lock;  /* Lock for voice access */
101         struct mutex register_mutex;
102         int client;             /* For the sequencer client */
103         int ports[SNDRV_EMUX_MAX_PORTS];        /* The ports for this device */
104         struct snd_emux_port *portptrs[SNDRV_EMUX_MAX_PORTS];
105         int used;       /* use counter */
106         char *name;     /* name of the device (internal) */
107         struct snd_rawmidi **vmidi;
108         struct timer_list tlist;        /* for pending note-offs */
109         int timer_active;
110
111         struct snd_util_memhdr *memhdr; /* memory chunk information */
112
113 #ifdef CONFIG_SND_PROC_FS
114         struct snd_info_entry *proc;
115 #endif
116
117 #if IS_ENABLED(CONFIG_SND_SEQUENCER_OSS)
118         struct snd_seq_device *oss_synth;
119 #endif
120 };
121
122
123 /*
124  * sequencer port information
125  */
126 struct snd_emux_port {
127
128         struct snd_midi_channel_set chset;
129         struct snd_emux *emu;
130
131         char port_mode;                 /* operation mode */
132         int volume_atten;               /* emuX raw attenuation */
133         unsigned long drum_flags;       /* drum bitmaps */
134         int ctrls[EMUX_MD_END];         /* control parameters */
135 #ifdef SNDRV_EMUX_USE_RAW_EFFECT
136         struct snd_emux_effect_table *effect;
137 #endif
138 #if IS_ENABLED(CONFIG_SND_SEQUENCER_OSS)
139         struct snd_seq_oss_arg *oss_arg;
140 #endif
141 };
142
143 /* port_mode */
144 #define SNDRV_EMUX_PORT_MODE_MIDI               0       /* normal MIDI port */
145 #define SNDRV_EMUX_PORT_MODE_OSS_SYNTH  1       /* OSS synth port */
146 #define SNDRV_EMUX_PORT_MODE_OSS_MIDI   2       /* OSS multi channel synth port */
147
148 /*
149  * A structure to keep track of each hardware voice
150  */
151 struct snd_emux_voice {
152         int  ch;                /* Hardware channel number */
153
154         int  state;             /* status */
155 #define SNDRV_EMUX_ST_OFF               0x00    /* Not playing, and inactive */
156 #define SNDRV_EMUX_ST_ON                0x01    /* Note on */
157 #define SNDRV_EMUX_ST_RELEASED  (0x02|SNDRV_EMUX_ST_ON) /* Note released */
158 #define SNDRV_EMUX_ST_SUSTAINED (0x04|SNDRV_EMUX_ST_ON) /* Note sustained */
159 #define SNDRV_EMUX_ST_STANDBY   (0x08|SNDRV_EMUX_ST_ON) /* Waiting to be triggered */
160 #define SNDRV_EMUX_ST_PENDING   (0x10|SNDRV_EMUX_ST_ON) /* Note will be released */
161 #define SNDRV_EMUX_ST_LOCKED            0x100   /* Not accessible */
162
163         unsigned int  time;     /* An allocation time */
164         unsigned char note;     /* Note currently assigned to this voice */
165         unsigned char key;
166         unsigned char velocity; /* Velocity of current note */
167
168         struct snd_sf_zone *zone;       /* Zone assigned to this note */
169         void *block;            /* sample block pointer (optional) */
170         struct snd_midi_channel *chan;  /* Midi channel for this note */
171         struct snd_emux_port *port;     /* associated port */
172         struct snd_emux *emu;   /* assigned root info */
173         void *hw;               /* hardware pointer (emu8000 or emu10k1) */
174         unsigned long ontime;   /* jiffies at note triggered */
175         
176         /* Emu8k/Emu10k1 registers */
177         struct soundfont_voice_info reg;
178
179         /* additional registers */
180         int avol;               /* volume attenuation */
181         int acutoff;            /* cutoff target */
182         int apitch;             /* pitch offset */
183         int apan;               /* pan/aux pair */
184         int aaux;
185         int ptarget;            /* pitch target */
186         int vtarget;            /* volume target */
187         int ftarget;            /* filter target */
188
189 };
190
191 /*
192  * update flags (can be combined)
193  */
194 #define SNDRV_EMUX_UPDATE_VOLUME                (1<<0)
195 #define SNDRV_EMUX_UPDATE_PITCH         (1<<1)
196 #define SNDRV_EMUX_UPDATE_PAN           (1<<2)
197 #define SNDRV_EMUX_UPDATE_FMMOD         (1<<3)
198 #define SNDRV_EMUX_UPDATE_TREMFREQ      (1<<4)
199 #define SNDRV_EMUX_UPDATE_FM2FRQ2               (1<<5)
200 #define SNDRV_EMUX_UPDATE_Q             (1<<6)
201
202
203 #ifdef SNDRV_EMUX_USE_RAW_EFFECT
204 /*
205  * effect table
206  */
207 struct snd_emux_effect_table {
208         /* Emu8000 specific effects */
209         short val[EMUX_NUM_EFFECTS];
210         unsigned char flag[EMUX_NUM_EFFECTS];
211 };
212 #endif /* SNDRV_EMUX_USE_RAW_EFFECT */
213
214
215 /*
216  * prototypes - interface to Emu10k1 and Emu8k routines
217  */
218 int snd_emux_new(struct snd_emux **remu);
219 int snd_emux_register(struct snd_emux *emu, struct snd_card *card, int index, char *name);
220 int snd_emux_free(struct snd_emux *emu);
221
222 /*
223  * exported functions
224  */
225 void snd_emux_terminate_all(struct snd_emux *emu);
226 void snd_emux_lock_voice(struct snd_emux *emu, int voice);
227 void snd_emux_unlock_voice(struct snd_emux *emu, int voice);
228
229 #endif /* __SOUND_EMUX_SYNTH_H */