aboutsummaryrefslogtreecommitdiffstats
path: root/sound/pci/emu10k1/emu10k1_callback.c
diff options
context:
space:
mode:
Diffstat (limited to 'sound/pci/emu10k1/emu10k1_callback.c')
-rw-r--r--sound/pci/emu10k1/emu10k1_callback.c105
1 files changed, 54 insertions, 51 deletions
diff --git a/sound/pci/emu10k1/emu10k1_callback.c b/sound/pci/emu10k1/emu10k1_callback.c
index 6589bf24abcd..01965bd99966 100644
--- a/sound/pci/emu10k1/emu10k1_callback.c
+++ b/sound/pci/emu10k1/emu10k1_callback.c
@@ -27,26 +27,28 @@ enum {
27}; 27};
28 28
29/* Keeps track of what we are finding */ 29/* Keeps track of what we are finding */
30typedef struct best_voice { 30struct best_voice {
31 unsigned int time; 31 unsigned int time;
32 int voice; 32 int voice;
33} best_voice_t; 33};
34 34
35/* 35/*
36 * prototypes 36 * prototypes
37 */ 37 */
38static void lookup_voices(snd_emux_t *emu, emu10k1_t *hw, best_voice_t *best, int active_only); 38static void lookup_voices(struct snd_emux *emu, struct snd_emu10k1 *hw,
39static snd_emux_voice_t *get_voice(snd_emux_t *emu, snd_emux_port_t *port); 39 struct best_voice *best, int active_only);
40static int start_voice(snd_emux_voice_t *vp); 40static struct snd_emux_voice *get_voice(struct snd_emux *emu,
41static void trigger_voice(snd_emux_voice_t *vp); 41 struct snd_emux_port *port);
42static void release_voice(snd_emux_voice_t *vp); 42static int start_voice(struct snd_emux_voice *vp);
43static void update_voice(snd_emux_voice_t *vp, int update); 43static void trigger_voice(struct snd_emux_voice *vp);
44static void terminate_voice(snd_emux_voice_t *vp); 44static void release_voice(struct snd_emux_voice *vp);
45static void free_voice(snd_emux_voice_t *vp); 45static void update_voice(struct snd_emux_voice *vp, int update);
46 46static void terminate_voice(struct snd_emux_voice *vp);
47static void set_fmmod(emu10k1_t *hw, snd_emux_voice_t *vp); 47static void free_voice(struct snd_emux_voice *vp);
48static void set_fm2frq2(emu10k1_t *hw, snd_emux_voice_t *vp); 48
49static void set_filterQ(emu10k1_t *hw, snd_emux_voice_t *vp); 49static void set_fmmod(struct snd_emu10k1 *hw, struct snd_emux_voice *vp);
50static void set_fm2frq2(struct snd_emu10k1 *hw, struct snd_emux_voice *vp);
51static void set_filterQ(struct snd_emu10k1 *hw, struct snd_emux_voice *vp);
50 52
51/* 53/*
52 * Ensure a value is between two points 54 * Ensure a value is between two points
@@ -59,7 +61,7 @@ static void set_filterQ(emu10k1_t *hw, snd_emux_voice_t *vp);
59/* 61/*
60 * set up operators 62 * set up operators
61 */ 63 */
62static snd_emux_operators_t emu10k1_ops = { 64static struct snd_emux_operators emu10k1_ops = {
63 .owner = THIS_MODULE, 65 .owner = THIS_MODULE,
64 .get_voice = get_voice, 66 .get_voice = get_voice,
65 .prepare = start_voice, 67 .prepare = start_voice,
@@ -73,7 +75,7 @@ static snd_emux_operators_t emu10k1_ops = {
73}; 75};
74 76
75void 77void
76snd_emu10k1_ops_setup(snd_emux_t *emu) 78snd_emu10k1_ops_setup(struct snd_emux *emu)
77{ 79{
78 emu->ops = emu10k1_ops; 80 emu->ops = emu10k1_ops;
79} 81}
@@ -85,11 +87,11 @@ snd_emu10k1_ops_setup(snd_emux_t *emu)
85 * terminate most inactive voice and give it as a pcm voice. 87 * terminate most inactive voice and give it as a pcm voice.
86 */ 88 */
87int 89int
88snd_emu10k1_synth_get_voice(emu10k1_t *hw) 90snd_emu10k1_synth_get_voice(struct snd_emu10k1 *hw)
89{ 91{
90 snd_emux_t *emu; 92 struct snd_emux *emu;
91 snd_emux_voice_t *vp; 93 struct snd_emux_voice *vp;
92 best_voice_t best[V_END]; 94 struct best_voice best[V_END];
93 unsigned long flags; 95 unsigned long flags;
94 int i; 96 int i;
95 97
@@ -123,10 +125,10 @@ snd_emu10k1_synth_get_voice(emu10k1_t *hw)
123 * turn off the voice (not terminated) 125 * turn off the voice (not terminated)
124 */ 126 */
125static void 127static void
126release_voice(snd_emux_voice_t *vp) 128release_voice(struct snd_emux_voice *vp)
127{ 129{
128 int dcysusv; 130 int dcysusv;
129 emu10k1_t *hw; 131 struct snd_emu10k1 *hw;
130 132
131 hw = vp->hw; 133 hw = vp->hw;
132 dcysusv = 0x8000 | (unsigned char)vp->reg.parm.modrelease; 134 dcysusv = 0x8000 | (unsigned char)vp->reg.parm.modrelease;
@@ -140,16 +142,16 @@ release_voice(snd_emux_voice_t *vp)
140 * terminate the voice 142 * terminate the voice
141 */ 143 */
142static void 144static void
143terminate_voice(snd_emux_voice_t *vp) 145terminate_voice(struct snd_emux_voice *vp)
144{ 146{
145 emu10k1_t *hw; 147 struct snd_emu10k1 *hw;
146 148
147 snd_assert(vp, return); 149 snd_assert(vp, return);
148 hw = vp->hw; 150 hw = vp->hw;
149 snd_emu10k1_ptr_write(hw, DCYSUSV, vp->ch, 0x807f | DCYSUSV_CHANNELENABLE_MASK); 151 snd_emu10k1_ptr_write(hw, DCYSUSV, vp->ch, 0x807f | DCYSUSV_CHANNELENABLE_MASK);
150 if (vp->block) { 152 if (vp->block) {
151 emu10k1_memblk_t *emem; 153 struct snd_emu10k1_memblk *emem;
152 emem = (emu10k1_memblk_t *)vp->block; 154 emem = (struct snd_emu10k1_memblk *)vp->block;
153 if (emem->map_locked > 0) 155 if (emem->map_locked > 0)
154 emem->map_locked--; 156 emem->map_locked--;
155 } 157 }
@@ -159,9 +161,9 @@ terminate_voice(snd_emux_voice_t *vp)
159 * release the voice to system 161 * release the voice to system
160 */ 162 */
161static void 163static void
162free_voice(snd_emux_voice_t *vp) 164free_voice(struct snd_emux_voice *vp)
163{ 165{
164 emu10k1_t *hw; 166 struct snd_emu10k1 *hw;
165 167
166 hw = vp->hw; 168 hw = vp->hw;
167 if (vp->ch >= 0) { 169 if (vp->ch >= 0) {
@@ -181,9 +183,9 @@ free_voice(snd_emux_voice_t *vp)
181 * update registers 183 * update registers
182 */ 184 */
183static void 185static void
184update_voice(snd_emux_voice_t *vp, int update) 186update_voice(struct snd_emux_voice *vp, int update)
185{ 187{
186 emu10k1_t *hw; 188 struct snd_emu10k1 *hw;
187 189
188 hw = vp->hw; 190 hw = vp->hw;
189 if (update & SNDRV_EMUX_UPDATE_VOLUME) 191 if (update & SNDRV_EMUX_UPDATE_VOLUME)
@@ -210,10 +212,11 @@ update_voice(snd_emux_voice_t *vp, int update)
210 */ 212 */
211/* spinlock held! */ 213/* spinlock held! */
212static void 214static void
213lookup_voices(snd_emux_t *emu, emu10k1_t *hw, best_voice_t *best, int active_only) 215lookup_voices(struct snd_emux *emu, struct snd_emu10k1 *hw,
216 struct best_voice *best, int active_only)
214{ 217{
215 snd_emux_voice_t *vp; 218 struct snd_emux_voice *vp;
216 best_voice_t *bp; 219 struct best_voice *bp;
217 int i; 220 int i;
218 221
219 for (i = 0; i < V_END; i++) { 222 for (i = 0; i < V_END; i++) {
@@ -274,12 +277,12 @@ lookup_voices(snd_emux_t *emu, emu10k1_t *hw, best_voice_t *best, int active_onl
274 * 277 *
275 * emu->voice_lock is already held. 278 * emu->voice_lock is already held.
276 */ 279 */
277static snd_emux_voice_t * 280static struct snd_emux_voice *
278get_voice(snd_emux_t *emu, snd_emux_port_t *port) 281get_voice(struct snd_emux *emu, struct snd_emux_port *port)
279{ 282{
280 emu10k1_t *hw; 283 struct snd_emu10k1 *hw;
281 snd_emux_voice_t *vp; 284 struct snd_emux_voice *vp;
282 best_voice_t best[V_END]; 285 struct best_voice best[V_END];
283 int i; 286 int i;
284 287
285 hw = emu->hw; 288 hw = emu->hw;
@@ -290,7 +293,7 @@ get_voice(snd_emux_t *emu, snd_emux_port_t *port)
290 vp = &emu->voices[best[i].voice]; 293 vp = &emu->voices[best[i].voice];
291 if (vp->ch < 0) { 294 if (vp->ch < 0) {
292 /* allocate a voice */ 295 /* allocate a voice */
293 emu10k1_voice_t *hwvoice; 296 struct snd_emu10k1_voice *hwvoice;
294 if (snd_emu10k1_voice_alloc(hw, EMU10K1_SYNTH, 1, &hwvoice) < 0 || hwvoice == NULL) 297 if (snd_emu10k1_voice_alloc(hw, EMU10K1_SYNTH, 1, &hwvoice) < 0 || hwvoice == NULL)
295 continue; 298 continue;
296 vp->ch = hwvoice->number; 299 vp->ch = hwvoice->number;
@@ -308,21 +311,21 @@ get_voice(snd_emux_t *emu, snd_emux_port_t *port)
308 * prepare envelopes and LFOs 311 * prepare envelopes and LFOs
309 */ 312 */
310static int 313static int
311start_voice(snd_emux_voice_t *vp) 314start_voice(struct snd_emux_voice *vp)
312{ 315{
313 unsigned int temp; 316 unsigned int temp;
314 int ch; 317 int ch;
315 unsigned int addr, mapped_offset; 318 unsigned int addr, mapped_offset;
316 snd_midi_channel_t *chan; 319 struct snd_midi_channel *chan;
317 emu10k1_t *hw; 320 struct snd_emu10k1 *hw;
318 emu10k1_memblk_t *emem; 321 struct snd_emu10k1_memblk *emem;
319 322
320 hw = vp->hw; 323 hw = vp->hw;
321 ch = vp->ch; 324 ch = vp->ch;
322 snd_assert(ch >= 0, return -EINVAL); 325 snd_assert(ch >= 0, return -EINVAL);
323 chan = vp->chan; 326 chan = vp->chan;
324 327
325 emem = (emu10k1_memblk_t *)vp->block; 328 emem = (struct snd_emu10k1_memblk *)vp->block;
326 if (emem == NULL) 329 if (emem == NULL)
327 return -EINVAL; 330 return -EINVAL;
328 emem->map_locked++; 331 emem->map_locked++;
@@ -463,15 +466,15 @@ start_voice(snd_emux_voice_t *vp)
463 * Start envelope 466 * Start envelope
464 */ 467 */
465static void 468static void
466trigger_voice(snd_emux_voice_t *vp) 469trigger_voice(struct snd_emux_voice *vp)
467{ 470{
468 unsigned int temp, ptarget; 471 unsigned int temp, ptarget;
469 emu10k1_t *hw; 472 struct snd_emu10k1 *hw;
470 emu10k1_memblk_t *emem; 473 struct snd_emu10k1_memblk *emem;
471 474
472 hw = vp->hw; 475 hw = vp->hw;
473 476
474 emem = (emu10k1_memblk_t *)vp->block; 477 emem = (struct snd_emu10k1_memblk *)vp->block;
475 if (! emem || emem->mapped_page < 0) 478 if (! emem || emem->mapped_page < 0)
476 return; /* not mapped */ 479 return; /* not mapped */
477 480
@@ -495,7 +498,7 @@ trigger_voice(snd_emux_voice_t *vp)
495 498
496/* set lfo1 modulation height and cutoff */ 499/* set lfo1 modulation height and cutoff */
497static void 500static void
498set_fmmod(emu10k1_t *hw, snd_emux_voice_t *vp) 501set_fmmod(struct snd_emu10k1 *hw, struct snd_emux_voice *vp)
499{ 502{
500 unsigned short fmmod; 503 unsigned short fmmod;
501 short pitch; 504 short pitch;
@@ -513,7 +516,7 @@ set_fmmod(emu10k1_t *hw, snd_emux_voice_t *vp)
513 516
514/* set lfo2 pitch & frequency */ 517/* set lfo2 pitch & frequency */
515static void 518static void
516set_fm2frq2(emu10k1_t *hw, snd_emux_voice_t *vp) 519set_fm2frq2(struct snd_emu10k1 *hw, struct snd_emux_voice *vp)
517{ 520{
518 unsigned short fm2frq2; 521 unsigned short fm2frq2;
519 short pitch; 522 short pitch;
@@ -531,7 +534,7 @@ set_fm2frq2(emu10k1_t *hw, snd_emux_voice_t *vp)
531 534
532/* set filterQ */ 535/* set filterQ */
533static void 536static void
534set_filterQ(emu10k1_t *hw, snd_emux_voice_t *vp) 537set_filterQ(struct snd_emu10k1 *hw, struct snd_emux_voice *vp)
535{ 538{
536 unsigned int val; 539 unsigned int val;
537 val = snd_emu10k1_ptr_read(hw, CCCA, vp->ch) & ~CCCA_RESONANCE; 540 val = snd_emu10k1_ptr_read(hw, CCCA, vp->ch) & ~CCCA_RESONANCE;