RISC-V: Make mmap() with PROT_WRITE imply PROT_READ
[platform/kernel/linux-starfive.git] / sound / pci / es1938.c
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  *  Driver for ESS Solo-1 (ES1938, ES1946, ES1969) soundcard
4  *  Copyright (c) by Jaromir Koutek <miri@punknet.cz>,
5  *                   Jaroslav Kysela <perex@perex.cz>,
6  *                   Thomas Sailer <sailer@ife.ee.ethz.ch>,
7  *                   Abramo Bagnara <abramo@alsa-project.org>,
8  *                   Markus Gruber <gruber@eikon.tum.de>
9  * 
10  * Rewritten from sonicvibes.c source.
11  *
12  *  TODO:
13  *    Rewrite better spinlocks
14  */
15
16 /*
17   NOTES:
18   - Capture data is written unaligned starting from dma_base + 1 so I need to
19     disable mmap and to add a copy callback.
20   - After several cycle of the following:
21     while : ; do arecord -d1 -f cd -t raw | aplay -f cd ; done
22     a "playback write error (DMA or IRQ trouble?)" may happen.
23     This is due to playback interrupts not generated.
24     I suspect a timing issue.
25   - Sometimes the interrupt handler is invoked wrongly during playback.
26     This generates some harmless "Unexpected hw_pointer: wrong interrupt
27     acknowledge".
28     I've seen that using small period sizes.
29     Reproducible with:
30     mpg123 test.mp3 &
31     hdparm -t -T /dev/hda
32 */
33
34
35 #include <linux/init.h>
36 #include <linux/interrupt.h>
37 #include <linux/pci.h>
38 #include <linux/slab.h>
39 #include <linux/gameport.h>
40 #include <linux/module.h>
41 #include <linux/delay.h>
42 #include <linux/dma-mapping.h>
43 #include <linux/io.h>
44 #include <sound/core.h>
45 #include <sound/control.h>
46 #include <sound/pcm.h>
47 #include <sound/opl3.h>
48 #include <sound/mpu401.h>
49 #include <sound/initval.h>
50 #include <sound/tlv.h>
51
52 MODULE_AUTHOR("Jaromir Koutek <miri@punknet.cz>");
53 MODULE_DESCRIPTION("ESS Solo-1");
54 MODULE_LICENSE("GPL");
55
56 #if IS_REACHABLE(CONFIG_GAMEPORT)
57 #define SUPPORT_JOYSTICK 1
58 #endif
59
60 static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;      /* Index 0-MAX */
61 static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR;       /* ID for this card */
62 static bool enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP;     /* Enable this card */
63
64 module_param_array(index, int, NULL, 0444);
65 MODULE_PARM_DESC(index, "Index value for ESS Solo-1 soundcard.");
66 module_param_array(id, charp, NULL, 0444);
67 MODULE_PARM_DESC(id, "ID string for ESS Solo-1 soundcard.");
68 module_param_array(enable, bool, NULL, 0444);
69 MODULE_PARM_DESC(enable, "Enable ESS Solo-1 soundcard.");
70
71 #define SLIO_REG(chip, x) ((chip)->io_port + ESSIO_REG_##x)
72
73 #define SLDM_REG(chip, x) ((chip)->ddma_port + ESSDM_REG_##x)
74
75 #define SLSB_REG(chip, x) ((chip)->sb_port + ESSSB_REG_##x)
76
77 #define SL_PCI_LEGACYCONTROL            0x40
78 #define SL_PCI_CONFIG                   0x50
79 #define SL_PCI_DDMACONTROL              0x60
80
81 #define ESSIO_REG_AUDIO2DMAADDR         0
82 #define ESSIO_REG_AUDIO2DMACOUNT        4
83 #define ESSIO_REG_AUDIO2MODE            6
84 #define ESSIO_REG_IRQCONTROL            7
85
86 #define ESSDM_REG_DMAADDR               0x00
87 #define ESSDM_REG_DMACOUNT              0x04
88 #define ESSDM_REG_DMACOMMAND            0x08
89 #define ESSDM_REG_DMASTATUS             0x08
90 #define ESSDM_REG_DMAMODE               0x0b
91 #define ESSDM_REG_DMACLEAR              0x0d
92 #define ESSDM_REG_DMAMASK               0x0f
93
94 #define ESSSB_REG_FMLOWADDR             0x00
95 #define ESSSB_REG_FMHIGHADDR            0x02
96 #define ESSSB_REG_MIXERADDR             0x04
97 #define ESSSB_REG_MIXERDATA             0x05
98
99 #define ESSSB_IREG_AUDIO1               0x14
100 #define ESSSB_IREG_MICMIX               0x1a
101 #define ESSSB_IREG_RECSRC               0x1c
102 #define ESSSB_IREG_MASTER               0x32
103 #define ESSSB_IREG_FM                   0x36
104 #define ESSSB_IREG_AUXACD               0x38
105 #define ESSSB_IREG_AUXB                 0x3a
106 #define ESSSB_IREG_PCSPEAKER            0x3c
107 #define ESSSB_IREG_LINE                 0x3e
108 #define ESSSB_IREG_SPATCONTROL          0x50
109 #define ESSSB_IREG_SPATLEVEL            0x52
110 #define ESSSB_IREG_MASTER_LEFT          0x60
111 #define ESSSB_IREG_MASTER_RIGHT         0x62
112 #define ESSSB_IREG_MPU401CONTROL        0x64
113 #define ESSSB_IREG_MICMIXRECORD         0x68
114 #define ESSSB_IREG_AUDIO2RECORD         0x69
115 #define ESSSB_IREG_AUXACDRECORD         0x6a
116 #define ESSSB_IREG_FMRECORD             0x6b
117 #define ESSSB_IREG_AUXBRECORD           0x6c
118 #define ESSSB_IREG_MONO                 0x6d
119 #define ESSSB_IREG_LINERECORD           0x6e
120 #define ESSSB_IREG_MONORECORD           0x6f
121 #define ESSSB_IREG_AUDIO2SAMPLE         0x70
122 #define ESSSB_IREG_AUDIO2MODE           0x71
123 #define ESSSB_IREG_AUDIO2FILTER         0x72
124 #define ESSSB_IREG_AUDIO2TCOUNTL        0x74
125 #define ESSSB_IREG_AUDIO2TCOUNTH        0x76
126 #define ESSSB_IREG_AUDIO2CONTROL1       0x78
127 #define ESSSB_IREG_AUDIO2CONTROL2       0x7a
128 #define ESSSB_IREG_AUDIO2               0x7c
129
130 #define ESSSB_REG_RESET                 0x06
131
132 #define ESSSB_REG_READDATA              0x0a
133 #define ESSSB_REG_WRITEDATA             0x0c
134 #define ESSSB_REG_READSTATUS            0x0c
135
136 #define ESSSB_REG_STATUS                0x0e
137
138 #define ESS_CMD_EXTSAMPLERATE           0xa1
139 #define ESS_CMD_FILTERDIV               0xa2
140 #define ESS_CMD_DMACNTRELOADL           0xa4
141 #define ESS_CMD_DMACNTRELOADH           0xa5
142 #define ESS_CMD_ANALOGCONTROL           0xa8
143 #define ESS_CMD_IRQCONTROL              0xb1
144 #define ESS_CMD_DRQCONTROL              0xb2
145 #define ESS_CMD_RECLEVEL                0xb4
146 #define ESS_CMD_SETFORMAT               0xb6
147 #define ESS_CMD_SETFORMAT2              0xb7
148 #define ESS_CMD_DMACONTROL              0xb8
149 #define ESS_CMD_DMATYPE                 0xb9
150 #define ESS_CMD_OFFSETLEFT              0xba    
151 #define ESS_CMD_OFFSETRIGHT             0xbb
152 #define ESS_CMD_READREG                 0xc0
153 #define ESS_CMD_ENABLEEXT               0xc6
154 #define ESS_CMD_PAUSEDMA                0xd0
155 #define ESS_CMD_ENABLEAUDIO1            0xd1
156 #define ESS_CMD_STOPAUDIO1              0xd3
157 #define ESS_CMD_AUDIO1STATUS            0xd8
158 #define ESS_CMD_CONTDMA                 0xd4
159 #define ESS_CMD_TESTIRQ                 0xf2
160
161 #define ESS_RECSRC_MIC          0
162 #define ESS_RECSRC_AUXACD       2
163 #define ESS_RECSRC_AUXB         5
164 #define ESS_RECSRC_LINE         6
165 #define ESS_RECSRC_NONE         7
166
167 #define DAC1 0x01
168 #define ADC1 0x02
169 #define DAC2 0x04
170
171 /*
172
173  */
174
175 #define SAVED_REG_SIZE  32 /* max. number of registers to save */
176
177 struct es1938 {
178         int irq;
179
180         unsigned long io_port;
181         unsigned long sb_port;
182         unsigned long vc_port;
183         unsigned long mpu_port;
184         unsigned long game_port;
185         unsigned long ddma_port;
186
187         unsigned char irqmask;
188         unsigned char revision;
189
190         struct snd_kcontrol *hw_volume;
191         struct snd_kcontrol *hw_switch;
192         struct snd_kcontrol *master_volume;
193         struct snd_kcontrol *master_switch;
194
195         struct pci_dev *pci;
196         struct snd_card *card;
197         struct snd_pcm *pcm;
198         struct snd_pcm_substream *capture_substream;
199         struct snd_pcm_substream *playback1_substream;
200         struct snd_pcm_substream *playback2_substream;
201         struct snd_rawmidi *rmidi;
202
203         unsigned int dma1_size;
204         unsigned int dma2_size;
205         unsigned int dma1_start;
206         unsigned int dma2_start;
207         unsigned int dma1_shift;
208         unsigned int dma2_shift;
209         unsigned int last_capture_dmaaddr;
210         unsigned int active;
211
212         spinlock_t reg_lock;
213         spinlock_t mixer_lock;
214         struct snd_info_entry *proc_entry;
215
216 #ifdef SUPPORT_JOYSTICK
217         struct gameport *gameport;
218 #endif
219 #ifdef CONFIG_PM_SLEEP
220         unsigned char saved_regs[SAVED_REG_SIZE];
221 #endif
222 };
223
224 static irqreturn_t snd_es1938_interrupt(int irq, void *dev_id);
225
226 static const struct pci_device_id snd_es1938_ids[] = {
227         { PCI_VDEVICE(ESS, 0x1969), 0, },   /* Solo-1 */
228         { 0, }
229 };
230
231 MODULE_DEVICE_TABLE(pci, snd_es1938_ids);
232
233 #define RESET_LOOP_TIMEOUT      0x10000
234 #define WRITE_LOOP_TIMEOUT      0x10000
235 #define GET_LOOP_TIMEOUT        0x01000
236
237 /* -----------------------------------------------------------------
238  * Write to a mixer register
239  * -----------------------------------------------------------------*/
240 static void snd_es1938_mixer_write(struct es1938 *chip, unsigned char reg, unsigned char val)
241 {
242         unsigned long flags;
243         spin_lock_irqsave(&chip->mixer_lock, flags);
244         outb(reg, SLSB_REG(chip, MIXERADDR));
245         outb(val, SLSB_REG(chip, MIXERDATA));
246         spin_unlock_irqrestore(&chip->mixer_lock, flags);
247         dev_dbg(chip->card->dev, "Mixer reg %02x set to %02x\n", reg, val);
248 }
249
250 /* -----------------------------------------------------------------
251  * Read from a mixer register
252  * -----------------------------------------------------------------*/
253 static int snd_es1938_mixer_read(struct es1938 *chip, unsigned char reg)
254 {
255         int data;
256         unsigned long flags;
257         spin_lock_irqsave(&chip->mixer_lock, flags);
258         outb(reg, SLSB_REG(chip, MIXERADDR));
259         data = inb(SLSB_REG(chip, MIXERDATA));
260         spin_unlock_irqrestore(&chip->mixer_lock, flags);
261         dev_dbg(chip->card->dev, "Mixer reg %02x now is %02x\n", reg, data);
262         return data;
263 }
264
265 /* -----------------------------------------------------------------
266  * Write to some bits of a mixer register (return old value)
267  * -----------------------------------------------------------------*/
268 static int snd_es1938_mixer_bits(struct es1938 *chip, unsigned char reg,
269                                  unsigned char mask, unsigned char val)
270 {
271         unsigned long flags;
272         unsigned char old, new, oval;
273         spin_lock_irqsave(&chip->mixer_lock, flags);
274         outb(reg, SLSB_REG(chip, MIXERADDR));
275         old = inb(SLSB_REG(chip, MIXERDATA));
276         oval = old & mask;
277         if (val != oval) {
278                 new = (old & ~mask) | (val & mask);
279                 outb(new, SLSB_REG(chip, MIXERDATA));
280                 dev_dbg(chip->card->dev,
281                         "Mixer reg %02x was %02x, set to %02x\n",
282                            reg, old, new);
283         }
284         spin_unlock_irqrestore(&chip->mixer_lock, flags);
285         return oval;
286 }
287
288 /* -----------------------------------------------------------------
289  * Write command to Controller Registers
290  * -----------------------------------------------------------------*/
291 static void snd_es1938_write_cmd(struct es1938 *chip, unsigned char cmd)
292 {
293         int i;
294         unsigned char v;
295         for (i = 0; i < WRITE_LOOP_TIMEOUT; i++) {
296                 v = inb(SLSB_REG(chip, READSTATUS));
297                 if (!(v & 0x80)) {
298                         outb(cmd, SLSB_REG(chip, WRITEDATA));
299                         return;
300                 }
301         }
302         dev_err(chip->card->dev,
303                 "snd_es1938_write_cmd timeout (0x02%x/0x02%x)\n", cmd, v);
304 }
305
306 /* -----------------------------------------------------------------
307  * Read the Read Data Buffer
308  * -----------------------------------------------------------------*/
309 static int snd_es1938_get_byte(struct es1938 *chip)
310 {
311         int i;
312         unsigned char v;
313         for (i = GET_LOOP_TIMEOUT; i; i--) {
314                 v = inb(SLSB_REG(chip, STATUS));
315                 if (v & 0x80)
316                         return inb(SLSB_REG(chip, READDATA));
317         }
318         dev_err(chip->card->dev, "get_byte timeout: status 0x02%x\n", v);
319         return -ENODEV;
320 }
321
322 /* -----------------------------------------------------------------
323  * Write value cmd register
324  * -----------------------------------------------------------------*/
325 static void snd_es1938_write(struct es1938 *chip, unsigned char reg, unsigned char val)
326 {
327         unsigned long flags;
328         spin_lock_irqsave(&chip->reg_lock, flags);
329         snd_es1938_write_cmd(chip, reg);
330         snd_es1938_write_cmd(chip, val);
331         spin_unlock_irqrestore(&chip->reg_lock, flags);
332         dev_dbg(chip->card->dev, "Reg %02x set to %02x\n", reg, val);
333 }
334
335 /* -----------------------------------------------------------------
336  * Read data from cmd register and return it
337  * -----------------------------------------------------------------*/
338 static unsigned char snd_es1938_read(struct es1938 *chip, unsigned char reg)
339 {
340         unsigned char val;
341         unsigned long flags;
342         spin_lock_irqsave(&chip->reg_lock, flags);
343         snd_es1938_write_cmd(chip, ESS_CMD_READREG);
344         snd_es1938_write_cmd(chip, reg);
345         val = snd_es1938_get_byte(chip);
346         spin_unlock_irqrestore(&chip->reg_lock, flags);
347         dev_dbg(chip->card->dev, "Reg %02x now is %02x\n", reg, val);
348         return val;
349 }
350
351 /* -----------------------------------------------------------------
352  * Write data to cmd register and return old value
353  * -----------------------------------------------------------------*/
354 static int snd_es1938_bits(struct es1938 *chip, unsigned char reg, unsigned char mask,
355                            unsigned char val)
356 {
357         unsigned long flags;
358         unsigned char old, new, oval;
359         spin_lock_irqsave(&chip->reg_lock, flags);
360         snd_es1938_write_cmd(chip, ESS_CMD_READREG);
361         snd_es1938_write_cmd(chip, reg);
362         old = snd_es1938_get_byte(chip);
363         oval = old & mask;
364         if (val != oval) {
365                 snd_es1938_write_cmd(chip, reg);
366                 new = (old & ~mask) | (val & mask);
367                 snd_es1938_write_cmd(chip, new);
368                 dev_dbg(chip->card->dev, "Reg %02x was %02x, set to %02x\n",
369                            reg, old, new);
370         }
371         spin_unlock_irqrestore(&chip->reg_lock, flags);
372         return oval;
373 }
374
375 /* --------------------------------------------------------------------
376  * Reset the chip
377  * --------------------------------------------------------------------*/
378 static void snd_es1938_reset(struct es1938 *chip)
379 {
380         int i;
381
382         outb(3, SLSB_REG(chip, RESET));
383         inb(SLSB_REG(chip, RESET));
384         outb(0, SLSB_REG(chip, RESET));
385         for (i = 0; i < RESET_LOOP_TIMEOUT; i++) {
386                 if (inb(SLSB_REG(chip, STATUS)) & 0x80) {
387                         if (inb(SLSB_REG(chip, READDATA)) == 0xaa)
388                                 goto __next;
389                 }
390         }
391         dev_err(chip->card->dev, "ESS Solo-1 reset failed\n");
392
393      __next:
394         snd_es1938_write_cmd(chip, ESS_CMD_ENABLEEXT);
395
396         /* Demand transfer DMA: 4 bytes per DMA request */
397         snd_es1938_write(chip, ESS_CMD_DMATYPE, 2);
398
399         /* Change behaviour of register A1
400            4x oversampling
401            2nd channel DAC asynchronous */                                                      
402         snd_es1938_mixer_write(chip, ESSSB_IREG_AUDIO2MODE, 0x32);
403         /* enable/select DMA channel and IRQ channel */
404         snd_es1938_bits(chip, ESS_CMD_IRQCONTROL, 0xf0, 0x50);
405         snd_es1938_bits(chip, ESS_CMD_DRQCONTROL, 0xf0, 0x50);
406         snd_es1938_write_cmd(chip, ESS_CMD_ENABLEAUDIO1);
407         /* Set spatializer parameters to recommended values */
408         snd_es1938_mixer_write(chip, 0x54, 0x8f);
409         snd_es1938_mixer_write(chip, 0x56, 0x95);
410         snd_es1938_mixer_write(chip, 0x58, 0x94);
411         snd_es1938_mixer_write(chip, 0x5a, 0x80);
412 }
413
414 /* --------------------------------------------------------------------
415  * Reset the FIFOs
416  * --------------------------------------------------------------------*/
417 static void snd_es1938_reset_fifo(struct es1938 *chip)
418 {
419         outb(2, SLSB_REG(chip, RESET));
420         outb(0, SLSB_REG(chip, RESET));
421 }
422
423 static const struct snd_ratnum clocks[2] = {
424         {
425                 .num = 793800,
426                 .den_min = 1,
427                 .den_max = 128,
428                 .den_step = 1,
429         },
430         {
431                 .num = 768000,
432                 .den_min = 1,
433                 .den_max = 128,
434                 .den_step = 1,
435         }
436 };
437
438 static const struct snd_pcm_hw_constraint_ratnums hw_constraints_clocks = {
439         .nrats = 2,
440         .rats = clocks,
441 };
442
443
444 static void snd_es1938_rate_set(struct es1938 *chip, 
445                                 struct snd_pcm_substream *substream,
446                                 int mode)
447 {
448         unsigned int bits, div0;
449         struct snd_pcm_runtime *runtime = substream->runtime;
450         if (runtime->rate_num == clocks[0].num)
451                 bits = 128 - runtime->rate_den;
452         else
453                 bits = 256 - runtime->rate_den;
454
455         /* set filter register */
456         div0 = 256 - 7160000*20/(8*82*runtime->rate);
457                 
458         if (mode == DAC2) {
459                 snd_es1938_mixer_write(chip, 0x70, bits);
460                 snd_es1938_mixer_write(chip, 0x72, div0);
461         } else {
462                 snd_es1938_write(chip, 0xA1, bits);
463                 snd_es1938_write(chip, 0xA2, div0);
464         }
465 }
466
467 /* --------------------------------------------------------------------
468  * Configure Solo1 builtin DMA Controller
469  * --------------------------------------------------------------------*/
470
471 static void snd_es1938_playback1_setdma(struct es1938 *chip)
472 {
473         outb(0x00, SLIO_REG(chip, AUDIO2MODE));
474         outl(chip->dma2_start, SLIO_REG(chip, AUDIO2DMAADDR));
475         outw(0, SLIO_REG(chip, AUDIO2DMACOUNT));
476         outw(chip->dma2_size, SLIO_REG(chip, AUDIO2DMACOUNT));
477 }
478
479 static void snd_es1938_playback2_setdma(struct es1938 *chip)
480 {
481         /* Enable DMA controller */
482         outb(0xc4, SLDM_REG(chip, DMACOMMAND));
483         /* 1. Master reset */
484         outb(0, SLDM_REG(chip, DMACLEAR));
485         /* 2. Mask DMA */
486         outb(1, SLDM_REG(chip, DMAMASK));
487         outb(0x18, SLDM_REG(chip, DMAMODE));
488         outl(chip->dma1_start, SLDM_REG(chip, DMAADDR));
489         outw(chip->dma1_size - 1, SLDM_REG(chip, DMACOUNT));
490         /* 3. Unmask DMA */
491         outb(0, SLDM_REG(chip, DMAMASK));
492 }
493
494 static void snd_es1938_capture_setdma(struct es1938 *chip)
495 {
496         /* Enable DMA controller */
497         outb(0xc4, SLDM_REG(chip, DMACOMMAND));
498         /* 1. Master reset */
499         outb(0, SLDM_REG(chip, DMACLEAR));
500         /* 2. Mask DMA */
501         outb(1, SLDM_REG(chip, DMAMASK));
502         outb(0x14, SLDM_REG(chip, DMAMODE));
503         outl(chip->dma1_start, SLDM_REG(chip, DMAADDR));
504         chip->last_capture_dmaaddr = chip->dma1_start;
505         outw(chip->dma1_size - 1, SLDM_REG(chip, DMACOUNT));
506         /* 3. Unmask DMA */
507         outb(0, SLDM_REG(chip, DMAMASK));
508 }
509
510 /* ----------------------------------------------------------------------
511  *
512  *                           *** PCM part ***
513  */
514
515 static int snd_es1938_capture_trigger(struct snd_pcm_substream *substream,
516                                       int cmd)
517 {
518         struct es1938 *chip = snd_pcm_substream_chip(substream);
519         int val;
520         switch (cmd) {
521         case SNDRV_PCM_TRIGGER_START:
522         case SNDRV_PCM_TRIGGER_RESUME:
523                 val = 0x0f;
524                 chip->active |= ADC1;
525                 break;
526         case SNDRV_PCM_TRIGGER_STOP:
527         case SNDRV_PCM_TRIGGER_SUSPEND:
528                 val = 0x00;
529                 chip->active &= ~ADC1;
530                 break;
531         default:
532                 return -EINVAL;
533         }
534         snd_es1938_write(chip, ESS_CMD_DMACONTROL, val);
535         return 0;
536 }
537
538 static int snd_es1938_playback1_trigger(struct snd_pcm_substream *substream,
539                                         int cmd)
540 {
541         struct es1938 *chip = snd_pcm_substream_chip(substream);
542         switch (cmd) {
543         case SNDRV_PCM_TRIGGER_START:
544         case SNDRV_PCM_TRIGGER_RESUME:
545                 /* According to the documentation this should be:
546                    0x13 but that value may randomly swap stereo channels */
547                 snd_es1938_mixer_write(chip, ESSSB_IREG_AUDIO2CONTROL1, 0x92);
548                 udelay(10);
549                 snd_es1938_mixer_write(chip, ESSSB_IREG_AUDIO2CONTROL1, 0x93);
550                 /* This two stage init gives the FIFO -> DAC connection time to
551                  * settle before first data from DMA flows in.  This should ensure
552                  * no swapping of stereo channels.  Report a bug if otherwise :-) */
553                 outb(0x0a, SLIO_REG(chip, AUDIO2MODE));
554                 chip->active |= DAC2;
555                 break;
556         case SNDRV_PCM_TRIGGER_STOP:
557         case SNDRV_PCM_TRIGGER_SUSPEND:
558                 outb(0, SLIO_REG(chip, AUDIO2MODE));
559                 snd_es1938_mixer_write(chip, ESSSB_IREG_AUDIO2CONTROL1, 0);
560                 chip->active &= ~DAC2;
561                 break;
562         default:
563                 return -EINVAL;
564         }
565         return 0;
566 }
567
568 static int snd_es1938_playback2_trigger(struct snd_pcm_substream *substream,
569                                         int cmd)
570 {
571         struct es1938 *chip = snd_pcm_substream_chip(substream);
572         int val;
573         switch (cmd) {
574         case SNDRV_PCM_TRIGGER_START:
575         case SNDRV_PCM_TRIGGER_RESUME:
576                 val = 5;
577                 chip->active |= DAC1;
578                 break;
579         case SNDRV_PCM_TRIGGER_STOP:
580         case SNDRV_PCM_TRIGGER_SUSPEND:
581                 val = 0;
582                 chip->active &= ~DAC1;
583                 break;
584         default:
585                 return -EINVAL;
586         }
587         snd_es1938_write(chip, ESS_CMD_DMACONTROL, val);
588         return 0;
589 }
590
591 static int snd_es1938_playback_trigger(struct snd_pcm_substream *substream,
592                                        int cmd)
593 {
594         switch (substream->number) {
595         case 0:
596                 return snd_es1938_playback1_trigger(substream, cmd);
597         case 1:
598                 return snd_es1938_playback2_trigger(substream, cmd);
599         }
600         snd_BUG();
601         return -EINVAL;
602 }
603
604 /* --------------------------------------------------------------------
605  * First channel for Extended Mode Audio 1 ADC Operation
606  * --------------------------------------------------------------------*/
607 static int snd_es1938_capture_prepare(struct snd_pcm_substream *substream)
608 {
609         struct es1938 *chip = snd_pcm_substream_chip(substream);
610         struct snd_pcm_runtime *runtime = substream->runtime;
611         int u, is8, mono;
612         unsigned int size = snd_pcm_lib_buffer_bytes(substream);
613         unsigned int count = snd_pcm_lib_period_bytes(substream);
614
615         chip->dma1_size = size;
616         chip->dma1_start = runtime->dma_addr;
617
618         mono = (runtime->channels > 1) ? 0 : 1;
619         is8 = snd_pcm_format_width(runtime->format) == 16 ? 0 : 1;
620         u = snd_pcm_format_unsigned(runtime->format);
621
622         chip->dma1_shift = 2 - mono - is8;
623
624         snd_es1938_reset_fifo(chip);
625         
626         /* program type */
627         snd_es1938_bits(chip, ESS_CMD_ANALOGCONTROL, 0x03, (mono ? 2 : 1));
628
629         /* set clock and counters */
630         snd_es1938_rate_set(chip, substream, ADC1);
631
632         count = 0x10000 - count;
633         snd_es1938_write(chip, ESS_CMD_DMACNTRELOADL, count & 0xff);
634         snd_es1938_write(chip, ESS_CMD_DMACNTRELOADH, count >> 8);
635
636         /* initialize and configure ADC */
637         snd_es1938_write(chip, ESS_CMD_SETFORMAT2, u ? 0x51 : 0x71);
638         snd_es1938_write(chip, ESS_CMD_SETFORMAT2, 0x90 | 
639                        (u ? 0x00 : 0x20) | 
640                        (is8 ? 0x00 : 0x04) | 
641                        (mono ? 0x40 : 0x08));
642
643         //      snd_es1938_reset_fifo(chip);    
644
645         /* 11. configure system interrupt controller and DMA controller */
646         snd_es1938_capture_setdma(chip);
647
648         return 0;
649 }
650
651
652 /* ------------------------------------------------------------------------------
653  * Second Audio channel DAC Operation
654  * ------------------------------------------------------------------------------*/
655 static int snd_es1938_playback1_prepare(struct snd_pcm_substream *substream)
656 {
657         struct es1938 *chip = snd_pcm_substream_chip(substream);
658         struct snd_pcm_runtime *runtime = substream->runtime;
659         int u, is8, mono;
660         unsigned int size = snd_pcm_lib_buffer_bytes(substream);
661         unsigned int count = snd_pcm_lib_period_bytes(substream);
662
663         chip->dma2_size = size;
664         chip->dma2_start = runtime->dma_addr;
665
666         mono = (runtime->channels > 1) ? 0 : 1;
667         is8 = snd_pcm_format_width(runtime->format) == 16 ? 0 : 1;
668         u = snd_pcm_format_unsigned(runtime->format);
669
670         chip->dma2_shift = 2 - mono - is8;
671
672         snd_es1938_reset_fifo(chip);
673
674         /* set clock and counters */
675         snd_es1938_rate_set(chip, substream, DAC2);
676
677         count >>= 1;
678         count = 0x10000 - count;
679         snd_es1938_mixer_write(chip, ESSSB_IREG_AUDIO2TCOUNTL, count & 0xff);
680         snd_es1938_mixer_write(chip, ESSSB_IREG_AUDIO2TCOUNTH, count >> 8);
681
682         /* initialize and configure Audio 2 DAC */
683         snd_es1938_mixer_write(chip, ESSSB_IREG_AUDIO2CONTROL2, 0x40 | (u ? 0 : 4) |
684                                (mono ? 0 : 2) | (is8 ? 0 : 1));
685
686         /* program DMA */
687         snd_es1938_playback1_setdma(chip);
688         
689         return 0;
690 }
691
692 static int snd_es1938_playback2_prepare(struct snd_pcm_substream *substream)
693 {
694         struct es1938 *chip = snd_pcm_substream_chip(substream);
695         struct snd_pcm_runtime *runtime = substream->runtime;
696         int u, is8, mono;
697         unsigned int size = snd_pcm_lib_buffer_bytes(substream);
698         unsigned int count = snd_pcm_lib_period_bytes(substream);
699
700         chip->dma1_size = size;
701         chip->dma1_start = runtime->dma_addr;
702
703         mono = (runtime->channels > 1) ? 0 : 1;
704         is8 = snd_pcm_format_width(runtime->format) == 16 ? 0 : 1;
705         u = snd_pcm_format_unsigned(runtime->format);
706
707         chip->dma1_shift = 2 - mono - is8;
708
709         count = 0x10000 - count;
710  
711         /* reset */
712         snd_es1938_reset_fifo(chip);
713         
714         snd_es1938_bits(chip, ESS_CMD_ANALOGCONTROL, 0x03, (mono ? 2 : 1));
715
716         /* set clock and counters */
717         snd_es1938_rate_set(chip, substream, DAC1);
718         snd_es1938_write(chip, ESS_CMD_DMACNTRELOADL, count & 0xff);
719         snd_es1938_write(chip, ESS_CMD_DMACNTRELOADH, count >> 8);
720
721         /* initialized and configure DAC */
722         snd_es1938_write(chip, ESS_CMD_SETFORMAT, u ? 0x80 : 0x00);
723         snd_es1938_write(chip, ESS_CMD_SETFORMAT, u ? 0x51 : 0x71);
724         snd_es1938_write(chip, ESS_CMD_SETFORMAT2, 
725                          0x90 | (mono ? 0x40 : 0x08) |
726                          (is8 ? 0x00 : 0x04) | (u ? 0x00 : 0x20));
727
728         /* program DMA */
729         snd_es1938_playback2_setdma(chip);
730         
731         return 0;
732 }
733
734 static int snd_es1938_playback_prepare(struct snd_pcm_substream *substream)
735 {
736         switch (substream->number) {
737         case 0:
738                 return snd_es1938_playback1_prepare(substream);
739         case 1:
740                 return snd_es1938_playback2_prepare(substream);
741         }
742         snd_BUG();
743         return -EINVAL;
744 }
745
746 /* during the incrementing of dma counters the DMA register reads sometimes
747    returns garbage. To ensure a valid hw pointer, the following checks which
748    should be very unlikely to fail are used:
749    - is the current DMA address in the valid DMA range ?
750    - is the sum of DMA address and DMA counter pointing to the last DMA byte ?
751    One can argue this could differ by one byte depending on which register is
752    updated first, so the implementation below allows for that.
753 */
754 static snd_pcm_uframes_t snd_es1938_capture_pointer(struct snd_pcm_substream *substream)
755 {
756         struct es1938 *chip = snd_pcm_substream_chip(substream);
757         size_t ptr;
758 #if 0
759         size_t old, new;
760         /* This stuff is *needed*, don't ask why - AB */
761         old = inw(SLDM_REG(chip, DMACOUNT));
762         while ((new = inw(SLDM_REG(chip, DMACOUNT))) != old)
763                 old = new;
764         ptr = chip->dma1_size - 1 - new;
765 #else
766         size_t count;
767         unsigned int diff;
768
769         ptr = inl(SLDM_REG(chip, DMAADDR));
770         count = inw(SLDM_REG(chip, DMACOUNT));
771         diff = chip->dma1_start + chip->dma1_size - ptr - count;
772
773         if (diff > 3 || ptr < chip->dma1_start
774               || ptr >= chip->dma1_start+chip->dma1_size)
775           ptr = chip->last_capture_dmaaddr;            /* bad, use last saved */
776         else
777           chip->last_capture_dmaaddr = ptr;            /* good, remember it */
778
779         ptr -= chip->dma1_start;
780 #endif
781         return ptr >> chip->dma1_shift;
782 }
783
784 static snd_pcm_uframes_t snd_es1938_playback1_pointer(struct snd_pcm_substream *substream)
785 {
786         struct es1938 *chip = snd_pcm_substream_chip(substream);
787         size_t ptr;
788 #if 1
789         ptr = chip->dma2_size - inw(SLIO_REG(chip, AUDIO2DMACOUNT));
790 #else
791         ptr = inl(SLIO_REG(chip, AUDIO2DMAADDR)) - chip->dma2_start;
792 #endif
793         return ptr >> chip->dma2_shift;
794 }
795
796 static snd_pcm_uframes_t snd_es1938_playback2_pointer(struct snd_pcm_substream *substream)
797 {
798         struct es1938 *chip = snd_pcm_substream_chip(substream);
799         size_t ptr;
800         size_t old, new;
801 #if 1
802         /* This stuff is *needed*, don't ask why - AB */
803         old = inw(SLDM_REG(chip, DMACOUNT));
804         while ((new = inw(SLDM_REG(chip, DMACOUNT))) != old)
805                 old = new;
806         ptr = chip->dma1_size - 1 - new;
807 #else
808         ptr = inl(SLDM_REG(chip, DMAADDR)) - chip->dma1_start;
809 #endif
810         return ptr >> chip->dma1_shift;
811 }
812
813 static snd_pcm_uframes_t snd_es1938_playback_pointer(struct snd_pcm_substream *substream)
814 {
815         switch (substream->number) {
816         case 0:
817                 return snd_es1938_playback1_pointer(substream);
818         case 1:
819                 return snd_es1938_playback2_pointer(substream);
820         }
821         snd_BUG();
822         return -EINVAL;
823 }
824
825 static int snd_es1938_capture_copy(struct snd_pcm_substream *substream,
826                                    int channel, unsigned long pos,
827                                    void __user *dst, unsigned long count)
828 {
829         struct snd_pcm_runtime *runtime = substream->runtime;
830         struct es1938 *chip = snd_pcm_substream_chip(substream);
831
832         if (snd_BUG_ON(pos + count > chip->dma1_size))
833                 return -EINVAL;
834         if (pos + count < chip->dma1_size) {
835                 if (copy_to_user(dst, runtime->dma_area + pos + 1, count))
836                         return -EFAULT;
837         } else {
838                 if (copy_to_user(dst, runtime->dma_area + pos + 1, count - 1))
839                         return -EFAULT;
840                 if (put_user(runtime->dma_area[0],
841                              ((unsigned char __user *)dst) + count - 1))
842                         return -EFAULT;
843         }
844         return 0;
845 }
846
847 static int snd_es1938_capture_copy_kernel(struct snd_pcm_substream *substream,
848                                           int channel, unsigned long pos,
849                                           void *dst, unsigned long count)
850 {
851         struct snd_pcm_runtime *runtime = substream->runtime;
852         struct es1938 *chip = snd_pcm_substream_chip(substream);
853
854         if (snd_BUG_ON(pos + count > chip->dma1_size))
855                 return -EINVAL;
856         if (pos + count < chip->dma1_size) {
857                 memcpy(dst, runtime->dma_area + pos + 1, count);
858         } else {
859                 memcpy(dst, runtime->dma_area + pos + 1, count - 1);
860                 runtime->dma_area[0] = *((unsigned char *)dst + count - 1);
861         }
862         return 0;
863 }
864
865 /* ----------------------------------------------------------------------
866  * Audio1 Capture (ADC)
867  * ----------------------------------------------------------------------*/
868 static const struct snd_pcm_hardware snd_es1938_capture =
869 {
870         .info =                 (SNDRV_PCM_INFO_INTERLEAVED |
871                                 SNDRV_PCM_INFO_BLOCK_TRANSFER),
872         .formats =              (SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S16_LE |
873                                  SNDRV_PCM_FMTBIT_S8 | SNDRV_PCM_FMTBIT_U16_LE),
874         .rates =                SNDRV_PCM_RATE_CONTINUOUS | SNDRV_PCM_RATE_8000_48000,
875         .rate_min =             6000,
876         .rate_max =             48000,
877         .channels_min =         1,
878         .channels_max =         2,
879         .buffer_bytes_max =     0x8000,       /* DMA controller screws on higher values */
880         .period_bytes_min =     64,
881         .period_bytes_max =     0x8000,
882         .periods_min =          1,
883         .periods_max =          1024,
884         .fifo_size =            256,
885 };
886
887 /* -----------------------------------------------------------------------
888  * Audio2 Playback (DAC)
889  * -----------------------------------------------------------------------*/
890 static const struct snd_pcm_hardware snd_es1938_playback =
891 {
892         .info =                 (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED |
893                                  SNDRV_PCM_INFO_BLOCK_TRANSFER |
894                                  SNDRV_PCM_INFO_MMAP_VALID),
895         .formats =              (SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S16_LE |
896                                  SNDRV_PCM_FMTBIT_S8 | SNDRV_PCM_FMTBIT_U16_LE),
897         .rates =                SNDRV_PCM_RATE_CONTINUOUS | SNDRV_PCM_RATE_8000_48000,
898         .rate_min =             6000,
899         .rate_max =             48000,
900         .channels_min =         1,
901         .channels_max =         2,
902         .buffer_bytes_max =     0x8000,       /* DMA controller screws on higher values */
903         .period_bytes_min =     64,
904         .period_bytes_max =     0x8000,
905         .periods_min =          1,
906         .periods_max =          1024,
907         .fifo_size =            256,
908 };
909
910 static int snd_es1938_capture_open(struct snd_pcm_substream *substream)
911 {
912         struct es1938 *chip = snd_pcm_substream_chip(substream);
913         struct snd_pcm_runtime *runtime = substream->runtime;
914
915         if (chip->playback2_substream)
916                 return -EAGAIN;
917         chip->capture_substream = substream;
918         runtime->hw = snd_es1938_capture;
919         snd_pcm_hw_constraint_ratnums(runtime, 0, SNDRV_PCM_HW_PARAM_RATE,
920                                       &hw_constraints_clocks);
921         snd_pcm_hw_constraint_minmax(runtime, SNDRV_PCM_HW_PARAM_BUFFER_BYTES, 0, 0xff00);
922         return 0;
923 }
924
925 static int snd_es1938_playback_open(struct snd_pcm_substream *substream)
926 {
927         struct es1938 *chip = snd_pcm_substream_chip(substream);
928         struct snd_pcm_runtime *runtime = substream->runtime;
929
930         switch (substream->number) {
931         case 0:
932                 chip->playback1_substream = substream;
933                 break;
934         case 1:
935                 if (chip->capture_substream)
936                         return -EAGAIN;
937                 chip->playback2_substream = substream;
938                 break;
939         default:
940                 snd_BUG();
941                 return -EINVAL;
942         }
943         runtime->hw = snd_es1938_playback;
944         snd_pcm_hw_constraint_ratnums(runtime, 0, SNDRV_PCM_HW_PARAM_RATE,
945                                       &hw_constraints_clocks);
946         snd_pcm_hw_constraint_minmax(runtime, SNDRV_PCM_HW_PARAM_BUFFER_BYTES, 0, 0xff00);
947         return 0;
948 }
949
950 static int snd_es1938_capture_close(struct snd_pcm_substream *substream)
951 {
952         struct es1938 *chip = snd_pcm_substream_chip(substream);
953
954         chip->capture_substream = NULL;
955         return 0;
956 }
957
958 static int snd_es1938_playback_close(struct snd_pcm_substream *substream)
959 {
960         struct es1938 *chip = snd_pcm_substream_chip(substream);
961
962         switch (substream->number) {
963         case 0:
964                 chip->playback1_substream = NULL;
965                 break;
966         case 1:
967                 chip->playback2_substream = NULL;
968                 break;
969         default:
970                 snd_BUG();
971                 return -EINVAL;
972         }
973         return 0;
974 }
975
976 static const struct snd_pcm_ops snd_es1938_playback_ops = {
977         .open =         snd_es1938_playback_open,
978         .close =        snd_es1938_playback_close,
979         .prepare =      snd_es1938_playback_prepare,
980         .trigger =      snd_es1938_playback_trigger,
981         .pointer =      snd_es1938_playback_pointer,
982 };
983
984 static const struct snd_pcm_ops snd_es1938_capture_ops = {
985         .open =         snd_es1938_capture_open,
986         .close =        snd_es1938_capture_close,
987         .prepare =      snd_es1938_capture_prepare,
988         .trigger =      snd_es1938_capture_trigger,
989         .pointer =      snd_es1938_capture_pointer,
990         .copy_user =    snd_es1938_capture_copy,
991         .copy_kernel =  snd_es1938_capture_copy_kernel,
992 };
993
994 static int snd_es1938_new_pcm(struct es1938 *chip, int device)
995 {
996         struct snd_pcm *pcm;
997         int err;
998
999         err = snd_pcm_new(chip->card, "es-1938-1946", device, 2, 1, &pcm);
1000         if (err < 0)
1001                 return err;
1002         snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_es1938_playback_ops);
1003         snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_es1938_capture_ops);
1004         
1005         pcm->private_data = chip;
1006         pcm->info_flags = 0;
1007         strcpy(pcm->name, "ESS Solo-1");
1008
1009         snd_pcm_set_managed_buffer_all(pcm, SNDRV_DMA_TYPE_DEV,
1010                                        &chip->pci->dev, 64*1024, 64*1024);
1011
1012         chip->pcm = pcm;
1013         return 0;
1014 }
1015
1016 /* -------------------------------------------------------------------
1017  * 
1018  *                       *** Mixer part ***
1019  */
1020
1021 static int snd_es1938_info_mux(struct snd_kcontrol *kcontrol,
1022                                struct snd_ctl_elem_info *uinfo)
1023 {
1024         static const char * const texts[8] = {
1025                 "Mic", "Mic Master", "CD", "AOUT",
1026                 "Mic1", "Mix", "Line", "Master"
1027         };
1028
1029         return snd_ctl_enum_info(uinfo, 1, 8, texts);
1030 }
1031
1032 static int snd_es1938_get_mux(struct snd_kcontrol *kcontrol,
1033                               struct snd_ctl_elem_value *ucontrol)
1034 {
1035         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1036         ucontrol->value.enumerated.item[0] = snd_es1938_mixer_read(chip, 0x1c) & 0x07;
1037         return 0;
1038 }
1039
1040 static int snd_es1938_put_mux(struct snd_kcontrol *kcontrol,
1041                               struct snd_ctl_elem_value *ucontrol)
1042 {
1043         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1044         unsigned char val = ucontrol->value.enumerated.item[0];
1045         
1046         if (val > 7)
1047                 return -EINVAL;
1048         return snd_es1938_mixer_bits(chip, 0x1c, 0x07, val) != val;
1049 }
1050
1051 #define snd_es1938_info_spatializer_enable      snd_ctl_boolean_mono_info
1052
1053 static int snd_es1938_get_spatializer_enable(struct snd_kcontrol *kcontrol,
1054                                              struct snd_ctl_elem_value *ucontrol)
1055 {
1056         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1057         unsigned char val = snd_es1938_mixer_read(chip, 0x50);
1058         ucontrol->value.integer.value[0] = !!(val & 8);
1059         return 0;
1060 }
1061
1062 static int snd_es1938_put_spatializer_enable(struct snd_kcontrol *kcontrol,
1063                                              struct snd_ctl_elem_value *ucontrol)
1064 {
1065         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1066         unsigned char oval, nval;
1067         int change;
1068         nval = ucontrol->value.integer.value[0] ? 0x0c : 0x04;
1069         oval = snd_es1938_mixer_read(chip, 0x50) & 0x0c;
1070         change = nval != oval;
1071         if (change) {
1072                 snd_es1938_mixer_write(chip, 0x50, nval & ~0x04);
1073                 snd_es1938_mixer_write(chip, 0x50, nval);
1074         }
1075         return change;
1076 }
1077
1078 static int snd_es1938_info_hw_volume(struct snd_kcontrol *kcontrol,
1079                                      struct snd_ctl_elem_info *uinfo)
1080 {
1081         uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
1082         uinfo->count = 2;
1083         uinfo->value.integer.min = 0;
1084         uinfo->value.integer.max = 63;
1085         return 0;
1086 }
1087
1088 static int snd_es1938_get_hw_volume(struct snd_kcontrol *kcontrol,
1089                                     struct snd_ctl_elem_value *ucontrol)
1090 {
1091         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1092         ucontrol->value.integer.value[0] = snd_es1938_mixer_read(chip, 0x61) & 0x3f;
1093         ucontrol->value.integer.value[1] = snd_es1938_mixer_read(chip, 0x63) & 0x3f;
1094         return 0;
1095 }
1096
1097 #define snd_es1938_info_hw_switch               snd_ctl_boolean_stereo_info
1098
1099 static int snd_es1938_get_hw_switch(struct snd_kcontrol *kcontrol,
1100                                     struct snd_ctl_elem_value *ucontrol)
1101 {
1102         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1103         ucontrol->value.integer.value[0] = !(snd_es1938_mixer_read(chip, 0x61) & 0x40);
1104         ucontrol->value.integer.value[1] = !(snd_es1938_mixer_read(chip, 0x63) & 0x40);
1105         return 0;
1106 }
1107
1108 static void snd_es1938_hwv_free(struct snd_kcontrol *kcontrol)
1109 {
1110         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1111         chip->master_volume = NULL;
1112         chip->master_switch = NULL;
1113         chip->hw_volume = NULL;
1114         chip->hw_switch = NULL;
1115 }
1116
1117 static int snd_es1938_reg_bits(struct es1938 *chip, unsigned char reg,
1118                                unsigned char mask, unsigned char val)
1119 {
1120         if (reg < 0xa0)
1121                 return snd_es1938_mixer_bits(chip, reg, mask, val);
1122         else
1123                 return snd_es1938_bits(chip, reg, mask, val);
1124 }
1125
1126 static int snd_es1938_reg_read(struct es1938 *chip, unsigned char reg)
1127 {
1128         if (reg < 0xa0)
1129                 return snd_es1938_mixer_read(chip, reg);
1130         else
1131                 return snd_es1938_read(chip, reg);
1132 }
1133
1134 #define ES1938_SINGLE_TLV(xname, xindex, reg, shift, mask, invert, xtlv)    \
1135 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1136   .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_TLV_READ,\
1137   .name = xname, .index = xindex, \
1138   .info = snd_es1938_info_single, \
1139   .get = snd_es1938_get_single, .put = snd_es1938_put_single, \
1140   .private_value = reg | (shift << 8) | (mask << 16) | (invert << 24), \
1141   .tlv = { .p = xtlv } }
1142 #define ES1938_SINGLE(xname, xindex, reg, shift, mask, invert) \
1143 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = xindex, \
1144   .info = snd_es1938_info_single, \
1145   .get = snd_es1938_get_single, .put = snd_es1938_put_single, \
1146   .private_value = reg | (shift << 8) | (mask << 16) | (invert << 24) }
1147
1148 static int snd_es1938_info_single(struct snd_kcontrol *kcontrol,
1149                                   struct snd_ctl_elem_info *uinfo)
1150 {
1151         int mask = (kcontrol->private_value >> 16) & 0xff;
1152
1153         uinfo->type = mask == 1 ? SNDRV_CTL_ELEM_TYPE_BOOLEAN : SNDRV_CTL_ELEM_TYPE_INTEGER;
1154         uinfo->count = 1;
1155         uinfo->value.integer.min = 0;
1156         uinfo->value.integer.max = mask;
1157         return 0;
1158 }
1159
1160 static int snd_es1938_get_single(struct snd_kcontrol *kcontrol,
1161                                  struct snd_ctl_elem_value *ucontrol)
1162 {
1163         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1164         int reg = kcontrol->private_value & 0xff;
1165         int shift = (kcontrol->private_value >> 8) & 0xff;
1166         int mask = (kcontrol->private_value >> 16) & 0xff;
1167         int invert = (kcontrol->private_value >> 24) & 0xff;
1168         int val;
1169         
1170         val = snd_es1938_reg_read(chip, reg);
1171         ucontrol->value.integer.value[0] = (val >> shift) & mask;
1172         if (invert)
1173                 ucontrol->value.integer.value[0] = mask - ucontrol->value.integer.value[0];
1174         return 0;
1175 }
1176
1177 static int snd_es1938_put_single(struct snd_kcontrol *kcontrol,
1178                                  struct snd_ctl_elem_value *ucontrol)
1179 {
1180         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1181         int reg = kcontrol->private_value & 0xff;
1182         int shift = (kcontrol->private_value >> 8) & 0xff;
1183         int mask = (kcontrol->private_value >> 16) & 0xff;
1184         int invert = (kcontrol->private_value >> 24) & 0xff;
1185         unsigned char val;
1186         
1187         val = (ucontrol->value.integer.value[0] & mask);
1188         if (invert)
1189                 val = mask - val;
1190         mask <<= shift;
1191         val <<= shift;
1192         return snd_es1938_reg_bits(chip, reg, mask, val) != val;
1193 }
1194
1195 #define ES1938_DOUBLE_TLV(xname, xindex, left_reg, right_reg, shift_left, shift_right, mask, invert, xtlv) \
1196 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1197   .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_TLV_READ,\
1198   .name = xname, .index = xindex, \
1199   .info = snd_es1938_info_double, \
1200   .get = snd_es1938_get_double, .put = snd_es1938_put_double, \
1201   .private_value = left_reg | (right_reg << 8) | (shift_left << 16) | (shift_right << 19) | (mask << 24) | (invert << 22), \
1202   .tlv = { .p = xtlv } }
1203 #define ES1938_DOUBLE(xname, xindex, left_reg, right_reg, shift_left, shift_right, mask, invert) \
1204 { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = xindex, \
1205   .info = snd_es1938_info_double, \
1206   .get = snd_es1938_get_double, .put = snd_es1938_put_double, \
1207   .private_value = left_reg | (right_reg << 8) | (shift_left << 16) | (shift_right << 19) | (mask << 24) | (invert << 22) }
1208
1209 static int snd_es1938_info_double(struct snd_kcontrol *kcontrol,
1210                                   struct snd_ctl_elem_info *uinfo)
1211 {
1212         int mask = (kcontrol->private_value >> 24) & 0xff;
1213
1214         uinfo->type = mask == 1 ? SNDRV_CTL_ELEM_TYPE_BOOLEAN : SNDRV_CTL_ELEM_TYPE_INTEGER;
1215         uinfo->count = 2;
1216         uinfo->value.integer.min = 0;
1217         uinfo->value.integer.max = mask;
1218         return 0;
1219 }
1220
1221 static int snd_es1938_get_double(struct snd_kcontrol *kcontrol,
1222                                  struct snd_ctl_elem_value *ucontrol)
1223 {
1224         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1225         int left_reg = kcontrol->private_value & 0xff;
1226         int right_reg = (kcontrol->private_value >> 8) & 0xff;
1227         int shift_left = (kcontrol->private_value >> 16) & 0x07;
1228         int shift_right = (kcontrol->private_value >> 19) & 0x07;
1229         int mask = (kcontrol->private_value >> 24) & 0xff;
1230         int invert = (kcontrol->private_value >> 22) & 1;
1231         unsigned char left, right;
1232         
1233         left = snd_es1938_reg_read(chip, left_reg);
1234         if (left_reg != right_reg)
1235                 right = snd_es1938_reg_read(chip, right_reg);
1236         else
1237                 right = left;
1238         ucontrol->value.integer.value[0] = (left >> shift_left) & mask;
1239         ucontrol->value.integer.value[1] = (right >> shift_right) & mask;
1240         if (invert) {
1241                 ucontrol->value.integer.value[0] = mask - ucontrol->value.integer.value[0];
1242                 ucontrol->value.integer.value[1] = mask - ucontrol->value.integer.value[1];
1243         }
1244         return 0;
1245 }
1246
1247 static int snd_es1938_put_double(struct snd_kcontrol *kcontrol,
1248                                  struct snd_ctl_elem_value *ucontrol)
1249 {
1250         struct es1938 *chip = snd_kcontrol_chip(kcontrol);
1251         int left_reg = kcontrol->private_value & 0xff;
1252         int right_reg = (kcontrol->private_value >> 8) & 0xff;
1253         int shift_left = (kcontrol->private_value >> 16) & 0x07;
1254         int shift_right = (kcontrol->private_value >> 19) & 0x07;
1255         int mask = (kcontrol->private_value >> 24) & 0xff;
1256         int invert = (kcontrol->private_value >> 22) & 1;
1257         int change;
1258         unsigned char val1, val2, mask1, mask2;
1259         
1260         val1 = ucontrol->value.integer.value[0] & mask;
1261         val2 = ucontrol->value.integer.value[1] & mask;
1262         if (invert) {
1263                 val1 = mask - val1;
1264                 val2 = mask - val2;
1265         }
1266         val1 <<= shift_left;
1267         val2 <<= shift_right;
1268         mask1 = mask << shift_left;
1269         mask2 = mask << shift_right;
1270         if (left_reg != right_reg) {
1271                 change = 0;
1272                 if (snd_es1938_reg_bits(chip, left_reg, mask1, val1) != val1)
1273                         change = 1;
1274                 if (snd_es1938_reg_bits(chip, right_reg, mask2, val2) != val2)
1275                         change = 1;
1276         } else {
1277                 change = (snd_es1938_reg_bits(chip, left_reg, mask1 | mask2, 
1278                                               val1 | val2) != (val1 | val2));
1279         }
1280         return change;
1281 }
1282
1283 static const DECLARE_TLV_DB_RANGE(db_scale_master,
1284         0, 54, TLV_DB_SCALE_ITEM(-3600, 50, 1),
1285         54, 63, TLV_DB_SCALE_ITEM(-900, 100, 0),
1286 );
1287
1288 static const DECLARE_TLV_DB_RANGE(db_scale_audio1,
1289         0, 8, TLV_DB_SCALE_ITEM(-3300, 300, 1),
1290         8, 15, TLV_DB_SCALE_ITEM(-900, 150, 0),
1291 );
1292
1293 static const DECLARE_TLV_DB_RANGE(db_scale_audio2,
1294         0, 8, TLV_DB_SCALE_ITEM(-3450, 300, 1),
1295         8, 15, TLV_DB_SCALE_ITEM(-1050, 150, 0),
1296 );
1297
1298 static const DECLARE_TLV_DB_RANGE(db_scale_mic,
1299         0, 8, TLV_DB_SCALE_ITEM(-2400, 300, 1),
1300         8, 15, TLV_DB_SCALE_ITEM(0, 150, 0),
1301 );
1302
1303 static const DECLARE_TLV_DB_RANGE(db_scale_line,
1304         0, 8, TLV_DB_SCALE_ITEM(-3150, 300, 1),
1305         8, 15, TLV_DB_SCALE_ITEM(-750, 150, 0),
1306 );
1307
1308 static const DECLARE_TLV_DB_SCALE(db_scale_capture, 0, 150, 0);
1309
1310 static const struct snd_kcontrol_new snd_es1938_controls[] = {
1311 ES1938_DOUBLE_TLV("Master Playback Volume", 0, 0x60, 0x62, 0, 0, 63, 0,
1312                   db_scale_master),
1313 ES1938_DOUBLE("Master Playback Switch", 0, 0x60, 0x62, 6, 6, 1, 1),
1314 {
1315         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1316         .name = "Hardware Master Playback Volume",
1317         .access = SNDRV_CTL_ELEM_ACCESS_READ,
1318         .info = snd_es1938_info_hw_volume,
1319         .get = snd_es1938_get_hw_volume,
1320 },
1321 {
1322         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1323         .access = (SNDRV_CTL_ELEM_ACCESS_READ |
1324                    SNDRV_CTL_ELEM_ACCESS_TLV_READ),
1325         .name = "Hardware Master Playback Switch",
1326         .info = snd_es1938_info_hw_switch,
1327         .get = snd_es1938_get_hw_switch,
1328         .tlv = { .p = db_scale_master },
1329 },
1330 ES1938_SINGLE("Hardware Volume Split", 0, 0x64, 7, 1, 0),
1331 ES1938_DOUBLE_TLV("Line Playback Volume", 0, 0x3e, 0x3e, 4, 0, 15, 0,
1332                   db_scale_line),
1333 ES1938_DOUBLE("CD Playback Volume", 0, 0x38, 0x38, 4, 0, 15, 0),
1334 ES1938_DOUBLE_TLV("FM Playback Volume", 0, 0x36, 0x36, 4, 0, 15, 0,
1335                   db_scale_mic),
1336 ES1938_DOUBLE_TLV("Mono Playback Volume", 0, 0x6d, 0x6d, 4, 0, 15, 0,
1337                   db_scale_line),
1338 ES1938_DOUBLE_TLV("Mic Playback Volume", 0, 0x1a, 0x1a, 4, 0, 15, 0,
1339                   db_scale_mic),
1340 ES1938_DOUBLE_TLV("Aux Playback Volume", 0, 0x3a, 0x3a, 4, 0, 15, 0,
1341                   db_scale_line),
1342 ES1938_DOUBLE_TLV("Capture Volume", 0, 0xb4, 0xb4, 4, 0, 15, 0,
1343                   db_scale_capture),
1344 ES1938_SINGLE("Beep Volume", 0, 0x3c, 0, 7, 0),
1345 ES1938_SINGLE("Record Monitor", 0, 0xa8, 3, 1, 0),
1346 ES1938_SINGLE("Capture Switch", 0, 0x1c, 4, 1, 1),
1347 {
1348         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1349         .name = "Capture Source",
1350         .info = snd_es1938_info_mux,
1351         .get = snd_es1938_get_mux,
1352         .put = snd_es1938_put_mux,
1353 },
1354 ES1938_DOUBLE_TLV("Mono Input Playback Volume", 0, 0x6d, 0x6d, 4, 0, 15, 0,
1355                   db_scale_line),
1356 ES1938_DOUBLE_TLV("PCM Capture Volume", 0, 0x69, 0x69, 4, 0, 15, 0,
1357                   db_scale_audio2),
1358 ES1938_DOUBLE_TLV("Mic Capture Volume", 0, 0x68, 0x68, 4, 0, 15, 0,
1359                   db_scale_mic),
1360 ES1938_DOUBLE_TLV("Line Capture Volume", 0, 0x6e, 0x6e, 4, 0, 15, 0,
1361                   db_scale_line),
1362 ES1938_DOUBLE_TLV("FM Capture Volume", 0, 0x6b, 0x6b, 4, 0, 15, 0,
1363                   db_scale_mic),
1364 ES1938_DOUBLE_TLV("Mono Capture Volume", 0, 0x6f, 0x6f, 4, 0, 15, 0,
1365                   db_scale_line),
1366 ES1938_DOUBLE_TLV("CD Capture Volume", 0, 0x6a, 0x6a, 4, 0, 15, 0,
1367                   db_scale_line),
1368 ES1938_DOUBLE_TLV("Aux Capture Volume", 0, 0x6c, 0x6c, 4, 0, 15, 0,
1369                   db_scale_line),
1370 ES1938_DOUBLE_TLV("PCM Playback Volume", 0, 0x7c, 0x7c, 4, 0, 15, 0,
1371                   db_scale_audio2),
1372 ES1938_DOUBLE_TLV("PCM Playback Volume", 1, 0x14, 0x14, 4, 0, 15, 0,
1373                   db_scale_audio1),
1374 ES1938_SINGLE("3D Control - Level", 0, 0x52, 0, 63, 0),
1375 {
1376         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1377         .name = "3D Control - Switch",
1378         .info = snd_es1938_info_spatializer_enable,
1379         .get = snd_es1938_get_spatializer_enable,
1380         .put = snd_es1938_put_spatializer_enable,
1381 },
1382 ES1938_SINGLE("Mic Boost (+26dB)", 0, 0x7d, 3, 1, 0)
1383 };
1384
1385
1386 /* ---------------------------------------------------------------------------- */
1387 /* ---------------------------------------------------------------------------- */
1388
1389 /*
1390  * initialize the chip - used by resume callback, too
1391  */
1392 static void snd_es1938_chip_init(struct es1938 *chip)
1393 {
1394         /* reset chip */
1395         snd_es1938_reset(chip);
1396
1397         /* configure native mode */
1398
1399         /* enable bus master */
1400         pci_set_master(chip->pci);
1401
1402         /* disable legacy audio */
1403         pci_write_config_word(chip->pci, SL_PCI_LEGACYCONTROL, 0x805f);
1404
1405         /* set DDMA base */
1406         pci_write_config_word(chip->pci, SL_PCI_DDMACONTROL, chip->ddma_port | 1);
1407
1408         /* set DMA/IRQ policy */
1409         pci_write_config_dword(chip->pci, SL_PCI_CONFIG, 0);
1410
1411         /* enable Audio 1, Audio 2, MPU401 IRQ and HW volume IRQ*/
1412         outb(0xf0, SLIO_REG(chip, IRQCONTROL));
1413
1414         /* reset DMA */
1415         outb(0, SLDM_REG(chip, DMACLEAR));
1416 }
1417
1418 #ifdef CONFIG_PM_SLEEP
1419 /*
1420  * PM support
1421  */
1422
1423 static const unsigned char saved_regs[SAVED_REG_SIZE+1] = {
1424         0x14, 0x1a, 0x1c, 0x3a, 0x3c, 0x3e, 0x36, 0x38,
1425         0x50, 0x52, 0x60, 0x61, 0x62, 0x63, 0x64, 0x68,
1426         0x69, 0x6a, 0x6b, 0x6d, 0x6e, 0x6f, 0x7c, 0x7d,
1427         0xa8, 0xb4,
1428 };
1429
1430
1431 static int es1938_suspend(struct device *dev)
1432 {
1433         struct snd_card *card = dev_get_drvdata(dev);
1434         struct es1938 *chip = card->private_data;
1435         const unsigned char *s;
1436         unsigned char *d;
1437
1438         snd_power_change_state(card, SNDRV_CTL_POWER_D3hot);
1439
1440         /* save mixer-related registers */
1441         for (s = saved_regs, d = chip->saved_regs; *s; s++, d++)
1442                 *d = snd_es1938_reg_read(chip, *s);
1443
1444         outb(0x00, SLIO_REG(chip, IRQCONTROL)); /* disable irqs */
1445         if (chip->irq >= 0) {
1446                 free_irq(chip->irq, chip);
1447                 chip->irq = -1;
1448                 card->sync_irq = -1;
1449         }
1450         return 0;
1451 }
1452
1453 static int es1938_resume(struct device *dev)
1454 {
1455         struct pci_dev *pci = to_pci_dev(dev);
1456         struct snd_card *card = dev_get_drvdata(dev);
1457         struct es1938 *chip = card->private_data;
1458         const unsigned char *s;
1459         unsigned char *d;
1460
1461         if (request_irq(pci->irq, snd_es1938_interrupt,
1462                         IRQF_SHARED, KBUILD_MODNAME, chip)) {
1463                 dev_err(dev, "unable to grab IRQ %d, disabling device\n",
1464                         pci->irq);
1465                 snd_card_disconnect(card);
1466                 return -EIO;
1467         }
1468         chip->irq = pci->irq;
1469         card->sync_irq = chip->irq;
1470         snd_es1938_chip_init(chip);
1471
1472         /* restore mixer-related registers */
1473         for (s = saved_regs, d = chip->saved_regs; *s; s++, d++) {
1474                 if (*s < 0xa0)
1475                         snd_es1938_mixer_write(chip, *s, *d);
1476                 else
1477                         snd_es1938_write(chip, *s, *d);
1478         }
1479
1480         snd_power_change_state(card, SNDRV_CTL_POWER_D0);
1481         return 0;
1482 }
1483
1484 static SIMPLE_DEV_PM_OPS(es1938_pm, es1938_suspend, es1938_resume);
1485 #define ES1938_PM_OPS   &es1938_pm
1486 #else
1487 #define ES1938_PM_OPS   NULL
1488 #endif /* CONFIG_PM_SLEEP */
1489
1490 #ifdef SUPPORT_JOYSTICK
1491 static int snd_es1938_create_gameport(struct es1938 *chip)
1492 {
1493         struct gameport *gp;
1494
1495         chip->gameport = gp = gameport_allocate_port();
1496         if (!gp) {
1497                 dev_err(chip->card->dev,
1498                         "cannot allocate memory for gameport\n");
1499                 return -ENOMEM;
1500         }
1501
1502         gameport_set_name(gp, "ES1938");
1503         gameport_set_phys(gp, "pci%s/gameport0", pci_name(chip->pci));
1504         gameport_set_dev_parent(gp, &chip->pci->dev);
1505         gp->io = chip->game_port;
1506
1507         gameport_register_port(gp);
1508
1509         return 0;
1510 }
1511
1512 static void snd_es1938_free_gameport(struct es1938 *chip)
1513 {
1514         if (chip->gameport) {
1515                 gameport_unregister_port(chip->gameport);
1516                 chip->gameport = NULL;
1517         }
1518 }
1519 #else
1520 static inline int snd_es1938_create_gameport(struct es1938 *chip) { return -ENOSYS; }
1521 static inline void snd_es1938_free_gameport(struct es1938 *chip) { }
1522 #endif /* SUPPORT_JOYSTICK */
1523
1524 static void snd_es1938_free(struct snd_card *card)
1525 {
1526         struct es1938 *chip = card->private_data;
1527
1528         /* disable irqs */
1529         outb(0x00, SLIO_REG(chip, IRQCONTROL));
1530         if (chip->rmidi)
1531                 snd_es1938_mixer_bits(chip, ESSSB_IREG_MPU401CONTROL, 0x40, 0);
1532
1533         snd_es1938_free_gameport(chip);
1534
1535         if (chip->irq >= 0)
1536                 free_irq(chip->irq, chip);
1537 }
1538
1539 static int snd_es1938_create(struct snd_card *card,
1540                              struct pci_dev *pci)
1541 {
1542         struct es1938 *chip = card->private_data;
1543         int err;
1544
1545         /* enable PCI device */
1546         err = pcim_enable_device(pci);
1547         if (err < 0)
1548                 return err;
1549         /* check, if we can restrict PCI DMA transfers to 24 bits */
1550         if (dma_set_mask_and_coherent(&pci->dev, DMA_BIT_MASK(24))) {
1551                 dev_err(card->dev,
1552                         "architecture does not support 24bit PCI busmaster DMA\n");
1553                 return -ENXIO;
1554         }
1555
1556         spin_lock_init(&chip->reg_lock);
1557         spin_lock_init(&chip->mixer_lock);
1558         chip->card = card;
1559         chip->pci = pci;
1560         chip->irq = -1;
1561         err = pci_request_regions(pci, "ESS Solo-1");
1562         if (err < 0)
1563                 return err;
1564         chip->io_port = pci_resource_start(pci, 0);
1565         chip->sb_port = pci_resource_start(pci, 1);
1566         chip->vc_port = pci_resource_start(pci, 2);
1567         chip->mpu_port = pci_resource_start(pci, 3);
1568         chip->game_port = pci_resource_start(pci, 4);
1569         /* still use non-managed irq handler as it's re-acquired at PM resume */
1570         if (request_irq(pci->irq, snd_es1938_interrupt, IRQF_SHARED,
1571                         KBUILD_MODNAME, chip)) {
1572                 dev_err(card->dev, "unable to grab IRQ %d\n", pci->irq);
1573                 return -EBUSY;
1574         }
1575         chip->irq = pci->irq;
1576         card->sync_irq = chip->irq;
1577         card->private_free = snd_es1938_free;
1578         dev_dbg(card->dev,
1579                 "create: io: 0x%lx, sb: 0x%lx, vc: 0x%lx, mpu: 0x%lx, game: 0x%lx\n",
1580                    chip->io_port, chip->sb_port, chip->vc_port, chip->mpu_port, chip->game_port);
1581
1582         chip->ddma_port = chip->vc_port + 0x00;         /* fix from Thomas Sailer */
1583
1584         snd_es1938_chip_init(chip);
1585         return 0;
1586 }
1587
1588 /* --------------------------------------------------------------------
1589  * Interrupt handler
1590  * -------------------------------------------------------------------- */
1591 static irqreturn_t snd_es1938_interrupt(int irq, void *dev_id)
1592 {
1593         struct es1938 *chip = dev_id;
1594         unsigned char status;
1595         __always_unused unsigned char audiostatus;
1596         int handled = 0;
1597
1598         status = inb(SLIO_REG(chip, IRQCONTROL));
1599 #if 0
1600         dev_dbg(chip->card->dev,
1601                 "Es1938debug - interrupt status: =0x%x\n", status);
1602 #endif
1603         
1604         /* AUDIO 1 */
1605         if (status & 0x10) {
1606 #if 0
1607                 dev_dbg(chip->card->dev,
1608                        "Es1938debug - AUDIO channel 1 interrupt\n");
1609                 dev_dbg(chip->card->dev,
1610                        "Es1938debug - AUDIO channel 1 DMAC DMA count: %u\n",
1611                        inw(SLDM_REG(chip, DMACOUNT)));
1612                 dev_dbg(chip->card->dev,
1613                        "Es1938debug - AUDIO channel 1 DMAC DMA base: %u\n",
1614                        inl(SLDM_REG(chip, DMAADDR)));
1615                 dev_dbg(chip->card->dev,
1616                        "Es1938debug - AUDIO channel 1 DMAC DMA status: 0x%x\n",
1617                        inl(SLDM_REG(chip, DMASTATUS)));
1618 #endif
1619                 /* clear irq */
1620                 handled = 1;
1621                 audiostatus = inb(SLSB_REG(chip, STATUS));
1622                 if (chip->active & ADC1)
1623                         snd_pcm_period_elapsed(chip->capture_substream);
1624                 else if (chip->active & DAC1)
1625                         snd_pcm_period_elapsed(chip->playback2_substream);
1626         }
1627         
1628         /* AUDIO 2 */
1629         if (status & 0x20) {
1630 #if 0
1631                 dev_dbg(chip->card->dev,
1632                        "Es1938debug - AUDIO channel 2 interrupt\n");
1633                 dev_dbg(chip->card->dev,
1634                        "Es1938debug - AUDIO channel 2 DMAC DMA count: %u\n",
1635                        inw(SLIO_REG(chip, AUDIO2DMACOUNT)));
1636                 dev_dbg(chip->card->dev,
1637                        "Es1938debug - AUDIO channel 2 DMAC DMA base: %u\n",
1638                        inl(SLIO_REG(chip, AUDIO2DMAADDR)));
1639
1640 #endif
1641                 /* clear irq */
1642                 handled = 1;
1643                 snd_es1938_mixer_bits(chip, ESSSB_IREG_AUDIO2CONTROL2, 0x80, 0);
1644                 if (chip->active & DAC2)
1645                         snd_pcm_period_elapsed(chip->playback1_substream);
1646         }
1647
1648         /* Hardware volume */
1649         if (status & 0x40) {
1650                 int split = snd_es1938_mixer_read(chip, 0x64) & 0x80;
1651                 handled = 1;
1652                 snd_ctl_notify(chip->card, SNDRV_CTL_EVENT_MASK_VALUE, &chip->hw_switch->id);
1653                 snd_ctl_notify(chip->card, SNDRV_CTL_EVENT_MASK_VALUE, &chip->hw_volume->id);
1654                 if (!split) {
1655                         snd_ctl_notify(chip->card, SNDRV_CTL_EVENT_MASK_VALUE,
1656                                        &chip->master_switch->id);
1657                         snd_ctl_notify(chip->card, SNDRV_CTL_EVENT_MASK_VALUE,
1658                                        &chip->master_volume->id);
1659                 }
1660                 /* ack interrupt */
1661                 snd_es1938_mixer_write(chip, 0x66, 0x00);
1662         }
1663
1664         /* MPU401 */
1665         if (status & 0x80) {
1666                 // the following line is evil! It switches off MIDI interrupt handling after the first interrupt received.
1667                 // replacing the last 0 by 0x40 works for ESS-Solo1, but just doing nothing works as well!
1668                 // andreas@flying-snail.de
1669                 // snd_es1938_mixer_bits(chip, ESSSB_IREG_MPU401CONTROL, 0x40, 0); /* ack? */
1670                 if (chip->rmidi) {
1671                         handled = 1;
1672                         snd_mpu401_uart_interrupt(irq, chip->rmidi->private_data);
1673                 }
1674         }
1675         return IRQ_RETVAL(handled);
1676 }
1677
1678 #define ES1938_DMA_SIZE 64
1679
1680 static int snd_es1938_mixer(struct es1938 *chip)
1681 {
1682         struct snd_card *card;
1683         unsigned int idx;
1684         int err;
1685
1686         card = chip->card;
1687
1688         strcpy(card->mixername, "ESS Solo-1");
1689
1690         for (idx = 0; idx < ARRAY_SIZE(snd_es1938_controls); idx++) {
1691                 struct snd_kcontrol *kctl;
1692                 kctl = snd_ctl_new1(&snd_es1938_controls[idx], chip);
1693                 switch (idx) {
1694                         case 0:
1695                                 chip->master_volume = kctl;
1696                                 kctl->private_free = snd_es1938_hwv_free;
1697                                 break;
1698                         case 1:
1699                                 chip->master_switch = kctl;
1700                                 kctl->private_free = snd_es1938_hwv_free;
1701                                 break;
1702                         case 2:
1703                                 chip->hw_volume = kctl;
1704                                 kctl->private_free = snd_es1938_hwv_free;
1705                                 break;
1706                         case 3:
1707                                 chip->hw_switch = kctl;
1708                                 kctl->private_free = snd_es1938_hwv_free;
1709                                 break;
1710                         }
1711                 err = snd_ctl_add(card, kctl);
1712                 if (err < 0)
1713                         return err;
1714         }
1715         return 0;
1716 }
1717        
1718
1719 static int __snd_es1938_probe(struct pci_dev *pci,
1720                               const struct pci_device_id *pci_id)
1721 {
1722         static int dev;
1723         struct snd_card *card;
1724         struct es1938 *chip;
1725         struct snd_opl3 *opl3;
1726         int idx, err;
1727
1728         if (dev >= SNDRV_CARDS)
1729                 return -ENODEV;
1730         if (!enable[dev]) {
1731                 dev++;
1732                 return -ENOENT;
1733         }
1734
1735         err = snd_devm_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
1736                                 sizeof(*chip), &card);
1737         if (err < 0)
1738                 return err;
1739         chip = card->private_data;
1740
1741         for (idx = 0; idx < 5; idx++)
1742                 if (pci_resource_start(pci, idx) == 0 ||
1743                     !(pci_resource_flags(pci, idx) & IORESOURCE_IO))
1744                         return -ENODEV;
1745
1746         err = snd_es1938_create(card, pci);
1747         if (err < 0)
1748                 return err;
1749
1750         strcpy(card->driver, "ES1938");
1751         strcpy(card->shortname, "ESS ES1938 (Solo-1)");
1752         sprintf(card->longname, "%s rev %i, irq %i",
1753                 card->shortname,
1754                 chip->revision,
1755                 chip->irq);
1756
1757         err = snd_es1938_new_pcm(chip, 0);
1758         if (err < 0)
1759                 return err;
1760         err = snd_es1938_mixer(chip);
1761         if (err < 0)
1762                 return err;
1763         if (snd_opl3_create(card,
1764                             SLSB_REG(chip, FMLOWADDR),
1765                             SLSB_REG(chip, FMHIGHADDR),
1766                             OPL3_HW_OPL3, 1, &opl3) < 0) {
1767                 dev_err(card->dev, "OPL3 not detected at 0x%lx\n",
1768                            SLSB_REG(chip, FMLOWADDR));
1769         } else {
1770                 err = snd_opl3_timer_new(opl3, 0, 1);
1771                 if (err < 0)
1772                         return err;
1773                 err = snd_opl3_hwdep_new(opl3, 0, 1, NULL);
1774                 if (err < 0)
1775                         return err;
1776         }
1777         if (snd_mpu401_uart_new(card, 0, MPU401_HW_MPU401,
1778                                 chip->mpu_port,
1779                                 MPU401_INFO_INTEGRATED | MPU401_INFO_IRQ_HOOK,
1780                                 -1, &chip->rmidi) < 0) {
1781                 dev_err(card->dev, "unable to initialize MPU-401\n");
1782         } else {
1783                 // this line is vital for MIDI interrupt handling on ess-solo1
1784                 // andreas@flying-snail.de
1785                 snd_es1938_mixer_bits(chip, ESSSB_IREG_MPU401CONTROL, 0x40, 0x40);
1786         }
1787
1788         snd_es1938_create_gameport(chip);
1789
1790         err = snd_card_register(card);
1791         if (err < 0)
1792                 return err;
1793
1794         pci_set_drvdata(pci, card);
1795         dev++;
1796         return 0;
1797 }
1798
1799 static int snd_es1938_probe(struct pci_dev *pci,
1800                             const struct pci_device_id *pci_id)
1801 {
1802         return snd_card_free_on_error(&pci->dev, __snd_es1938_probe(pci, pci_id));
1803 }
1804
1805 static struct pci_driver es1938_driver = {
1806         .name = KBUILD_MODNAME,
1807         .id_table = snd_es1938_ids,
1808         .probe = snd_es1938_probe,
1809         .driver = {
1810                 .pm = ES1938_PM_OPS,
1811         },
1812 };
1813
1814 module_pci_driver(es1938_driver);