aboutsummaryrefslogtreecommitdiffstats
path: root/sound/sparc/cs4231.c
diff options
context:
space:
mode:
Diffstat (limited to 'sound/sparc/cs4231.c')
-rw-r--r--sound/sparc/cs4231.c380
1 files changed, 230 insertions, 150 deletions
diff --git a/sound/sparc/cs4231.c b/sound/sparc/cs4231.c
index 20daf261d03d..bd1e35580f3a 100644
--- a/sound/sparc/cs4231.c
+++ b/sound/sparc/cs4231.c
@@ -3,7 +3,7 @@
3 * Copyright (C) 2002 David S. Miller <davem@redhat.com> 3 * Copyright (C) 2002 David S. Miller <davem@redhat.com>
4 * 4 *
5 * Based entirely upon drivers/sbus/audio/cs4231.c which is: 5 * Based entirely upon drivers/sbus/audio/cs4231.c which is:
6 * Copyright (C) 1996, 1997, 1998, 1998 Derrick J Brashear (shadow@andrew.cmu.edu) 6 * Copyright (C) 1996, 1997, 1998 Derrick J Brashear (shadow@andrew.cmu.edu)
7 * and also sound/isa/cs423x/cs4231_lib.c which is: 7 * and also sound/isa/cs423x/cs4231_lib.c which is:
8 * Copyright (c) by Jaroslav Kysela <perex@suse.cz> 8 * Copyright (c) by Jaroslav Kysela <perex@suse.cz>
9 */ 9 */
@@ -15,6 +15,9 @@
15#include <linux/init.h> 15#include <linux/init.h>
16#include <linux/interrupt.h> 16#include <linux/interrupt.h>
17#include <linux/moduleparam.h> 17#include <linux/moduleparam.h>
18#include <linux/irq.h>
19#include <linux/io.h>
20
18 21
19#include <sound/driver.h> 22#include <sound/driver.h>
20#include <sound/core.h> 23#include <sound/core.h>
@@ -25,9 +28,6 @@
25#include <sound/initval.h> 28#include <sound/initval.h>
26#include <sound/pcm_params.h> 29#include <sound/pcm_params.h>
27 30
28#include <asm/io.h>
29#include <asm/irq.h>
30
31#ifdef CONFIG_SBUS 31#ifdef CONFIG_SBUS
32#define SBUS_SUPPORT 32#define SBUS_SUPPORT
33#include <asm/sbus.h> 33#include <asm/sbus.h>
@@ -41,7 +41,8 @@
41 41
42static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX; /* Index 0-MAX */ 42static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX; /* Index 0-MAX */
43static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR; /* ID for this card */ 43static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR; /* ID for this card */
44static int enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP; /* Enable this card */ 44/* Enable this card */
45static int enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP;
45 46
46module_param_array(index, int, NULL, 0444); 47module_param_array(index, int, NULL, 0444);
47MODULE_PARM_DESC(index, "Index value for Sun CS4231 soundcard."); 48MODULE_PARM_DESC(index, "Index value for Sun CS4231 soundcard.");
@@ -56,19 +57,22 @@ MODULE_SUPPORTED_DEVICE("{{Sun,CS4231}}");
56 57
57#ifdef SBUS_SUPPORT 58#ifdef SBUS_SUPPORT
58struct sbus_dma_info { 59struct sbus_dma_info {
59 spinlock_t lock; 60 spinlock_t lock; /* DMA access lock */
60 int dir; 61 int dir;
61 void __iomem *regs; 62 void __iomem *regs;
62}; 63};
63#endif 64#endif
64 65
65struct snd_cs4231; 66struct snd_cs4231;
66struct cs4231_dma_control { 67struct cs4231_dma_control {
67 void (*prepare)(struct cs4231_dma_control *dma_cont, int dir); 68 void (*prepare)(struct cs4231_dma_control *dma_cont,
68 void (*enable)(struct cs4231_dma_control *dma_cont, int on); 69 int dir);
69 int (*request)(struct cs4231_dma_control *dma_cont, dma_addr_t bus_addr, size_t len); 70 void (*enable)(struct cs4231_dma_control *dma_cont, int on);
70 unsigned int (*address)(struct cs4231_dma_control *dma_cont); 71 int (*request)(struct cs4231_dma_control *dma_cont,
71 void (*preallocate)(struct snd_cs4231 *chip, struct snd_pcm *pcm); 72 dma_addr_t bus_addr, size_t len);
73 unsigned int (*address)(struct cs4231_dma_control *dma_cont);
74 void (*preallocate)(struct snd_cs4231 *chip,
75 struct snd_pcm *pcm);
72#ifdef EBUS_SUPPORT 76#ifdef EBUS_SUPPORT
73 struct ebus_dma_info ebus_info; 77 struct ebus_dma_info ebus_info;
74#endif 78#endif
@@ -78,7 +82,7 @@ struct cs4231_dma_control {
78}; 82};
79 83
80struct snd_cs4231 { 84struct snd_cs4231 {
81 spinlock_t lock; 85 spinlock_t lock; /* registers access lock */
82 void __iomem *port; 86 void __iomem *port;
83 87
84 struct cs4231_dma_control p_dma; 88 struct cs4231_dma_control p_dma;
@@ -102,13 +106,14 @@ struct snd_cs4231 {
102#define CS4231_MODE_PLAY 0x0001 106#define CS4231_MODE_PLAY 0x0001
103#define CS4231_MODE_RECORD 0x0002 107#define CS4231_MODE_RECORD 0x0002
104#define CS4231_MODE_TIMER 0x0004 108#define CS4231_MODE_TIMER 0x0004
105#define CS4231_MODE_OPEN (CS4231_MODE_PLAY|CS4231_MODE_RECORD|CS4231_MODE_TIMER) 109#define CS4231_MODE_OPEN (CS4231_MODE_PLAY | CS4231_MODE_RECORD | \
110 CS4231_MODE_TIMER)
106 111
107 unsigned char image[32]; /* registers image */ 112 unsigned char image[32]; /* registers image */
108 int mce_bit; 113 int mce_bit;
109 int calibrate_mute; 114 int calibrate_mute;
110 struct mutex mce_mutex; 115 struct mutex mce_mutex; /* mutex for mce register */
111 struct mutex open_mutex; 116 struct mutex open_mutex; /* mutex for ALSA open/close */
112 117
113 union { 118 union {
114#ifdef SBUS_SUPPORT 119#ifdef SBUS_SUPPORT
@@ -392,7 +397,8 @@ static u8 __cs4231_readb(struct snd_cs4231 *cp, void __iomem *reg_addr)
392#endif 397#endif
393} 398}
394 399
395static void __cs4231_writeb(struct snd_cs4231 *cp, u8 val, void __iomem *reg_addr) 400static void __cs4231_writeb(struct snd_cs4231 *cp, u8 val,
401 void __iomem *reg_addr)
396{ 402{
397#ifdef EBUS_SUPPORT 403#ifdef EBUS_SUPPORT
398 if (cp->flags & CS4231_FLAG_EBUS) 404 if (cp->flags & CS4231_FLAG_EBUS)
@@ -418,7 +424,8 @@ static void snd_cs4231_ready(struct snd_cs4231 *chip)
418 udelay(100); 424 udelay(100);
419} 425}
420 426
421static void snd_cs4231_dout(struct snd_cs4231 *chip, unsigned char reg, unsigned char value) 427static void snd_cs4231_dout(struct snd_cs4231 *chip, unsigned char reg,
428 unsigned char value)
422{ 429{
423 snd_cs4231_ready(chip); 430 snd_cs4231_ready(chip);
424#ifdef CONFIG_SND_DEBUG 431#ifdef CONFIG_SND_DEBUG
@@ -472,7 +479,7 @@ static void snd_cs4231_busy_wait(struct snd_cs4231 *chip)
472{ 479{
473 int timeout; 480 int timeout;
474 481
475 /* huh.. looks like this sequence is proper for CS4231A chip (GUS MAX) */ 482 /* looks like this sequence is proper for CS4231A chip (GUS MAX) */
476 for (timeout = 5; timeout > 0; timeout--) 483 for (timeout = 5; timeout > 0; timeout--)
477 __cs4231_readb(chip, CS4231P(chip, REGSEL)); 484 __cs4231_readb(chip, CS4231P(chip, REGSEL));
478 485
@@ -497,7 +504,9 @@ static void snd_cs4231_mce_up(struct snd_cs4231 *chip)
497 chip->mce_bit |= CS4231_MCE; 504 chip->mce_bit |= CS4231_MCE;
498 timeout = __cs4231_readb(chip, CS4231P(chip, REGSEL)); 505 timeout = __cs4231_readb(chip, CS4231P(chip, REGSEL));
499 if (timeout == 0x80) 506 if (timeout == 0x80)
500 snd_printdd("mce_up [%p]: serious init problem - codec still busy\n", chip->port); 507 snd_printdd("mce_up [%p]: serious init problem - "
508 "codec still busy\n",
509 chip->port);
501 if (!(timeout & CS4231_MCE)) 510 if (!(timeout & CS4231_MCE))
502 __cs4231_writeb(chip, chip->mce_bit | (timeout & 0x1f), CS4231P(chip, REGSEL)); 511 __cs4231_writeb(chip, chip->mce_bit | (timeout & 0x1f), CS4231P(chip, REGSEL));
503 spin_unlock_irqrestore(&chip->lock, flags); 512 spin_unlock_irqrestore(&chip->lock, flags);
@@ -518,7 +527,9 @@ static void snd_cs4231_mce_down(struct snd_cs4231 *chip)
518 timeout = __cs4231_readb(chip, CS4231P(chip, REGSEL)); 527 timeout = __cs4231_readb(chip, CS4231P(chip, REGSEL));
519 __cs4231_writeb(chip, chip->mce_bit | (timeout & 0x1f), CS4231P(chip, REGSEL)); 528 __cs4231_writeb(chip, chip->mce_bit | (timeout & 0x1f), CS4231P(chip, REGSEL));
520 if (timeout == 0x80) 529 if (timeout == 0x80)
521 snd_printdd("mce_down [%p]: serious init problem - codec still busy\n", chip->port); 530 snd_printdd("mce_down [%p]: serious init problem - "
531 "codec still busy\n",
532 chip->port);
522 if ((timeout & CS4231_MCE) == 0) { 533 if ((timeout & CS4231_MCE) == 0) {
523 spin_unlock_irqrestore(&chip->lock, flags); 534 spin_unlock_irqrestore(&chip->lock, flags);
524 return; 535 return;
@@ -529,7 +540,8 @@ static void snd_cs4231_mce_down(struct snd_cs4231 *chip)
529 540
530 snd_cs4231_ready(chip); 541 snd_cs4231_ready(chip);
531 snd_cs4231_ready(chip); 542 snd_cs4231_ready(chip);
532 if ((snd_cs4231_in(chip, CS4231_TEST_INIT) & CS4231_CALIB_IN_PROGRESS) == 0) { 543 timeout = snd_cs4231_in(chip, CS4231_TEST_INIT);
544 if ((timeout & CS4231_CALIB_IN_PROGRESS) == 0) {
533 snd_printd("cs4231_mce_down - auto calibration time out (1)\n"); 545 snd_printd("cs4231_mce_down - auto calibration time out (1)\n");
534 spin_unlock_irqrestore(&chip->lock, flags); 546 spin_unlock_irqrestore(&chip->lock, flags);
535 return; 547 return;
@@ -537,10 +549,13 @@ static void snd_cs4231_mce_down(struct snd_cs4231 *chip)
537 549
538 /* in 10ms increments, check condition, up to 250ms */ 550 /* in 10ms increments, check condition, up to 250ms */
539 timeout = 25; 551 timeout = 25;
540 while (snd_cs4231_in(chip, CS4231_TEST_INIT) & CS4231_CALIB_IN_PROGRESS) { 552 while (snd_cs4231_in(chip, CS4231_TEST_INIT) &
553 CS4231_CALIB_IN_PROGRESS) {
554
541 spin_unlock_irqrestore(&chip->lock, flags); 555 spin_unlock_irqrestore(&chip->lock, flags);
542 if (--timeout < 0) { 556 if (--timeout < 0) {
543 snd_printk("mce_down - auto calibration time out (2)\n"); 557 snd_printk("mce_down - "
558 "auto calibration time out (2)\n");
544 return; 559 return;
545 } 560 }
546 msleep(10); 561 msleep(10);
@@ -552,7 +567,8 @@ static void snd_cs4231_mce_down(struct snd_cs4231 *chip)
552 while (__cs4231_readb(chip, CS4231P(chip, REGSEL)) & CS4231_INIT) { 567 while (__cs4231_readb(chip, CS4231P(chip, REGSEL)) & CS4231_INIT) {
553 spin_unlock_irqrestore(&chip->lock, flags); 568 spin_unlock_irqrestore(&chip->lock, flags);
554 if (--timeout < 0) { 569 if (--timeout < 0) {
555 snd_printk("mce_down - auto calibration time out (3)\n"); 570 snd_printk("mce_down - "
571 "auto calibration time out (3)\n");
556 return; 572 return;
557 } 573 }
558 msleep(10); 574 msleep(10);
@@ -573,7 +589,8 @@ static void snd_cs4231_advance_dma(struct cs4231_dma_control *dma_cont,
573 589
574 BUG_ON(period_size >= (1 << 24)); 590 BUG_ON(period_size >= (1 << 24));
575 591
576 if (dma_cont->request(dma_cont, runtime->dma_addr + offset, period_size)) 592 if (dma_cont->request(dma_cont,
593 runtime->dma_addr + offset, period_size))
577 return; 594 return;
578 (*periods_sent) = ((*periods_sent) + 1) % runtime->periods; 595 (*periods_sent) = ((*periods_sent) + 1) % runtime->periods;
579 } 596 }
@@ -666,21 +683,32 @@ static unsigned char snd_cs4231_get_rate(unsigned int rate)
666 for (i = 0; i < 14; i++) 683 for (i = 0; i < 14; i++)
667 if (rate == rates[i]) 684 if (rate == rates[i])
668 return freq_bits[i]; 685 return freq_bits[i];
669 // snd_BUG(); 686
670 return freq_bits[13]; 687 return freq_bits[13];
671} 688}
672 689
673static unsigned char snd_cs4231_get_format(struct snd_cs4231 *chip, int format, int channels) 690static unsigned char snd_cs4231_get_format(struct snd_cs4231 *chip, int format,
691 int channels)
674{ 692{
675 unsigned char rformat; 693 unsigned char rformat;
676 694
677 rformat = CS4231_LINEAR_8; 695 rformat = CS4231_LINEAR_8;
678 switch (format) { 696 switch (format) {
679 case SNDRV_PCM_FORMAT_MU_LAW: rformat = CS4231_ULAW_8; break; 697 case SNDRV_PCM_FORMAT_MU_LAW:
680 case SNDRV_PCM_FORMAT_A_LAW: rformat = CS4231_ALAW_8; break; 698 rformat = CS4231_ULAW_8;
681 case SNDRV_PCM_FORMAT_S16_LE: rformat = CS4231_LINEAR_16; break; 699 break;
682 case SNDRV_PCM_FORMAT_S16_BE: rformat = CS4231_LINEAR_16_BIG; break; 700 case SNDRV_PCM_FORMAT_A_LAW:
683 case SNDRV_PCM_FORMAT_IMA_ADPCM: rformat = CS4231_ADPCM_16; break; 701 rformat = CS4231_ALAW_8;
702 break;
703 case SNDRV_PCM_FORMAT_S16_LE:
704 rformat = CS4231_LINEAR_16;
705 break;
706 case SNDRV_PCM_FORMAT_S16_BE:
707 rformat = CS4231_LINEAR_16_BIG;
708 break;
709 case SNDRV_PCM_FORMAT_IMA_ADPCM:
710 rformat = CS4231_ADPCM_16;
711 break;
684 } 712 }
685 if (channels > 1) 713 if (channels > 1)
686 rformat |= CS4231_STEREO; 714 rformat |= CS4231_STEREO;
@@ -727,7 +755,8 @@ static void snd_cs4231_calibrate_mute(struct snd_cs4231 *chip, int mute)
727 spin_unlock_irqrestore(&chip->lock, flags); 755 spin_unlock_irqrestore(&chip->lock, flags);
728} 756}
729 757
730static void snd_cs4231_playback_format(struct snd_cs4231 *chip, struct snd_pcm_hw_params *params, 758static void snd_cs4231_playback_format(struct snd_cs4231 *chip,
759 struct snd_pcm_hw_params *params,
731 unsigned char pdfr) 760 unsigned char pdfr)
732{ 761{
733 unsigned long flags; 762 unsigned long flags;
@@ -750,8 +779,9 @@ static void snd_cs4231_playback_format(struct snd_cs4231 *chip, struct snd_pcm_h
750 mutex_unlock(&chip->mce_mutex); 779 mutex_unlock(&chip->mce_mutex);
751} 780}
752 781
753static void snd_cs4231_capture_format(struct snd_cs4231 *chip, struct snd_pcm_hw_params *params, 782static void snd_cs4231_capture_format(struct snd_cs4231 *chip,
754 unsigned char cdfr) 783 struct snd_pcm_hw_params *params,
784 unsigned char cdfr)
755{ 785{
756 unsigned long flags; 786 unsigned long flags;
757 787
@@ -808,7 +838,8 @@ static int snd_cs4231_timer_start(struct snd_timer *timer)
808 chip->image[CS4231_TIMER_LOW] = 838 chip->image[CS4231_TIMER_LOW] =
809 (unsigned char) ticks); 839 (unsigned char) ticks);
810 snd_cs4231_out(chip, CS4231_ALT_FEATURE_1, 840 snd_cs4231_out(chip, CS4231_ALT_FEATURE_1,
811 chip->image[CS4231_ALT_FEATURE_1] | CS4231_TIMER_ENABLE); 841 chip->image[CS4231_ALT_FEATURE_1] |
842 CS4231_TIMER_ENABLE);
812 } 843 }
813 spin_unlock_irqrestore(&chip->lock, flags); 844 spin_unlock_irqrestore(&chip->lock, flags);
814 845
@@ -821,8 +852,9 @@ static int snd_cs4231_timer_stop(struct snd_timer *timer)
821 struct snd_cs4231 *chip = snd_timer_chip(timer); 852 struct snd_cs4231 *chip = snd_timer_chip(timer);
822 853
823 spin_lock_irqsave(&chip->lock, flags); 854 spin_lock_irqsave(&chip->lock, flags);
855 chip->image[CS4231_ALT_FEATURE_1] &= ~CS4231_TIMER_ENABLE;
824 snd_cs4231_out(chip, CS4231_ALT_FEATURE_1, 856 snd_cs4231_out(chip, CS4231_ALT_FEATURE_1,
825 chip->image[CS4231_ALT_FEATURE_1] &= ~CS4231_TIMER_ENABLE); 857 chip->image[CS4231_ALT_FEATURE_1]);
826 spin_unlock_irqrestore(&chip->lock, flags); 858 spin_unlock_irqrestore(&chip->lock, flags);
827 859
828 return 0; 860 return 0;
@@ -839,8 +871,10 @@ static void __init snd_cs4231_init(struct snd_cs4231 *chip)
839#endif 871#endif
840 snd_cs4231_mce_up(chip); 872 snd_cs4231_mce_up(chip);
841 spin_lock_irqsave(&chip->lock, flags); 873 spin_lock_irqsave(&chip->lock, flags);
842 chip->image[CS4231_IFACE_CTRL] &= ~(CS4231_PLAYBACK_ENABLE | CS4231_PLAYBACK_PIO | 874 chip->image[CS4231_IFACE_CTRL] &= ~(CS4231_PLAYBACK_ENABLE |
843 CS4231_RECORD_ENABLE | CS4231_RECORD_PIO | 875 CS4231_PLAYBACK_PIO |
876 CS4231_RECORD_ENABLE |
877 CS4231_RECORD_PIO |
844 CS4231_CALIB_MODE); 878 CS4231_CALIB_MODE);
845 chip->image[CS4231_IFACE_CTRL] |= CS4231_AUTOCALIB; 879 chip->image[CS4231_IFACE_CTRL] |= CS4231_AUTOCALIB;
846 snd_cs4231_out(chip, CS4231_IFACE_CTRL, chip->image[CS4231_IFACE_CTRL]); 880 snd_cs4231_out(chip, CS4231_IFACE_CTRL, chip->image[CS4231_IFACE_CTRL]);
@@ -853,21 +887,25 @@ static void __init snd_cs4231_init(struct snd_cs4231 *chip)
853 887
854 snd_cs4231_mce_up(chip); 888 snd_cs4231_mce_up(chip);
855 spin_lock_irqsave(&chip->lock, flags); 889 spin_lock_irqsave(&chip->lock, flags);
856 snd_cs4231_out(chip, CS4231_ALT_FEATURE_1, chip->image[CS4231_ALT_FEATURE_1]); 890 snd_cs4231_out(chip, CS4231_ALT_FEATURE_1,
891 chip->image[CS4231_ALT_FEATURE_1]);
857 spin_unlock_irqrestore(&chip->lock, flags); 892 spin_unlock_irqrestore(&chip->lock, flags);
858 snd_cs4231_mce_down(chip); 893 snd_cs4231_mce_down(chip);
859 894
860#ifdef SNDRV_DEBUG_MCE 895#ifdef SNDRV_DEBUG_MCE
861 snd_printdd("init: (3) - afei = 0x%x\n", chip->image[CS4231_ALT_FEATURE_1]); 896 snd_printdd("init: (3) - afei = 0x%x\n",
897 chip->image[CS4231_ALT_FEATURE_1]);
862#endif 898#endif
863 899
864 spin_lock_irqsave(&chip->lock, flags); 900 spin_lock_irqsave(&chip->lock, flags);
865 snd_cs4231_out(chip, CS4231_ALT_FEATURE_2, chip->image[CS4231_ALT_FEATURE_2]); 901 snd_cs4231_out(chip, CS4231_ALT_FEATURE_2,
902 chip->image[CS4231_ALT_FEATURE_2]);
866 spin_unlock_irqrestore(&chip->lock, flags); 903 spin_unlock_irqrestore(&chip->lock, flags);
867 904
868 snd_cs4231_mce_up(chip); 905 snd_cs4231_mce_up(chip);
869 spin_lock_irqsave(&chip->lock, flags); 906 spin_lock_irqsave(&chip->lock, flags);
870 snd_cs4231_out(chip, CS4231_PLAYBK_FORMAT, chip->image[CS4231_PLAYBK_FORMAT]); 907 snd_cs4231_out(chip, CS4231_PLAYBK_FORMAT,
908 chip->image[CS4231_PLAYBK_FORMAT]);
871 spin_unlock_irqrestore(&chip->lock, flags); 909 spin_unlock_irqrestore(&chip->lock, flags);
872 snd_cs4231_mce_down(chip); 910 snd_cs4231_mce_down(chip);
873 911
@@ -950,7 +988,8 @@ static void snd_cs4231_close(struct snd_cs4231 *chip, unsigned int mode)
950 chip->image[CS4231_IFACE_CTRL] &= 988 chip->image[CS4231_IFACE_CTRL] &=
951 ~(CS4231_PLAYBACK_ENABLE | CS4231_PLAYBACK_PIO | 989 ~(CS4231_PLAYBACK_ENABLE | CS4231_PLAYBACK_PIO |
952 CS4231_RECORD_ENABLE | CS4231_RECORD_PIO); 990 CS4231_RECORD_ENABLE | CS4231_RECORD_PIO);
953 snd_cs4231_out(chip, CS4231_IFACE_CTRL, chip->image[CS4231_IFACE_CTRL]); 991 snd_cs4231_out(chip, CS4231_IFACE_CTRL,
992 chip->image[CS4231_IFACE_CTRL]);
954 spin_unlock_irqrestore(&chip->lock, flags); 993 spin_unlock_irqrestore(&chip->lock, flags);
955 snd_cs4231_mce_down(chip); 994 snd_cs4231_mce_down(chip);
956 spin_lock_irqsave(&chip->lock, flags); 995 spin_lock_irqsave(&chip->lock, flags);
@@ -979,15 +1018,14 @@ static int snd_cs4231_timer_open(struct snd_timer *timer)
979 return 0; 1018 return 0;
980} 1019}
981 1020
982static int snd_cs4231_timer_close(struct snd_timer * timer) 1021static int snd_cs4231_timer_close(struct snd_timer *timer)
983{ 1022{
984 struct snd_cs4231 *chip = snd_timer_chip(timer); 1023 struct snd_cs4231 *chip = snd_timer_chip(timer);
985 snd_cs4231_close(chip, CS4231_MODE_TIMER); 1024 snd_cs4231_close(chip, CS4231_MODE_TIMER);
986 return 0; 1025 return 0;
987} 1026}
988 1027
989static struct snd_timer_hardware snd_cs4231_timer_table = 1028static struct snd_timer_hardware snd_cs4231_timer_table = {
990{
991 .flags = SNDRV_TIMER_HW_AUTO, 1029 .flags = SNDRV_TIMER_HW_AUTO,
992 .resolution = 9945, 1030 .resolution = 9945,
993 .ticks = 65535, 1031 .ticks = 65535,
@@ -1009,8 +1047,9 @@ static int snd_cs4231_playback_hw_params(struct snd_pcm_substream *substream,
1009 unsigned char new_pdfr; 1047 unsigned char new_pdfr;
1010 int err; 1048 int err;
1011 1049
1012 if ((err = snd_pcm_lib_malloc_pages(substream, 1050 err = snd_pcm_lib_malloc_pages(substream,
1013 params_buffer_bytes(hw_params))) < 0) 1051 params_buffer_bytes(hw_params));
1052 if (err < 0)
1014 return err; 1053 return err;
1015 new_pdfr = snd_cs4231_get_format(chip, params_format(hw_params), 1054 new_pdfr = snd_cs4231_get_format(chip, params_format(hw_params),
1016 params_channels(hw_params)) | 1055 params_channels(hw_params)) |
@@ -1046,8 +1085,9 @@ static int snd_cs4231_capture_hw_params(struct snd_pcm_substream *substream,
1046 unsigned char new_cdfr; 1085 unsigned char new_cdfr;
1047 int err; 1086 int err;
1048 1087
1049 if ((err = snd_pcm_lib_malloc_pages(substream, 1088 err = snd_pcm_lib_malloc_pages(substream,
1050 params_buffer_bytes(hw_params))) < 0) 1089 params_buffer_bytes(hw_params));
1090 if (err < 0)
1051 return err; 1091 return err;
1052 new_cdfr = snd_cs4231_get_format(chip, params_format(hw_params), 1092 new_cdfr = snd_cs4231_get_format(chip, params_format(hw_params),
1053 params_channels(hw_params)) | 1093 params_channels(hw_params)) |
@@ -1082,7 +1122,8 @@ static void snd_cs4231_overrange(struct snd_cs4231 *chip)
1082 res = snd_cs4231_in(chip, CS4231_TEST_INIT); 1122 res = snd_cs4231_in(chip, CS4231_TEST_INIT);
1083 spin_unlock_irqrestore(&chip->lock, flags); 1123 spin_unlock_irqrestore(&chip->lock, flags);
1084 1124
1085 if (res & (0x08 | 0x02)) /* detect overrange only above 0dB; may be user selectable? */ 1125 /* detect overrange only above 0dB; may be user selectable? */
1126 if (res & (0x08 | 0x02))
1086 chip->capture_substream->runtime->overrange++; 1127 chip->capture_substream->runtime->overrange++;
1087} 1128}
1088 1129
@@ -1104,47 +1145,50 @@ static void snd_cs4231_capture_callback(struct snd_cs4231 *chip)
1104 } 1145 }
1105} 1146}
1106 1147
1107static snd_pcm_uframes_t snd_cs4231_playback_pointer(struct snd_pcm_substream *substream) 1148static snd_pcm_uframes_t snd_cs4231_playback_pointer(
1149 struct snd_pcm_substream *substream)
1108{ 1150{
1109 struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); 1151 struct snd_cs4231 *chip = snd_pcm_substream_chip(substream);
1110 struct cs4231_dma_control *dma_cont = &chip->p_dma; 1152 struct cs4231_dma_control *dma_cont = &chip->p_dma;
1111 size_t ptr; 1153 size_t ptr;
1112 1154
1113 if (!(chip->image[CS4231_IFACE_CTRL] & CS4231_PLAYBACK_ENABLE)) 1155 if (!(chip->image[CS4231_IFACE_CTRL] & CS4231_PLAYBACK_ENABLE))
1114 return 0; 1156 return 0;
1115 ptr = dma_cont->address(dma_cont); 1157 ptr = dma_cont->address(dma_cont);
1116 if (ptr != 0) 1158 if (ptr != 0)
1117 ptr -= substream->runtime->dma_addr; 1159 ptr -= substream->runtime->dma_addr;
1118 1160
1119 return bytes_to_frames(substream->runtime, ptr); 1161 return bytes_to_frames(substream->runtime, ptr);
1120} 1162}
1121 1163
1122static snd_pcm_uframes_t snd_cs4231_capture_pointer(struct snd_pcm_substream *substream) 1164static snd_pcm_uframes_t snd_cs4231_capture_pointer(
1165 struct snd_pcm_substream *substream)
1123{ 1166{
1124 struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); 1167 struct snd_cs4231 *chip = snd_pcm_substream_chip(substream);
1125 struct cs4231_dma_control *dma_cont = &chip->c_dma; 1168 struct cs4231_dma_control *dma_cont = &chip->c_dma;
1126 size_t ptr; 1169 size_t ptr;
1127 1170
1128 if (!(chip->image[CS4231_IFACE_CTRL] & CS4231_RECORD_ENABLE)) 1171 if (!(chip->image[CS4231_IFACE_CTRL] & CS4231_RECORD_ENABLE))
1129 return 0; 1172 return 0;
1130 ptr = dma_cont->address(dma_cont); 1173 ptr = dma_cont->address(dma_cont);
1131 if (ptr != 0) 1174 if (ptr != 0)
1132 ptr -= substream->runtime->dma_addr; 1175 ptr -= substream->runtime->dma_addr;
1133 1176
1134 return bytes_to_frames(substream->runtime, ptr); 1177 return bytes_to_frames(substream->runtime, ptr);
1135} 1178}
1136 1179
1137static int __init snd_cs4231_probe(struct snd_cs4231 *chip) 1180static int __init snd_cs4231_probe(struct snd_cs4231 *chip)
1138{ 1181{
1139 unsigned long flags; 1182 unsigned long flags;
1140 int i, id, vers; 1183 int i;
1184 int id = 0;
1185 int vers = 0;
1141 unsigned char *ptr; 1186 unsigned char *ptr;
1142 1187
1143 id = vers = 0;
1144 for (i = 0; i < 50; i++) { 1188 for (i = 0; i < 50; i++) {
1145 mb(); 1189 mb();
1146 if (__cs4231_readb(chip, CS4231P(chip, REGSEL)) & CS4231_INIT) 1190 if (__cs4231_readb(chip, CS4231P(chip, REGSEL)) & CS4231_INIT)
1147 udelay(2000); 1191 msleep(2);
1148 else { 1192 else {
1149 spin_lock_irqsave(&chip->lock, flags); 1193 spin_lock_irqsave(&chip->lock, flags);
1150 snd_cs4231_out(chip, CS4231_MISC_INFO, CS4231_MODE2); 1194 snd_cs4231_out(chip, CS4231_MISC_INFO, CS4231_MODE2);
@@ -1195,42 +1239,50 @@ static int __init snd_cs4231_probe(struct snd_cs4231 *chip)
1195 return 0; /* all things are ok.. */ 1239 return 0; /* all things are ok.. */
1196} 1240}
1197 1241
1198static struct snd_pcm_hardware snd_cs4231_playback = 1242static struct snd_pcm_hardware snd_cs4231_playback = {
1199{ 1243 .info = SNDRV_PCM_INFO_MMAP |
1200 .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | 1244 SNDRV_PCM_INFO_INTERLEAVED |
1201 SNDRV_PCM_INFO_MMAP_VALID | SNDRV_PCM_INFO_SYNC_START), 1245 SNDRV_PCM_INFO_MMAP_VALID |
1202 .formats = (SNDRV_PCM_FMTBIT_MU_LAW | SNDRV_PCM_FMTBIT_A_LAW | 1246 SNDRV_PCM_INFO_SYNC_START,
1203 SNDRV_PCM_FMTBIT_IMA_ADPCM | 1247 .formats = SNDRV_PCM_FMTBIT_MU_LAW |
1204 SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S16_LE | 1248 SNDRV_PCM_FMTBIT_A_LAW |
1205 SNDRV_PCM_FMTBIT_S16_BE), 1249 SNDRV_PCM_FMTBIT_IMA_ADPCM |
1206 .rates = SNDRV_PCM_RATE_KNOT | SNDRV_PCM_RATE_8000_48000, 1250 SNDRV_PCM_FMTBIT_U8 |
1251 SNDRV_PCM_FMTBIT_S16_LE |
1252 SNDRV_PCM_FMTBIT_S16_BE,
1253 .rates = SNDRV_PCM_RATE_KNOT |
1254 SNDRV_PCM_RATE_8000_48000,
1207 .rate_min = 5510, 1255 .rate_min = 5510,
1208 .rate_max = 48000, 1256 .rate_max = 48000,
1209 .channels_min = 1, 1257 .channels_min = 1,
1210 .channels_max = 2, 1258 .channels_max = 2,
1211 .buffer_bytes_max = (32*1024), 1259 .buffer_bytes_max = 32 * 1024,
1212 .period_bytes_min = 64, 1260 .period_bytes_min = 64,
1213 .period_bytes_max = (32*1024), 1261 .period_bytes_max = 32 * 1024,
1214 .periods_min = 1, 1262 .periods_min = 1,
1215 .periods_max = 1024, 1263 .periods_max = 1024,
1216}; 1264};
1217 1265
1218static struct snd_pcm_hardware snd_cs4231_capture = 1266static struct snd_pcm_hardware snd_cs4231_capture = {
1219{ 1267 .info = SNDRV_PCM_INFO_MMAP |
1220 .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | 1268 SNDRV_PCM_INFO_INTERLEAVED |
1221 SNDRV_PCM_INFO_MMAP_VALID | SNDRV_PCM_INFO_SYNC_START), 1269 SNDRV_PCM_INFO_MMAP_VALID |
1222 .formats = (SNDRV_PCM_FMTBIT_MU_LAW | SNDRV_PCM_FMTBIT_A_LAW | 1270 SNDRV_PCM_INFO_SYNC_START,
1223 SNDRV_PCM_FMTBIT_IMA_ADPCM | 1271 .formats = SNDRV_PCM_FMTBIT_MU_LAW |
1224 SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S16_LE | 1272 SNDRV_PCM_FMTBIT_A_LAW |
1225 SNDRV_PCM_FMTBIT_S16_BE), 1273 SNDRV_PCM_FMTBIT_IMA_ADPCM |
1226 .rates = SNDRV_PCM_RATE_KNOT | SNDRV_PCM_RATE_8000_48000, 1274 SNDRV_PCM_FMTBIT_U8 |
1275 SNDRV_PCM_FMTBIT_S16_LE |
1276 SNDRV_PCM_FMTBIT_S16_BE,
1277 .rates = SNDRV_PCM_RATE_KNOT |
1278 SNDRV_PCM_RATE_8000_48000,
1227 .rate_min = 5510, 1279 .rate_min = 5510,
1228 .rate_max = 48000, 1280 .rate_max = 48000,
1229 .channels_min = 1, 1281 .channels_min = 1,
1230 .channels_max = 2, 1282 .channels_max = 2,
1231 .buffer_bytes_max = (32*1024), 1283 .buffer_bytes_max = 32 * 1024,
1232 .period_bytes_min = 64, 1284 .period_bytes_min = 64,
1233 .period_bytes_max = (32*1024), 1285 .period_bytes_max = 32 * 1024,
1234 .periods_min = 1, 1286 .periods_min = 1,
1235 .periods_max = 1024, 1287 .periods_max = 1024,
1236}; 1288};
@@ -1243,7 +1295,8 @@ static int snd_cs4231_playback_open(struct snd_pcm_substream *substream)
1243 1295
1244 runtime->hw = snd_cs4231_playback; 1296 runtime->hw = snd_cs4231_playback;
1245 1297
1246 if ((err = snd_cs4231_open(chip, CS4231_MODE_PLAY)) < 0) { 1298 err = snd_cs4231_open(chip, CS4231_MODE_PLAY);
1299 if (err < 0) {
1247 snd_free_pages(runtime->dma_area, runtime->dma_bytes); 1300 snd_free_pages(runtime->dma_area, runtime->dma_bytes);
1248 return err; 1301 return err;
1249 } 1302 }
@@ -1263,7 +1316,8 @@ static int snd_cs4231_capture_open(struct snd_pcm_substream *substream)
1263 1316
1264 runtime->hw = snd_cs4231_capture; 1317 runtime->hw = snd_cs4231_capture;
1265 1318
1266 if ((err = snd_cs4231_open(chip, CS4231_MODE_RECORD)) < 0) { 1319 err = snd_cs4231_open(chip, CS4231_MODE_RECORD);
1320 if (err < 0) {
1267 snd_free_pages(runtime->dma_area, runtime->dma_bytes); 1321 snd_free_pages(runtime->dma_area, runtime->dma_bytes);
1268 return err; 1322 return err;
1269 } 1323 }
@@ -1331,9 +1385,11 @@ static int __init snd_cs4231_pcm(struct snd_card *card)
1331 if (err < 0) 1385 if (err < 0)
1332 return err; 1386 return err;
1333 1387
1334 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_cs4231_playback_ops); 1388 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK,
1335 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_cs4231_capture_ops); 1389 &snd_cs4231_playback_ops);
1336 1390 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE,
1391 &snd_cs4231_capture_ops);
1392
1337 /* global setup */ 1393 /* global setup */
1338 pcm->private_data = chip; 1394 pcm->private_data = chip;
1339 pcm->info_flags = SNDRV_PCM_INFO_JOINT_DUPLEX; 1395 pcm->info_flags = SNDRV_PCM_INFO_JOINT_DUPLEX;
@@ -1369,7 +1425,7 @@ static int __init snd_cs4231_timer(struct snd_card *card)
1369 1425
1370 return 0; 1426 return 0;
1371} 1427}
1372 1428
1373/* 1429/*
1374 * MIXER part 1430 * MIXER part
1375 */ 1431 */
@@ -1386,7 +1442,8 @@ static int snd_cs4231_info_mux(struct snd_kcontrol *kcontrol,
1386 uinfo->value.enumerated.items = 4; 1442 uinfo->value.enumerated.items = 4;
1387 if (uinfo->value.enumerated.item > 3) 1443 if (uinfo->value.enumerated.item > 3)
1388 uinfo->value.enumerated.item = 3; 1444 uinfo->value.enumerated.item = 3;
1389 strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]); 1445 strcpy(uinfo->value.enumerated.name,
1446 texts[uinfo->value.enumerated.item]);
1390 1447
1391 return 0; 1448 return 0;
1392} 1449}
@@ -1396,7 +1453,7 @@ static int snd_cs4231_get_mux(struct snd_kcontrol *kcontrol,
1396{ 1453{
1397 struct snd_cs4231 *chip = snd_kcontrol_chip(kcontrol); 1454 struct snd_cs4231 *chip = snd_kcontrol_chip(kcontrol);
1398 unsigned long flags; 1455 unsigned long flags;
1399 1456
1400 spin_lock_irqsave(&chip->lock, flags); 1457 spin_lock_irqsave(&chip->lock, flags);
1401 ucontrol->value.enumerated.item[0] = 1458 ucontrol->value.enumerated.item[0] =
1402 (chip->image[CS4231_LEFT_INPUT] & CS4231_MIXS_ALL) >> 6; 1459 (chip->image[CS4231_LEFT_INPUT] & CS4231_MIXS_ALL) >> 6;
@@ -1414,7 +1471,7 @@ static int snd_cs4231_put_mux(struct snd_kcontrol *kcontrol,
1414 unsigned long flags; 1471 unsigned long flags;
1415 unsigned short left, right; 1472 unsigned short left, right;
1416 int change; 1473 int change;
1417 1474
1418 if (ucontrol->value.enumerated.item[0] > 3 || 1475 if (ucontrol->value.enumerated.item[0] > 3 ||
1419 ucontrol->value.enumerated.item[1] > 3) 1476 ucontrol->value.enumerated.item[1] > 3)
1420 return -EINVAL; 1477 return -EINVAL;
@@ -1426,7 +1483,7 @@ static int snd_cs4231_put_mux(struct snd_kcontrol *kcontrol,
1426 left = (chip->image[CS4231_LEFT_INPUT] & ~CS4231_MIXS_ALL) | left; 1483 left = (chip->image[CS4231_LEFT_INPUT] & ~CS4231_MIXS_ALL) | left;
1427 right = (chip->image[CS4231_RIGHT_INPUT] & ~CS4231_MIXS_ALL) | right; 1484 right = (chip->image[CS4231_RIGHT_INPUT] & ~CS4231_MIXS_ALL) | right;
1428 change = left != chip->image[CS4231_LEFT_INPUT] || 1485 change = left != chip->image[CS4231_LEFT_INPUT] ||
1429 right != chip->image[CS4231_RIGHT_INPUT]; 1486 right != chip->image[CS4231_RIGHT_INPUT];
1430 snd_cs4231_out(chip, CS4231_LEFT_INPUT, left); 1487 snd_cs4231_out(chip, CS4231_LEFT_INPUT, left);
1431 snd_cs4231_out(chip, CS4231_RIGHT_INPUT, right); 1488 snd_cs4231_out(chip, CS4231_RIGHT_INPUT, right);
1432 1489
@@ -1458,7 +1515,7 @@ static int snd_cs4231_get_single(struct snd_kcontrol *kcontrol,
1458 int shift = (kcontrol->private_value >> 8) & 0xff; 1515 int shift = (kcontrol->private_value >> 8) & 0xff;
1459 int mask = (kcontrol->private_value >> 16) & 0xff; 1516 int mask = (kcontrol->private_value >> 16) & 0xff;
1460 int invert = (kcontrol->private_value >> 24) & 0xff; 1517 int invert = (kcontrol->private_value >> 24) & 0xff;
1461 1518
1462 spin_lock_irqsave(&chip->lock, flags); 1519 spin_lock_irqsave(&chip->lock, flags);
1463 1520
1464 ucontrol->value.integer.value[0] = (chip->image[reg] >> shift) & mask; 1521 ucontrol->value.integer.value[0] = (chip->image[reg] >> shift) & mask;
@@ -1483,7 +1540,7 @@ static int snd_cs4231_put_single(struct snd_kcontrol *kcontrol,
1483 int invert = (kcontrol->private_value >> 24) & 0xff; 1540 int invert = (kcontrol->private_value >> 24) & 0xff;
1484 int change; 1541 int change;
1485 unsigned short val; 1542 unsigned short val;
1486 1543
1487 val = (ucontrol->value.integer.value[0] & mask); 1544 val = (ucontrol->value.integer.value[0] & mask);
1488 if (invert) 1545 if (invert)
1489 val = mask - val; 1546 val = mask - val;
@@ -1525,11 +1582,13 @@ static int snd_cs4231_get_double(struct snd_kcontrol *kcontrol,
1525 int shift_right = (kcontrol->private_value >> 19) & 0x07; 1582 int shift_right = (kcontrol->private_value >> 19) & 0x07;
1526 int mask = (kcontrol->private_value >> 24) & 0xff; 1583 int mask = (kcontrol->private_value >> 24) & 0xff;
1527 int invert = (kcontrol->private_value >> 22) & 1; 1584 int invert = (kcontrol->private_value >> 22) & 1;
1528 1585
1529 spin_lock_irqsave(&chip->lock, flags); 1586 spin_lock_irqsave(&chip->lock, flags);
1530 1587
1531 ucontrol->value.integer.value[0] = (chip->image[left_reg] >> shift_left) & mask; 1588 ucontrol->value.integer.value[0] =
1532 ucontrol->value.integer.value[1] = (chip->image[right_reg] >> shift_right) & mask; 1589 (chip->image[left_reg] >> shift_left) & mask;
1590 ucontrol->value.integer.value[1] =
1591 (chip->image[right_reg] >> shift_right) & mask;
1533 1592
1534 spin_unlock_irqrestore(&chip->lock, flags); 1593 spin_unlock_irqrestore(&chip->lock, flags);
1535 1594
@@ -1556,7 +1615,7 @@ static int snd_cs4231_put_double(struct snd_kcontrol *kcontrol,
1556 int invert = (kcontrol->private_value >> 22) & 1; 1615 int invert = (kcontrol->private_value >> 22) & 1;
1557 int change; 1616 int change;
1558 unsigned short val1, val2; 1617 unsigned short val1, val2;
1559 1618
1560 val1 = ucontrol->value.integer.value[0] & mask; 1619 val1 = ucontrol->value.integer.value[0] & mask;
1561 val2 = ucontrol->value.integer.value[1] & mask; 1620 val2 = ucontrol->value.integer.value[1] & mask;
1562 if (invert) { 1621 if (invert) {
@@ -1570,7 +1629,8 @@ static int snd_cs4231_put_double(struct snd_kcontrol *kcontrol,
1570 1629
1571 val1 = (chip->image[left_reg] & ~(mask << shift_left)) | val1; 1630 val1 = (chip->image[left_reg] & ~(mask << shift_left)) | val1;
1572 val2 = (chip->image[right_reg] & ~(mask << shift_right)) | val2; 1631 val2 = (chip->image[right_reg] & ~(mask << shift_right)) | val2;
1573 change = val1 != chip->image[left_reg] || val2 != chip->image[right_reg]; 1632 change = val1 != chip->image[left_reg];
1633 change |= val2 != chip->image[right_reg];
1574 snd_cs4231_out(chip, left_reg, val1); 1634 snd_cs4231_out(chip, left_reg, val1);
1575 snd_cs4231_out(chip, right_reg, val2); 1635 snd_cs4231_out(chip, right_reg, val2);
1576 1636
@@ -1580,31 +1640,42 @@ static int snd_cs4231_put_double(struct snd_kcontrol *kcontrol,
1580} 1640}
1581 1641
1582#define CS4231_SINGLE(xname, xindex, reg, shift, mask, invert) \ 1642#define CS4231_SINGLE(xname, xindex, reg, shift, mask, invert) \
1583{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = xindex, \ 1643{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname), .index = (xindex), \
1584 .info = snd_cs4231_info_single, \ 1644 .info = snd_cs4231_info_single, \
1585 .get = snd_cs4231_get_single, .put = snd_cs4231_put_single, \ 1645 .get = snd_cs4231_get_single, .put = snd_cs4231_put_single, \
1586 .private_value = reg | (shift << 8) | (mask << 16) | (invert << 24) } 1646 .private_value = (reg) | ((shift) << 8) | ((mask) << 16) | ((invert) << 24) }
1587 1647
1588#define CS4231_DOUBLE(xname, xindex, left_reg, right_reg, shift_left, shift_right, mask, invert) \ 1648#define CS4231_DOUBLE(xname, xindex, left_reg, right_reg, shift_left, \
1589{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = xindex, \ 1649 shift_right, mask, invert) \
1590 .info = snd_cs4231_info_double, \ 1650{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = (xname), .index = (xindex), \
1591 .get = snd_cs4231_get_double, .put = snd_cs4231_put_double, \ 1651 .info = snd_cs4231_info_double, \
1592 .private_value = left_reg | (right_reg << 8) | (shift_left << 16) | (shift_right << 19) | (mask << 24) | (invert << 22) } 1652 .get = snd_cs4231_get_double, .put = snd_cs4231_put_double, \
1653 .private_value = (left_reg) | ((right_reg) << 8) | ((shift_left) << 16) | \
1654 ((shift_right) << 19) | ((mask) << 24) | ((invert) << 22) }
1593 1655
1594static struct snd_kcontrol_new snd_cs4231_controls[] __initdata = { 1656static struct snd_kcontrol_new snd_cs4231_controls[] __initdata = {
1595CS4231_DOUBLE("PCM Playback Switch", 0, CS4231_LEFT_OUTPUT, CS4231_RIGHT_OUTPUT, 7, 7, 1, 1), 1657CS4231_DOUBLE("PCM Playback Switch", 0, CS4231_LEFT_OUTPUT,
1596CS4231_DOUBLE("PCM Playback Volume", 0, CS4231_LEFT_OUTPUT, CS4231_RIGHT_OUTPUT, 0, 0, 63, 1), 1658 CS4231_RIGHT_OUTPUT, 7, 7, 1, 1),
1597CS4231_DOUBLE("Line Playback Switch", 0, CS4231_LEFT_LINE_IN, CS4231_RIGHT_LINE_IN, 7, 7, 1, 1), 1659CS4231_DOUBLE("PCM Playback Volume", 0, CS4231_LEFT_OUTPUT,
1598CS4231_DOUBLE("Line Playback Volume", 0, CS4231_LEFT_LINE_IN, CS4231_RIGHT_LINE_IN, 0, 0, 31, 1), 1660 CS4231_RIGHT_OUTPUT, 0, 0, 63, 1),
1599CS4231_DOUBLE("Aux Playback Switch", 0, CS4231_AUX1_LEFT_INPUT, CS4231_AUX1_RIGHT_INPUT, 7, 7, 1, 1), 1661CS4231_DOUBLE("Line Playback Switch", 0, CS4231_LEFT_LINE_IN,
1600CS4231_DOUBLE("Aux Playback Volume", 0, CS4231_AUX1_LEFT_INPUT, CS4231_AUX1_RIGHT_INPUT, 0, 0, 31, 1), 1662 CS4231_RIGHT_LINE_IN, 7, 7, 1, 1),
1601CS4231_DOUBLE("Aux Playback Switch", 1, CS4231_AUX2_LEFT_INPUT, CS4231_AUX2_RIGHT_INPUT, 7, 7, 1, 1), 1663CS4231_DOUBLE("Line Playback Volume", 0, CS4231_LEFT_LINE_IN,
1602CS4231_DOUBLE("Aux Playback Volume", 1, CS4231_AUX2_LEFT_INPUT, CS4231_AUX2_RIGHT_INPUT, 0, 0, 31, 1), 1664 CS4231_RIGHT_LINE_IN, 0, 0, 31, 1),
1665CS4231_DOUBLE("Aux Playback Switch", 0, CS4231_AUX1_LEFT_INPUT,
1666 CS4231_AUX1_RIGHT_INPUT, 7, 7, 1, 1),
1667CS4231_DOUBLE("Aux Playback Volume", 0, CS4231_AUX1_LEFT_INPUT,
1668 CS4231_AUX1_RIGHT_INPUT, 0, 0, 31, 1),
1669CS4231_DOUBLE("Aux Playback Switch", 1, CS4231_AUX2_LEFT_INPUT,
1670 CS4231_AUX2_RIGHT_INPUT, 7, 7, 1, 1),
1671CS4231_DOUBLE("Aux Playback Volume", 1, CS4231_AUX2_LEFT_INPUT,
1672 CS4231_AUX2_RIGHT_INPUT, 0, 0, 31, 1),
1603CS4231_SINGLE("Mono Playback Switch", 0, CS4231_MONO_CTRL, 7, 1, 1), 1673CS4231_SINGLE("Mono Playback Switch", 0, CS4231_MONO_CTRL, 7, 1, 1),
1604CS4231_SINGLE("Mono Playback Volume", 0, CS4231_MONO_CTRL, 0, 15, 1), 1674CS4231_SINGLE("Mono Playback Volume", 0, CS4231_MONO_CTRL, 0, 15, 1),
1605CS4231_SINGLE("Mono Output Playback Switch", 0, CS4231_MONO_CTRL, 6, 1, 1), 1675CS4231_SINGLE("Mono Output Playback Switch", 0, CS4231_MONO_CTRL, 6, 1, 1),
1606CS4231_SINGLE("Mono Output Playback Bypass", 0, CS4231_MONO_CTRL, 5, 1, 0), 1676CS4231_SINGLE("Mono Output Playback Bypass", 0, CS4231_MONO_CTRL, 5, 1, 0),
1607CS4231_DOUBLE("Capture Volume", 0, CS4231_LEFT_INPUT, CS4231_RIGHT_INPUT, 0, 0, 15, 0), 1677CS4231_DOUBLE("Capture Volume", 0, CS4231_LEFT_INPUT, CS4231_RIGHT_INPUT, 0, 0,
1678 15, 0),
1608{ 1679{
1609 .iface = SNDRV_CTL_ELEM_IFACE_MIXER, 1680 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1610 .name = "Capture Source", 1681 .name = "Capture Source",
@@ -1612,14 +1683,15 @@ CS4231_DOUBLE("Capture Volume", 0, CS4231_LEFT_INPUT, CS4231_RIGHT_INPUT, 0, 0,
1612 .get = snd_cs4231_get_mux, 1683 .get = snd_cs4231_get_mux,
1613 .put = snd_cs4231_put_mux, 1684 .put = snd_cs4231_put_mux,
1614}, 1685},
1615CS4231_DOUBLE("Mic Boost", 0, CS4231_LEFT_INPUT, CS4231_RIGHT_INPUT, 5, 5, 1, 0), 1686CS4231_DOUBLE("Mic Boost", 0, CS4231_LEFT_INPUT, CS4231_RIGHT_INPUT, 5, 5,
1687 1, 0),
1616CS4231_SINGLE("Loopback Capture Switch", 0, CS4231_LOOPBACK, 0, 1, 0), 1688CS4231_SINGLE("Loopback Capture Switch", 0, CS4231_LOOPBACK, 0, 1, 0),
1617CS4231_SINGLE("Loopback Capture Volume", 0, CS4231_LOOPBACK, 2, 63, 1), 1689CS4231_SINGLE("Loopback Capture Volume", 0, CS4231_LOOPBACK, 2, 63, 1),
1618/* SPARC specific uses of XCTL{0,1} general purpose outputs. */ 1690/* SPARC specific uses of XCTL{0,1} general purpose outputs. */
1619CS4231_SINGLE("Line Out Switch", 0, CS4231_PIN_CTRL, 6, 1, 1), 1691CS4231_SINGLE("Line Out Switch", 0, CS4231_PIN_CTRL, 6, 1, 1),
1620CS4231_SINGLE("Headphone Out Switch", 0, CS4231_PIN_CTRL, 7, 1, 1) 1692CS4231_SINGLE("Headphone Out Switch", 0, CS4231_PIN_CTRL, 7, 1, 1)
1621}; 1693};
1622 1694
1623static int __init snd_cs4231_mixer(struct snd_card *card) 1695static int __init snd_cs4231_mixer(struct snd_card *card)
1624{ 1696{
1625 struct snd_cs4231 *chip = card->private_data; 1697 struct snd_cs4231 *chip = card->private_data;
@@ -1720,24 +1792,24 @@ static irqreturn_t snd_cs4231_sbus_interrupt(int irq, void *dev_id)
1720 1792
1721 sbus_writel(csr, chip->port + APCCSR); 1793 sbus_writel(csr, chip->port + APCCSR);
1722 1794
1723 if ((csr & APC_PDMA_READY) && 1795 if ((csr & APC_PDMA_READY) &&
1724 (csr & APC_PLAY_INT) && 1796 (csr & APC_PLAY_INT) &&
1725 (csr & APC_XINT_PNVA) && 1797 (csr & APC_XINT_PNVA) &&
1726 !(csr & APC_XINT_EMPT)) 1798 !(csr & APC_XINT_EMPT))
1727 snd_cs4231_play_callback(chip); 1799 snd_cs4231_play_callback(chip);
1728 1800
1729 if ((csr & APC_CDMA_READY) && 1801 if ((csr & APC_CDMA_READY) &&
1730 (csr & APC_CAPT_INT) && 1802 (csr & APC_CAPT_INT) &&
1731 (csr & APC_XINT_CNVA) && 1803 (csr & APC_XINT_CNVA) &&
1732 !(csr & APC_XINT_EMPT)) 1804 !(csr & APC_XINT_EMPT))
1733 snd_cs4231_capture_callback(chip); 1805 snd_cs4231_capture_callback(chip);
1734 1806
1735 status = snd_cs4231_in(chip, CS4231_IRQ_STATUS); 1807 status = snd_cs4231_in(chip, CS4231_IRQ_STATUS);
1736 1808
1737 if (status & CS4231_TIMER_IRQ) { 1809 if (status & CS4231_TIMER_IRQ) {
1738 if (chip->timer) 1810 if (chip->timer)
1739 snd_timer_interrupt(chip->timer, chip->timer->sticks); 1811 snd_timer_interrupt(chip->timer, chip->timer->sticks);
1740 } 1812 }
1741 1813
1742 if ((status & CS4231_RECORD_IRQ) && (csr & APC_CDMA_READY)) 1814 if ((status & CS4231_RECORD_IRQ) && (csr & APC_CDMA_READY))
1743 snd_cs4231_overrange(chip); 1815 snd_cs4231_overrange(chip);
@@ -1754,26 +1826,27 @@ static irqreturn_t snd_cs4231_sbus_interrupt(int irq, void *dev_id)
1754 * SBUS DMA routines 1826 * SBUS DMA routines
1755 */ 1827 */
1756 1828
1757static int sbus_dma_request(struct cs4231_dma_control *dma_cont, dma_addr_t bus_addr, size_t len) 1829static int sbus_dma_request(struct cs4231_dma_control *dma_cont,
1830 dma_addr_t bus_addr, size_t len)
1758{ 1831{
1759 unsigned long flags; 1832 unsigned long flags;
1760 u32 test, csr; 1833 u32 test, csr;
1761 int err; 1834 int err;
1762 struct sbus_dma_info *base = &dma_cont->sbus_info; 1835 struct sbus_dma_info *base = &dma_cont->sbus_info;
1763 1836
1764 if (len >= (1 << 24)) 1837 if (len >= (1 << 24))
1765 return -EINVAL; 1838 return -EINVAL;
1766 spin_lock_irqsave(&base->lock, flags); 1839 spin_lock_irqsave(&base->lock, flags);
1767 csr = sbus_readl(base->regs + APCCSR); 1840 csr = sbus_readl(base->regs + APCCSR);
1768 err = -EINVAL; 1841 err = -EINVAL;
1769 test = APC_CDMA_READY; 1842 test = APC_CDMA_READY;
1770 if ( base->dir == APC_PLAY ) 1843 if (base->dir == APC_PLAY)
1771 test = APC_PDMA_READY; 1844 test = APC_PDMA_READY;
1772 if (!(csr & test)) 1845 if (!(csr & test))
1773 goto out; 1846 goto out;
1774 err = -EBUSY; 1847 err = -EBUSY;
1775 test = APC_XINT_CNVA; 1848 test = APC_XINT_CNVA;
1776 if ( base->dir == APC_PLAY ) 1849 if (base->dir == APC_PLAY)
1777 test = APC_XINT_PNVA; 1850 test = APC_XINT_PNVA;
1778 if (!(csr & test)) 1851 if (!(csr & test))
1779 goto out; 1852 goto out;
@@ -1796,7 +1869,7 @@ static void sbus_dma_prepare(struct cs4231_dma_control *dma_cont, int d)
1796 test = APC_GENL_INT | APC_PLAY_INT | APC_XINT_ENA | 1869 test = APC_GENL_INT | APC_PLAY_INT | APC_XINT_ENA |
1797 APC_XINT_PLAY | APC_XINT_PEMP | APC_XINT_GENL | 1870 APC_XINT_PLAY | APC_XINT_PEMP | APC_XINT_GENL |
1798 APC_XINT_PENA; 1871 APC_XINT_PENA;
1799 if ( base->dir == APC_RECORD ) 1872 if (base->dir == APC_RECORD)
1800 test = APC_GENL_INT | APC_CAPT_INT | APC_XINT_ENA | 1873 test = APC_GENL_INT | APC_CAPT_INT | APC_XINT_ENA |
1801 APC_XINT_CAPT | APC_XINT_CEMP | APC_XINT_GENL; 1874 APC_XINT_CAPT | APC_XINT_CEMP | APC_XINT_GENL;
1802 csr |= test; 1875 csr |= test;
@@ -1814,28 +1887,28 @@ static void sbus_dma_enable(struct cs4231_dma_control *dma_cont, int on)
1814 if (!on) { 1887 if (!on) {
1815 sbus_writel(0, base->regs + base->dir + APCNC); 1888 sbus_writel(0, base->regs + base->dir + APCNC);
1816 sbus_writel(0, base->regs + base->dir + APCNVA); 1889 sbus_writel(0, base->regs + base->dir + APCNVA);
1817 if ( base->dir == APC_PLAY ) { 1890 if (base->dir == APC_PLAY) {
1818 sbus_writel(0, base->regs + base->dir + APCC); 1891 sbus_writel(0, base->regs + base->dir + APCC);
1819 sbus_writel(0, base->regs + base->dir + APCVA); 1892 sbus_writel(0, base->regs + base->dir + APCVA);
1820 } 1893 }
1821 1894
1822 udelay(1200); 1895 udelay(1200);
1823 } 1896 }
1824 csr = sbus_readl(base->regs + APCCSR); 1897 csr = sbus_readl(base->regs + APCCSR);
1825 shift = 0; 1898 shift = 0;
1826 if ( base->dir == APC_PLAY ) 1899 if (base->dir == APC_PLAY)
1827 shift = 1; 1900 shift = 1;
1828 if (on) 1901 if (on)
1829 csr &= ~(APC_CPAUSE << shift); 1902 csr &= ~(APC_CPAUSE << shift);
1830 else 1903 else
1831 csr |= (APC_CPAUSE << shift); 1904 csr |= (APC_CPAUSE << shift);
1832 sbus_writel(csr, base->regs + APCCSR); 1905 sbus_writel(csr, base->regs + APCCSR);
1833 if (on) 1906 if (on)
1834 csr |= (APC_CDMA_READY << shift); 1907 csr |= (APC_CDMA_READY << shift);
1835 else 1908 else
1836 csr &= ~(APC_CDMA_READY << shift); 1909 csr &= ~(APC_CDMA_READY << shift);
1837 sbus_writel(csr, base->regs + APCCSR); 1910 sbus_writel(csr, base->regs + APCCSR);
1838 1911
1839 spin_unlock_irqrestore(&base->lock, flags); 1912 spin_unlock_irqrestore(&base->lock, flags);
1840} 1913}
1841 1914
@@ -1843,14 +1916,14 @@ static unsigned int sbus_dma_addr(struct cs4231_dma_control *dma_cont)
1843{ 1916{
1844 struct sbus_dma_info *base = &dma_cont->sbus_info; 1917 struct sbus_dma_info *base = &dma_cont->sbus_info;
1845 1918
1846 return sbus_readl(base->regs + base->dir + APCVA); 1919 return sbus_readl(base->regs + base->dir + APCVA);
1847} 1920}
1848 1921
1849static void sbus_dma_preallocate(struct snd_cs4231 *chip, struct snd_pcm *pcm) 1922static void sbus_dma_preallocate(struct snd_cs4231 *chip, struct snd_pcm *pcm)
1850{ 1923{
1851 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_SBUS, 1924 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_SBUS,
1852 snd_dma_sbus_data(chip->dev_u.sdev), 1925 snd_dma_sbus_data(chip->dev_u.sdev),
1853 64*1024, 128*1024); 1926 64 * 1024, 128 * 1024);
1854} 1927}
1855 1928
1856/* 1929/*
@@ -1972,14 +2045,16 @@ static int __init cs4231_sbus_attach(struct sbus_dev *sdev)
1972 2045
1973#ifdef EBUS_SUPPORT 2046#ifdef EBUS_SUPPORT
1974 2047
1975static void snd_cs4231_ebus_play_callback(struct ebus_dma_info *p, int event, void *cookie) 2048static void snd_cs4231_ebus_play_callback(struct ebus_dma_info *p, int event,
2049 void *cookie)
1976{ 2050{
1977 struct snd_cs4231 *chip = cookie; 2051 struct snd_cs4231 *chip = cookie;
1978 2052
1979 snd_cs4231_play_callback(chip); 2053 snd_cs4231_play_callback(chip);
1980} 2054}
1981 2055
1982static void snd_cs4231_ebus_capture_callback(struct ebus_dma_info *p, int event, void *cookie) 2056static void snd_cs4231_ebus_capture_callback(struct ebus_dma_info *p,
2057 int event, void *cookie)
1983{ 2058{
1984 struct snd_cs4231 *chip = cookie; 2059 struct snd_cs4231 *chip = cookie;
1985 2060
@@ -1990,7 +2065,8 @@ static void snd_cs4231_ebus_capture_callback(struct ebus_dma_info *p, int event,
1990 * EBUS DMA wrappers 2065 * EBUS DMA wrappers
1991 */ 2066 */
1992 2067
1993static int _ebus_dma_request(struct cs4231_dma_control *dma_cont, dma_addr_t bus_addr, size_t len) 2068static int _ebus_dma_request(struct cs4231_dma_control *dma_cont,
2069 dma_addr_t bus_addr, size_t len)
1994{ 2070{
1995 return ebus_dma_request(&dma_cont->ebus_info, bus_addr, len); 2071 return ebus_dma_request(&dma_cont->ebus_info, bus_addr, len);
1996} 2072}
@@ -2091,7 +2167,8 @@ static int __init snd_cs4231_ebus_create(struct snd_card *card,
2091 chip->port = ioremap(edev->resource[0].start, 0x10); 2167 chip->port = ioremap(edev->resource[0].start, 0x10);
2092 chip->p_dma.ebus_info.regs = ioremap(edev->resource[1].start, 0x10); 2168 chip->p_dma.ebus_info.regs = ioremap(edev->resource[1].start, 0x10);
2093 chip->c_dma.ebus_info.regs = ioremap(edev->resource[2].start, 0x10); 2169 chip->c_dma.ebus_info.regs = ioremap(edev->resource[2].start, 0x10);
2094 if (!chip->port || !chip->p_dma.ebus_info.regs || !chip->c_dma.ebus_info.regs) { 2170 if (!chip->port || !chip->p_dma.ebus_info.regs ||
2171 !chip->c_dma.ebus_info.regs) {
2095 snd_cs4231_ebus_free(chip); 2172 snd_cs4231_ebus_free(chip);
2096 snd_printdd("cs4231-%d: Unable to map chip registers.\n", dev); 2173 snd_printdd("cs4231-%d: Unable to map chip registers.\n", dev);
2097 return -EIO; 2174 return -EIO;
@@ -2099,18 +2176,21 @@ static int __init snd_cs4231_ebus_create(struct snd_card *card,
2099 2176
2100 if (ebus_dma_register(&chip->c_dma.ebus_info)) { 2177 if (ebus_dma_register(&chip->c_dma.ebus_info)) {
2101 snd_cs4231_ebus_free(chip); 2178 snd_cs4231_ebus_free(chip);
2102 snd_printdd("cs4231-%d: Unable to register EBUS capture DMA\n", dev); 2179 snd_printdd("cs4231-%d: Unable to register EBUS capture DMA\n",
2180 dev);
2103 return -EBUSY; 2181 return -EBUSY;
2104 } 2182 }
2105 if (ebus_dma_irq_enable(&chip->c_dma.ebus_info, 1)) { 2183 if (ebus_dma_irq_enable(&chip->c_dma.ebus_info, 1)) {
2106 snd_cs4231_ebus_free(chip); 2184 snd_cs4231_ebus_free(chip);
2107 snd_printdd("cs4231-%d: Unable to enable EBUS capture IRQ\n", dev); 2185 snd_printdd("cs4231-%d: Unable to enable EBUS capture IRQ\n",
2186 dev);
2108 return -EBUSY; 2187 return -EBUSY;
2109 } 2188 }
2110 2189
2111 if (ebus_dma_register(&chip->p_dma.ebus_info)) { 2190 if (ebus_dma_register(&chip->p_dma.ebus_info)) {
2112 snd_cs4231_ebus_free(chip); 2191 snd_cs4231_ebus_free(chip);
2113 snd_printdd("cs4231-%d: Unable to register EBUS play DMA\n", dev); 2192 snd_printdd("cs4231-%d: Unable to register EBUS play DMA\n",
2193 dev);
2114 return -EBUSY; 2194 return -EBUSY;
2115 } 2195 }
2116 if (ebus_dma_irq_enable(&chip->p_dma.ebus_info, 1)) { 2196 if (ebus_dma_irq_enable(&chip->p_dma.ebus_info, 1)) {