All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 0/4] ASoC updates
@ 2008-09-24 11:59 Mark Brown
  2008-09-24 12:43 ` Takashi Iwai
  0 siblings, 1 reply; 25+ messages in thread
From: Mark Brown @ 2008-09-24 11:59 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel

This series fixes a couple of bugs (neither of which affect 2.6.27) and
introduces a new API call for marking disconnected pins, mostly as a
placeholder for future development so machine drivers can start using it
now and then benefit when a more substantial implementation follows.

The following changes since commit 3090258fed179996ac4daecb482bad28d84cb054:
  Jean Delvare (1):
        ALSA: ASoC: Convert tlv320aic3x to a new-style i2c driver (v2)

are available in the git repository at:

  git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

Mark Brown (4):
      ASoC: Fix inverted input PGA mute bits in WM8903
      ASoC: Fix build of GTA01 audio driver
      ASoC: Allow machine drivers to mark pins as not connected
      ASoC: Use snd_soc_dapm_nc_pin() in GTA01 audio driver

 include/sound/soc-dapm.h           |    1 +
 sound/soc/codecs/wm8903.c          |    4 ++--
 sound/soc/s3c24xx/neo1973_wm8753.c |   17 ++++++++---------
 sound/soc/soc-dapm.c               |   20 ++++++++++++++++++++
 4 files changed, 31 insertions(+), 11 deletions(-)

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 0/4] ASoC updates
  2008-09-24 11:59 Mark Brown
@ 2008-09-24 12:43 ` Takashi Iwai
  0 siblings, 0 replies; 25+ messages in thread
From: Takashi Iwai @ 2008-09-24 12:43 UTC (permalink / raw)
  To: Mark Brown; +Cc: alsa-devel

At Wed, 24 Sep 2008 12:59:07 +0100,
Mark Brown wrote:
> 
> This series fixes a couple of bugs (neither of which affect 2.6.27) and
> introduces a new API call for marking disconnected pins, mostly as a
> placeholder for future development so machine drivers can start using it
> now and then benefit when a more substantial implementation follows.
> 
> The following changes since commit 3090258fed179996ac4daecb482bad28d84cb054:
>   Jean Delvare (1):
>         ALSA: ASoC: Convert tlv320aic3x to a new-style i2c driver (v2)
> 
> are available in the git repository at:
> 
>   git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

Applied.  Thanks.


Takashi

^ permalink raw reply	[flat|nested] 25+ messages in thread

* [PATCH 0/4] ASoC updates
@ 2008-11-05 18:52 Mark Brown
  0 siblings, 0 replies; 25+ messages in thread
From: Mark Brown @ 2008-11-05 18:52 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel

The following changes since commit 0ee4663617fb0f78cec4cc6558a096ccbd8c3ffc:
  Takashi Iwai (1):
        ALSA: ASoC - Remove unnecessary inclusion of linux/version.h

are available in the git repository at:

  git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

David Anders (1):
      ASoC: Add new parameter to s3c24xx_pcm_enqueue

Marek Vasut (1):
      ASoC: Add Palm/PXA27x unified ASoC audio driver

Mark Brown (1):
      ASoC: Remove core version number

Troy Kisky (1):
      ASoC: TLV320AIC23B Support more sample rates

 arch/arm/mach-pxa/include/mach/palmasoc.h |   13 ++
 include/sound/soc.h                       |    2 -
 sound/soc/codecs/tlv320aic23.c            |  227 +++++++++++++++++++-----
 sound/soc/pxa/Kconfig                     |    9 +
 sound/soc/pxa/Makefile                    |    2 +
 sound/soc/pxa/palm27x.c                   |  269 +++++++++++++++++++++++++++++
 sound/soc/s3c24xx/s3c24xx-pcm.c           |   12 +-
 sound/soc/soc-core.c                      |    1 -
 8 files changed, 483 insertions(+), 52 deletions(-)
 create mode 100644 arch/arm/mach-pxa/include/mach/palmasoc.h
 create mode 100644 sound/soc/pxa/palm27x.c

^ permalink raw reply	[flat|nested] 25+ messages in thread

* [PATCH 0/4] ASoC updates
@ 2008-11-06 11:38 Mark Brown
  2008-11-06 11:57 ` Takashi Iwai
  0 siblings, 1 reply; 25+ messages in thread
From: Mark Brown @ 2008-11-06 11:38 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel

The following changes since commit 0ee4663617fb0f78cec4cc6558a096ccbd8c3ffc:
  Takashi Iwai (1):
        ALSA: ASoC - Remove unnecessary inclusion of linux/version.h

are available in the git repository at:

  git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

This series drops the TLV320AIC23 patch for now and makes the Palm
driver non-modular for the time being due to the platform data dodge
being used.

David Anders (1):
      ASoC: Add new parameter to s3c24xx_pcm_enqueue

Grazvydas Ignotas (1):
      ALSA: ASoC: TWL4030 codec - fix 256*Fs clock

Marek Vasut (1):
      ASoC: Add Palm/PXA27x unified ASoC audio driver

Mark Brown (1):
      ASoC: Remove core version number

 arch/arm/mach-pxa/include/mach/palmasoc.h |   13 ++
 include/sound/soc.h                       |    2 -
 sound/soc/codecs/twl4030.c                |    4 +-
 sound/soc/pxa/Kconfig                     |    9 +
 sound/soc/pxa/Makefile                    |    2 +
 sound/soc/pxa/palm27x.c                   |  269 +++++++++++++++++++++++++++++
 sound/soc/s3c24xx/s3c24xx-pcm.c           |   12 +-
 sound/soc/soc-core.c                      |    1 -
 8 files changed, 303 insertions(+), 9 deletions(-)
 create mode 100644 arch/arm/mach-pxa/include/mach/palmasoc.h
 create mode 100644 sound/soc/pxa/palm27x.c

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 0/4] ASoC updates
  2008-11-06 11:38 Mark Brown
@ 2008-11-06 11:57 ` Takashi Iwai
  0 siblings, 0 replies; 25+ messages in thread
From: Takashi Iwai @ 2008-11-06 11:57 UTC (permalink / raw)
  To: Mark Brown; +Cc: alsa-devel

At Thu, 6 Nov 2008 11:38:32 +0000,
Mark Brown wrote:
> 
> The following changes since commit 0ee4663617fb0f78cec4cc6558a096ccbd8c3ffc:
>   Takashi Iwai (1):
>         ALSA: ASoC - Remove unnecessary inclusion of linux/version.h
> 
> are available in the git repository at:
> 
>   git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

Thanks, pulled now.


Takashi

> 
> This series drops the TLV320AIC23 patch for now and makes the Palm
> driver non-modular for the time being due to the platform data dodge
> being used.
> 
> David Anders (1):
>       ASoC: Add new parameter to s3c24xx_pcm_enqueue
> 
> Grazvydas Ignotas (1):
>       ALSA: ASoC: TWL4030 codec - fix 256*Fs clock
> 
> Marek Vasut (1):
>       ASoC: Add Palm/PXA27x unified ASoC audio driver
> 
> Mark Brown (1):
>       ASoC: Remove core version number
> 
>  arch/arm/mach-pxa/include/mach/palmasoc.h |   13 ++
>  include/sound/soc.h                       |    2 -
>  sound/soc/codecs/twl4030.c                |    4 +-
>  sound/soc/pxa/Kconfig                     |    9 +
>  sound/soc/pxa/Makefile                    |    2 +
>  sound/soc/pxa/palm27x.c                   |  269 +++++++++++++++++++++++++++++
>  sound/soc/s3c24xx/s3c24xx-pcm.c           |   12 +-
>  sound/soc/soc-core.c                      |    1 -
>  8 files changed, 303 insertions(+), 9 deletions(-)
>  create mode 100644 arch/arm/mach-pxa/include/mach/palmasoc.h
>  create mode 100644 sound/soc/pxa/palm27x.c
> 

^ permalink raw reply	[flat|nested] 25+ messages in thread

* [PATCH 0/4] ASoC updates
@ 2008-11-12 11:55 Mark Brown
  2008-11-12 11:55 ` [PATCH 1/4] ASoC: TLV320AIC23B Support more sample rates Mark Brown
  2008-11-12 12:31 ` [PATCH 0/4] ASoC updates Takashi Iwai
  0 siblings, 2 replies; 25+ messages in thread
From: Mark Brown @ 2008-11-12 11:55 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel

The following changes since commit e18c94d20224f3df584531a48d944d8cccfda46d:
  Grazvydas Ignotas (1):
        ALSA: ASoC: TWL4030 codec - fix 256*Fs clock

are available in the git repository at:

  git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

Christian Pellegrin (1):
      ASoC: s3c24xx 8 bit sound fix

Hugo Villeneuve (1):
      ASoC: Add Right-Justified mode and Codec clock master to davinci-i2s

Naresh Medisetty (1):
      ASoC: DaVinci: Audio: Fix swapping of channels at start of stereo playback

Troy Kisky (1):
      ASoC: TLV320AIC23B Support more sample rates

 sound/soc/codecs/tlv320aic23.c  |  222 +++++++++++++++++++++++++++++++--------
 sound/soc/davinci/davinci-i2s.c |   89 ++++++++++++++--
 sound/soc/s3c24xx/s3c24xx-i2s.c |    7 ++
 3 files changed, 263 insertions(+), 55 deletions(-)

^ permalink raw reply	[flat|nested] 25+ messages in thread

* [PATCH 1/4] ASoC: TLV320AIC23B Support more sample rates
  2008-11-12 11:55 [PATCH 0/4] ASoC updates Mark Brown
@ 2008-11-12 11:55 ` Mark Brown
  2008-11-12 11:55   ` [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix Mark Brown
  2008-11-12 12:31 ` [PATCH 0/4] ASoC updates Takashi Iwai
  1 sibling, 1 reply; 25+ messages in thread
From: Mark Brown @ 2008-11-12 11:55 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel, Mark Brown, Troy Kisky

From: Troy Kisky <troy.kisky@boundarydevices.com>

Add support for more sample rates, different crystals
and split playback/capture rates.

Signed-off-by: Troy Kisky <troy.kisky@boundarydevices.com>
Acked-by: Arun KS <arunks@mistralsolutions.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
---
 sound/soc/codecs/tlv320aic23.c |  222 ++++++++++++++++++++++++++++++++--------
 1 files changed, 177 insertions(+), 45 deletions(-)

diff --git a/sound/soc/codecs/tlv320aic23.c b/sound/soc/codecs/tlv320aic23.c
index 44308da..a95b538 100644
--- a/sound/soc/codecs/tlv320aic23.c
+++ b/sound/soc/codecs/tlv320aic23.c
@@ -37,12 +37,6 @@
 
 #define AIC23_VERSION "0.1"
 
-struct tlv320aic23_srate_reg_info {
-	u32 sample_rate;
-	u8 control;		/* SR3, SR2, SR1, SR0 and BOSR */
-	u8 divider;		/* if 0 CLKIN = MCLK, if 1 CLKIN = MCLK/2 */
-};
-
 /*
  * AIC23 register cache
  */
@@ -261,20 +255,151 @@ static const struct snd_soc_dapm_route intercon[] = {
 
 };
 
-/* tlv320aic23 related */
-static const struct tlv320aic23_srate_reg_info srate_reg_info[] = {
-	{4000, 0x06, 1},	/*  4000 */
-	{8000, 0x06, 0},	/*  8000 */
-	{16000, 0x0C, 1},	/* 16000 */
-	{22050, 0x11, 1},	/* 22050 */
-	{24000, 0x00, 1},	/* 24000 */
-	{32000, 0x0C, 0},	/* 32000 */
-	{44100, 0x11, 0},	/* 44100 */
-	{48000, 0x00, 0},	/* 48000 */
-	{88200, 0x1F, 0},	/* 88200 */
-	{96000, 0x0E, 0},	/* 96000 */
+/* AIC23 driver data */
+struct aic23 {
+	struct snd_soc_codec codec;
+	int mclk;
+	int requested_adc;
+	int requested_dac;
+};
+
+/*
+ * Common Crystals used
+ * 11.2896 Mhz /128 = *88.2k  /192 = 58.8k
+ * 12.0000 Mhz /125 = *96k    /136 = 88.235K
+ * 12.2880 Mhz /128 = *96k    /192 = 64k
+ * 16.9344 Mhz /128 = 132.3k /192 = *88.2k
+ * 18.4320 Mhz /128 = 144k   /192 = *96k
+ */
+
+/*
+ * Normal BOSR 0-256/2 = 128, 1-384/2 = 192
+ * USB BOSR 0-250/2 = 125, 1-272/2 = 136
+ */
+static const int bosr_usb_divisor_table[] = {
+	128, 125, 192, 136
+};
+#define LOWER_GROUP ((1<<0) | (1<<1) | (1<<2) | (1<<3) | (1<<6) | (1<<7))
+#define UPPER_GROUP ((1<<8) | (1<<9) | (1<<10) | (1<<11)        | (1<<15))
+static const unsigned short sr_valid_mask[] = {
+	LOWER_GROUP|UPPER_GROUP,	/* Normal, bosr - 0*/
+	LOWER_GROUP|UPPER_GROUP,	/* Normal, bosr - 1*/
+	LOWER_GROUP,			/* Usb, bosr - 0*/
+	UPPER_GROUP,			/* Usb, bosr - 1*/
+};
+/*
+ * Every divisor is a factor of 11*12
+ */
+#define SR_MULT (11*12)
+#define A(x) (x) ? (SR_MULT/x) : 0
+static const unsigned char sr_adc_mult_table[] = {
+	A(2), A(2), A(12), A(12),  A(0), A(0), A(3), A(1),
+	A(2), A(2), A(11), A(11),  A(0), A(0), A(0), A(1)
+};
+static const unsigned char sr_dac_mult_table[] = {
+	A(2), A(12), A(2), A(12),  A(0), A(0), A(3), A(1),
+	A(2), A(11), A(2), A(11),  A(0), A(0), A(0), A(1)
 };
 
+static unsigned get_score(int adc, int adc_l, int adc_h, int need_adc,
+		int dac, int dac_l, int dac_h, int need_dac)
+{
+	if ((adc >= adc_l) && (adc <= adc_h) &&
+			(dac >= dac_l) && (dac <= dac_h)) {
+		int diff_adc = need_adc - adc;
+		int diff_dac = need_dac - dac;
+		return abs(diff_adc) + abs(diff_dac);
+	}
+	return UINT_MAX;
+}
+
+static int find_rate(int mclk, u32 need_adc, u32 need_dac)
+{
+	int i, j;
+	int best_i = -1;
+	int best_j = -1;
+	int best_div = 0;
+	unsigned best_score = UINT_MAX;
+	int adc_l, adc_h, dac_l, dac_h;
+
+	need_adc *= SR_MULT;
+	need_dac *= SR_MULT;
+	/*
+	 * rates given are +/- 1/32
+	 */
+	adc_l = need_adc - (need_adc >> 5);
+	adc_h = need_adc + (need_adc >> 5);
+	dac_l = need_dac - (need_dac >> 5);
+	dac_h = need_dac + (need_dac >> 5);
+	for (i = 0; i < 4; i++) {
+		int base = mclk / bosr_usb_divisor_table[i];
+		int mask = sr_valid_mask[i];
+		for (j = 0; j < 16; j++, mask >>= 1) {
+			int adc;
+			int dac;
+			int score;
+			if ((mask & 1) == 0)
+				continue;
+			adc = base * sr_adc_mult_table[j];
+			dac = base * sr_dac_mult_table[j];
+			score = get_score(adc, adc_l, adc_h, need_adc,
+					dac, dac_l, dac_h, need_dac);
+			if (best_score > score) {
+				best_score = score;
+				best_i = i;
+				best_j = j;
+				best_div = 0;
+			}
+			score = get_score((adc >> 1), adc_l, adc_h, need_adc,
+					(dac >> 1), dac_l, dac_h, need_dac);
+			/* prefer to have a /2 */
+			if ((score != UINT_MAX) && (best_score >= score)) {
+				best_score = score;
+				best_i = i;
+				best_j = j;
+				best_div = 1;
+			}
+		}
+	}
+	return (best_j << 2) | best_i | (best_div << TLV320AIC23_CLKIN_SHIFT);
+}
+
+static void get_current_sample_rates(struct snd_soc_codec *codec, int mclk,
+		u32 *sample_rate_adc, u32 *sample_rate_dac)
+{
+	int src = tlv320aic23_read_reg_cache(codec, TLV320AIC23_SRATE);
+	int sr = (src >> 2) & 0x0f;
+	int val = (mclk / bosr_usb_divisor_table[src & 3]);
+	int adc = (val * sr_adc_mult_table[sr]) / SR_MULT;
+	int dac = (val * sr_dac_mult_table[sr]) / SR_MULT;
+	if (src & TLV320AIC23_CLKIN_HALF) {
+		adc >>= 1;
+		dac >>= 1;
+	}
+	*sample_rate_adc = adc;
+	*sample_rate_dac = dac;
+}
+
+static int set_sample_rate_control(struct snd_soc_codec *codec, int mclk,
+		u32 sample_rate_adc, u32 sample_rate_dac)
+{
+	/* Search for the right sample rate */
+	int data = find_rate(mclk, sample_rate_adc, sample_rate_dac);
+	if (data < 0) {
+		printk(KERN_ERR "%s:Invalid rate %u,%u requested\n",
+				__func__, sample_rate_adc, sample_rate_dac);
+		return -EINVAL;
+	}
+	tlv320aic23_write(codec, TLV320AIC23_SRATE, data);
+	if (1) {
+		int adc, dac;
+		get_current_sample_rates(codec, mclk, &adc, &dac);
+		printk(KERN_DEBUG "actual samplerate = %u,%u reg=%x\n",
+			adc, dac, data);
+	}
+	return 0;
+}
+
 static int tlv320aic23_add_widgets(struct snd_soc_codec *codec)
 {
 	snd_soc_dapm_new_controls(codec, tlv320aic23_dapm_widgets,
@@ -293,27 +418,30 @@ static int tlv320aic23_hw_params(struct snd_pcm_substream *substream,
 	struct snd_soc_pcm_runtime *rtd = substream->private_data;
 	struct snd_soc_device *socdev = rtd->socdev;
 	struct snd_soc_codec *codec = socdev->codec;
-	u16 iface_reg, data;
-	u8 count = 0;
+	u16 iface_reg;
+	int ret;
+	struct aic23 *aic23 = container_of(codec, struct aic23, codec);
+	u32 sample_rate_adc = aic23->requested_adc;
+	u32 sample_rate_dac = aic23->requested_dac;
+	u32 sample_rate = params_rate(params);
+
+	if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
+		aic23->requested_dac = sample_rate_dac = sample_rate;
+		if (!sample_rate_adc)
+			sample_rate_adc = sample_rate;
+	} else {
+		aic23->requested_adc = sample_rate_adc = sample_rate;
+		if (!sample_rate_dac)
+			sample_rate_dac = sample_rate;
+	}
+	ret = set_sample_rate_control(codec, aic23->mclk, sample_rate_adc,
+			sample_rate_dac);
+	if (ret < 0)
+		return ret;
 
 	iface_reg =
 	    tlv320aic23_read_reg_cache(codec,
 				       TLV320AIC23_DIGT_FMT) & ~(0x03 << 2);
-
-	/* Search for the right sample rate */
-	/* Verify what happens if the rate is not supported
-	 * now it goes to 96Khz */
-	while ((srate_reg_info[count].sample_rate != params_rate(params)) &&
-	       (count < ARRAY_SIZE(srate_reg_info))) {
-		count++;
-	}
-
-	data =  (srate_reg_info[count].divider << TLV320AIC23_CLKIN_SHIFT) |
-		(srate_reg_info[count]. control << TLV320AIC23_BOSR_SHIFT) |
-		TLV320AIC23_USB_CLK_ON;
-
-	tlv320aic23_write(codec, TLV320AIC23_SRATE, data);
-
 	switch (params_format(params)) {
 	case SNDRV_PCM_FORMAT_S16_LE:
 		break;
@@ -349,12 +477,17 @@ static void tlv320aic23_shutdown(struct snd_pcm_substream *substream)
 	struct snd_soc_pcm_runtime *rtd = substream->private_data;
 	struct snd_soc_device *socdev = rtd->socdev;
 	struct snd_soc_codec *codec = socdev->codec;
+	struct aic23 *aic23 = container_of(codec, struct aic23, codec);
 
 	/* deactivate */
 	if (!codec->active) {
 		udelay(50);
 		tlv320aic23_write(codec, TLV320AIC23_ACTIVE, 0x0);
 	}
+	if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
+		aic23->requested_dac = 0;
+	else
+		aic23->requested_adc = 0;
 }
 
 static int tlv320aic23_mute(struct snd_soc_dai *dai, int mute)
@@ -422,12 +555,9 @@ static int tlv320aic23_set_dai_sysclk(struct snd_soc_dai *codec_dai,
 				      int clk_id, unsigned int freq, int dir)
 {
 	struct snd_soc_codec *codec = codec_dai->codec;
-
-	switch (freq) {
-	case 12000000:
-		return 0;
-	}
-	return -EINVAL;
+	struct aic23 *aic23 = container_of(codec, struct aic23, codec);
+	aic23->mclk = freq;
+	return 0;
 }
 
 static int tlv320aic23_set_bias_level(struct snd_soc_codec *codec,
@@ -659,14 +789,15 @@ static int tlv320aic23_probe(struct platform_device *pdev)
 {
 	struct snd_soc_device *socdev = platform_get_drvdata(pdev);
 	struct snd_soc_codec *codec;
+	struct aic23 *aic23;
 	int ret = 0;
 
 	printk(KERN_INFO "AIC23 Audio Codec %s\n", AIC23_VERSION);
 
-	codec = kzalloc(sizeof(struct snd_soc_codec), GFP_KERNEL);
-	if (codec == NULL)
+	aic23 = kzalloc(sizeof(struct aic23), GFP_KERNEL);
+	if (aic23 == NULL)
 		return -ENOMEM;
-
+	codec = &aic23->codec;
 	socdev->codec = codec;
 	mutex_init(&codec->mutex);
 	INIT_LIST_HEAD(&codec->dapm_widgets);
@@ -687,6 +818,7 @@ static int tlv320aic23_remove(struct platform_device *pdev)
 {
 	struct snd_soc_device *socdev = platform_get_drvdata(pdev);
 	struct snd_soc_codec *codec = socdev->codec;
+	struct aic23 *aic23 = container_of(codec, struct aic23, codec);
 
 	if (codec->control_data)
 		tlv320aic23_set_bias_level(codec, SND_SOC_BIAS_OFF);
@@ -697,7 +829,7 @@ static int tlv320aic23_remove(struct platform_device *pdev)
 	i2c_del_driver(&tlv320aic23_i2c_driver);
 #endif
 	kfree(codec->reg_cache);
-	kfree(codec);
+	kfree(aic23);
 
 	return 0;
 }
-- 
1.5.6.5

^ permalink raw reply related	[flat|nested] 25+ messages in thread

* [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix
  2008-11-12 11:55 ` [PATCH 1/4] ASoC: TLV320AIC23B Support more sample rates Mark Brown
@ 2008-11-12 11:55   ` Mark Brown
  2008-11-12 11:55     ` [PATCH 3/4] ASoC: Add Right-Justified mode and Codec clock master to davinci-i2s Mark Brown
                       ` (2 more replies)
  0 siblings, 3 replies; 25+ messages in thread
From: Mark Brown @ 2008-11-12 11:55 UTC (permalink / raw)
  To: Takashi Iwai
  Cc: alsa-devel, Mark Brown, Christian Pellegrin, Christian Pellegrin

From: Christian Pellegrin <chripell@gmail.com>

fixes playing/recording of 8 bit audio files.

Generated on  20081108  against v2.6.27

Signed-off-by: Christian Pellegrin <chripell@fsfe.org>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
---
 sound/soc/s3c24xx/s3c24xx-i2s.c |    7 +++++++
 1 files changed, 7 insertions(+), 0 deletions(-)

diff --git a/sound/soc/s3c24xx/s3c24xx-i2s.c b/sound/soc/s3c24xx/s3c24xx-i2s.c
index ba4476b..c18977b 100644
--- a/sound/soc/s3c24xx/s3c24xx-i2s.c
+++ b/sound/soc/s3c24xx/s3c24xx-i2s.c
@@ -261,10 +261,17 @@ static int s3c24xx_i2s_hw_params(struct snd_pcm_substream *substream,
 
 	switch (params_format(params)) {
 	case SNDRV_PCM_FORMAT_S8:
+		iismod &= ~S3C2410_IISMOD_16BIT;
+		((struct s3c24xx_pcm_dma_params *)
+		  rtd->dai->cpu_dai->dma_data)->dma_size = 1;
 		break;
 	case SNDRV_PCM_FORMAT_S16_LE:
 		iismod |= S3C2410_IISMOD_16BIT;
+		((struct s3c24xx_pcm_dma_params *)
+		  rtd->dai->cpu_dai->dma_data)->dma_size = 2;
 		break;
+	default:
+		return -EINVAL;
 	}
 
 	writel(iismod, s3c24xx_i2s.regs + S3C2410_IISMOD);
-- 
1.5.6.5

^ permalink raw reply related	[flat|nested] 25+ messages in thread

* [PATCH 3/4] ASoC: Add Right-Justified mode and Codec clock master to davinci-i2s
  2008-11-12 11:55   ` [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix Mark Brown
@ 2008-11-12 11:55     ` Mark Brown
  2008-11-12 11:55       ` [PATCH 4/4] ASoC: DaVinci: Audio: Fix swapping of channels at start of stereo playback Mark Brown
  2008-11-12 12:33     ` [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix Takashi Iwai
  2008-11-12 14:19     ` Ben Dooks
  2 siblings, 1 reply; 25+ messages in thread
From: Mark Brown @ 2008-11-12 11:55 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel, Hugo Villeneuve, Mark Brown

From: Hugo Villeneuve <hugo.villeneuve@lyrtech.com>

The TI DVEVM board uses the SND_SOC_DAIFMT_CBM_CFM & I2S formats, but the
Lyrtech SFFSDR board uses the SND_SOC_DAIFMT_CBM_CFS & RIGHT-JUSTIFIED formats.

Signed-off-by: Hugo Villeneuve <hugo.villeneuve@lyrtech.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
---
 sound/soc/davinci/davinci-i2s.c |   40 ++++++++++++++++++++++++++++++++------
 1 files changed, 33 insertions(+), 7 deletions(-)

diff --git a/sound/soc/davinci/davinci-i2s.c b/sound/soc/davinci/davinci-i2s.c
index abb5fed..d814ec8 100644
--- a/sound/soc/davinci/davinci-i2s.c
+++ b/sound/soc/davinci/davinci-i2s.c
@@ -59,6 +59,7 @@
 #define DAVINCI_MCBSP_PCR_CLKXP		(1 << 1)
 #define DAVINCI_MCBSP_PCR_FSRP		(1 << 2)
 #define DAVINCI_MCBSP_PCR_FSXP		(1 << 3)
+#define DAVINCI_MCBSP_PCR_SCLKME	(1 << 7)
 #define DAVINCI_MCBSP_PCR_CLKRM		(1 << 8)
 #define DAVINCI_MCBSP_PCR_CLKXM		(1 << 9)
 #define DAVINCI_MCBSP_PCR_FSRM		(1 << 10)
@@ -171,6 +172,16 @@ static int davinci_i2s_set_dai_fmt(struct snd_soc_dai *cpu_dai,
 		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_SRGR_REG,
 					DAVINCI_MCBSP_SRGR_FSGM);
 		break;
+	case SND_SOC_DAIFMT_CBM_CFS:
+		/* McBSP CLKR pin is the input for the Sample Rate Generator.
+		 * McBSP FSR and FSX are driven by the Sample Rate Generator. */
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_PCR_REG,
+					DAVINCI_MCBSP_PCR_SCLKME |
+					DAVINCI_MCBSP_PCR_FSXM |
+					DAVINCI_MCBSP_PCR_FSRM);
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_SRGR_REG,
+					DAVINCI_MCBSP_SRGR_FSGM);
+		break;
 	case SND_SOC_DAIFMT_CBM_CFM:
 		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_PCR_REG, 0);
 		break;
@@ -205,6 +216,28 @@ static int davinci_i2s_set_dai_fmt(struct snd_soc_dai *cpu_dai,
 		return -EINVAL;
 	}
 
+	switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) {
+	case SND_SOC_DAIFMT_RIGHT_J:
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_RCR_REG,
+					DAVINCI_MCBSP_RCR_RFRLEN1(1) |
+					DAVINCI_MCBSP_RCR_RDATDLY(0));
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_XCR_REG,
+					DAVINCI_MCBSP_XCR_XFRLEN1(1) |
+					DAVINCI_MCBSP_XCR_XDATDLY(0) |
+					DAVINCI_MCBSP_XCR_XFIG);
+		break;
+	case SND_SOC_DAIFMT_I2S:
+	default:
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_RCR_REG,
+					DAVINCI_MCBSP_RCR_RFRLEN1(1) |
+					DAVINCI_MCBSP_RCR_RDATDLY(1));
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_XCR_REG,
+					DAVINCI_MCBSP_XCR_XFRLEN1(1) |
+					DAVINCI_MCBSP_XCR_XDATDLY(1) |
+					DAVINCI_MCBSP_XCR_XFIG);
+		break;
+	}
+
 	return 0;
 }
 
@@ -223,13 +256,6 @@ static int davinci_i2s_hw_params(struct snd_pcm_substream *substream,
 				DAVINCI_MCBSP_SPCR_RINTM(3) |
 				DAVINCI_MCBSP_SPCR_XINTM(3) |
 				DAVINCI_MCBSP_SPCR_FREE);
-	davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_RCR_REG,
-				DAVINCI_MCBSP_RCR_RFRLEN1(1) |
-				DAVINCI_MCBSP_RCR_RDATDLY(1));
-	davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_XCR_REG,
-				DAVINCI_MCBSP_XCR_XFRLEN1(1) |
-				DAVINCI_MCBSP_XCR_XDATDLY(1) |
-				DAVINCI_MCBSP_XCR_XFIG);
 
 	i = hw_param_interval(params, SNDRV_PCM_HW_PARAM_SAMPLE_BITS);
 	w = davinci_mcbsp_read_reg(dev, DAVINCI_MCBSP_SRGR_REG);
-- 
1.5.6.5

^ permalink raw reply related	[flat|nested] 25+ messages in thread

* [PATCH 4/4] ASoC: DaVinci: Audio: Fix swapping of channels at start of stereo playback
  2008-11-12 11:55     ` [PATCH 3/4] ASoC: Add Right-Justified mode and Codec clock master to davinci-i2s Mark Brown
@ 2008-11-12 11:55       ` Mark Brown
  0 siblings, 0 replies; 25+ messages in thread
From: Mark Brown @ 2008-11-12 11:55 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel, Mark Brown, Naresh Medisetty

From: Naresh Medisetty <naresh@ti.com>

Fixes swapping of channels at start of stereo playback.

Channel swap can be observed while playing left-only or right-only audio data. The channel
swap is fixed by handling the XSYNCERR condition.

Signed-off-by: Naresh Medisetty <naresh@ti.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
---
 sound/soc/davinci/davinci-i2s.c |   49 ++++++++++++++++++++++++++++++++++++--
 1 files changed, 46 insertions(+), 3 deletions(-)

diff --git a/sound/soc/davinci/davinci-i2s.c b/sound/soc/davinci/davinci-i2s.c
index d814ec8..8c1bf87 100644
--- a/sound/soc/davinci/davinci-i2s.c
+++ b/sound/soc/davinci/davinci-i2s.c
@@ -111,16 +111,59 @@ static void davinci_mcbsp_start(struct snd_pcm_substream *substream)
 {
 	struct snd_soc_pcm_runtime *rtd = substream->private_data;
 	struct davinci_mcbsp_dev *dev = rtd->dai->cpu_dai->private_data;
+	struct snd_soc_device *socdev = rtd->socdev;
+	struct snd_soc_platform *platform = socdev->platform;
 	u32 w;
+	int ret;
 
 	/* Start the sample generator and enable transmitter/receiver */
 	w = davinci_mcbsp_read_reg(dev, DAVINCI_MCBSP_SPCR_REG);
 	MOD_REG_BIT(w, DAVINCI_MCBSP_SPCR_GRST, 1);
-	if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
+	davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_SPCR_REG, w);
+
+	if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
+		/* Stop the DMA to avoid data loss */
+		/* while the transmitter is out of reset to handle XSYNCERR */
+		if (platform->pcm_ops->trigger) {
+			ret = platform->pcm_ops->trigger(substream,
+				SNDRV_PCM_TRIGGER_STOP);
+			if (ret < 0)
+				printk(KERN_DEBUG "Playback DMA stop failed\n");
+		}
+
+		/* Enable the transmitter */
+		w = davinci_mcbsp_read_reg(dev, DAVINCI_MCBSP_SPCR_REG);
 		MOD_REG_BIT(w, DAVINCI_MCBSP_SPCR_XRST, 1);
-	else
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_SPCR_REG, w);
+
+		/* wait for any unexpected frame sync error to occur */
+		udelay(100);
+
+		/* Disable the transmitter to clear any outstanding XSYNCERR */
+		w = davinci_mcbsp_read_reg(dev, DAVINCI_MCBSP_SPCR_REG);
+		MOD_REG_BIT(w, DAVINCI_MCBSP_SPCR_XRST, 0);
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_SPCR_REG, w);
+
+		/* Restart the DMA */
+		if (platform->pcm_ops->trigger) {
+			ret = platform->pcm_ops->trigger(substream,
+				SNDRV_PCM_TRIGGER_START);
+			if (ret < 0)
+				printk(KERN_DEBUG "Playback DMA start failed\n");
+		}
+		/* Enable the transmitter */
+		w = davinci_mcbsp_read_reg(dev, DAVINCI_MCBSP_SPCR_REG);
+		MOD_REG_BIT(w, DAVINCI_MCBSP_SPCR_XRST, 1);
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_SPCR_REG, w);
+
+	} else {
+
+		/* Enable the reciever */
+		w = davinci_mcbsp_read_reg(dev, DAVINCI_MCBSP_SPCR_REG);
 		MOD_REG_BIT(w, DAVINCI_MCBSP_SPCR_RRST, 1);
-	davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_SPCR_REG, w);
+		davinci_mcbsp_write_reg(dev, DAVINCI_MCBSP_SPCR_REG, w);
+	}
+
 
 	/* Start frame sync */
 	w = davinci_mcbsp_read_reg(dev, DAVINCI_MCBSP_SPCR_REG);
-- 
1.5.6.5

^ permalink raw reply related	[flat|nested] 25+ messages in thread

* Re: [PATCH 0/4] ASoC updates
  2008-11-12 11:55 [PATCH 0/4] ASoC updates Mark Brown
  2008-11-12 11:55 ` [PATCH 1/4] ASoC: TLV320AIC23B Support more sample rates Mark Brown
@ 2008-11-12 12:31 ` Takashi Iwai
  1 sibling, 0 replies; 25+ messages in thread
From: Takashi Iwai @ 2008-11-12 12:31 UTC (permalink / raw)
  To: Mark Brown; +Cc: alsa-devel

At Wed, 12 Nov 2008 11:55:07 +0000,
Mark Brown wrote:
> 
> The following changes since commit e18c94d20224f3df584531a48d944d8cccfda46d:
>   Grazvydas Ignotas (1):
>         ALSA: ASoC: TWL4030 codec - fix 256*Fs clock
> 
> are available in the git repository at:
> 
>   git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

Thanks, pulled in, and pushed out.


Takashi

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix
  2008-11-12 11:55   ` [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix Mark Brown
  2008-11-12 11:55     ` [PATCH 3/4] ASoC: Add Right-Justified mode and Codec clock master to davinci-i2s Mark Brown
@ 2008-11-12 12:33     ` Takashi Iwai
  2008-11-12 15:10       ` Mark Brown
  2008-11-12 14:19     ` Ben Dooks
  2 siblings, 1 reply; 25+ messages in thread
From: Takashi Iwai @ 2008-11-12 12:33 UTC (permalink / raw)
  To: Mark Brown; +Cc: alsa-devel, Christian Pellegrin, Christian Pellegrin

At Wed, 12 Nov 2008 11:55:47 +0000,
Mark Brown wrote:
> 
> From: Christian Pellegrin <chripell@gmail.com>
> 
> fixes playing/recording of 8 bit audio files.
> 
> Generated on  20081108  against v2.6.27
> 
> Signed-off-by: Christian Pellegrin <chripell@fsfe.org>
> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
> ---
>  sound/soc/s3c24xx/s3c24xx-i2s.c |    7 +++++++
>  1 files changed, 7 insertions(+), 0 deletions(-)
> 
> diff --git a/sound/soc/s3c24xx/s3c24xx-i2s.c b/sound/soc/s3c24xx/s3c24xx-i2s.c
> index ba4476b..c18977b 100644
> --- a/sound/soc/s3c24xx/s3c24xx-i2s.c
> +++ b/sound/soc/s3c24xx/s3c24xx-i2s.c
> @@ -261,10 +261,17 @@ static int s3c24xx_i2s_hw_params(struct snd_pcm_substream *substream,
>  
>  	switch (params_format(params)) {
>  	case SNDRV_PCM_FORMAT_S8:
> +		iismod &= ~S3C2410_IISMOD_16BIT;
> +		((struct s3c24xx_pcm_dma_params *)
> +		  rtd->dai->cpu_dai->dma_data)->dma_size = 1;
>  		break;
>  	case SNDRV_PCM_FORMAT_S16_LE:
>  		iismod |= S3C2410_IISMOD_16BIT;
> +		((struct s3c24xx_pcm_dma_params *)
> +		  rtd->dai->cpu_dai->dma_data)->dma_size = 2;
>  		break;

I still feel a bit uncomfortable with this as it changes the global
variables.  Maybe better to assign the corresponding fields in the
local struct.


Takashi

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix
  2008-11-12 11:55   ` [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix Mark Brown
  2008-11-12 11:55     ` [PATCH 3/4] ASoC: Add Right-Justified mode and Codec clock master to davinci-i2s Mark Brown
  2008-11-12 12:33     ` [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix Takashi Iwai
@ 2008-11-12 14:19     ` Ben Dooks
  2008-11-12 14:21       ` Takashi Iwai
                         ` (2 more replies)
  2 siblings, 3 replies; 25+ messages in thread
From: Ben Dooks @ 2008-11-12 14:19 UTC (permalink / raw)
  To: Mark Brown
  Cc: Takashi Iwai, alsa-devel, Christian Pellegrin,
	Christian Pellegrin

On Wed, Nov 12, 2008 at 11:55:47AM +0000, Mark Brown wrote:
> From: Christian Pellegrin <chripell@gmail.com>
> 
> fixes playing/recording of 8 bit audio files.
> 
> Generated on  20081108  against v2.6.27
> 
> Signed-off-by: Christian Pellegrin <chripell@fsfe.org>
> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
> ---
>  sound/soc/s3c24xx/s3c24xx-i2s.c |    7 +++++++
>  1 files changed, 7 insertions(+), 0 deletions(-)
> 
> diff --git a/sound/soc/s3c24xx/s3c24xx-i2s.c b/sound/soc/s3c24xx/s3c24xx-i2s.c
> index ba4476b..c18977b 100644
> --- a/sound/soc/s3c24xx/s3c24xx-i2s.c
> +++ b/sound/soc/s3c24xx/s3c24xx-i2s.c
> @@ -261,10 +261,17 @@ static int s3c24xx_i2s_hw_params(struct snd_pcm_substream *substream,
>  
>  	switch (params_format(params)) {
>  	case SNDRV_PCM_FORMAT_S8:
> +		iismod &= ~S3C2410_IISMOD_16BIT;
> +		((struct s3c24xx_pcm_dma_params *)
> +		  rtd->dai->cpu_dai->dma_data)->dma_size = 1;
>  		break;
>  	case SNDRV_PCM_FORMAT_S16_LE:
>  		iismod |= S3C2410_IISMOD_16BIT;
> +		((struct s3c24xx_pcm_dma_params *)
> +		  rtd->dai->cpu_dai->dma_data)->dma_size = 2;
>  		break;
> +	default:
> +		return -EINVAL;
>  	}

Is playing with the dma parameters like that the correct way?
  
>  	writel(iismod, s3c24xx_i2s.regs + S3C2410_IISMOD);
> -- 
> 1.5.6.5
> 
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel@alsa-project.org
> http://mailman.alsa-project.org/mailman/listinfo/alsa-devel

-- 
-- 
Ben

Q:      What's a light-year?
A:      One-third less calories than a regular year.

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix
  2008-11-12 14:19     ` Ben Dooks
@ 2008-11-12 14:21       ` Takashi Iwai
  2008-11-12 14:59       ` Mark Brown
  2008-11-12 17:29       ` christian pellegrin
  2 siblings, 0 replies; 25+ messages in thread
From: Takashi Iwai @ 2008-11-12 14:21 UTC (permalink / raw)
  To: Ben Dooks
  Cc: alsa-devel, Mark Brown, Christian Pellegrin, Christian Pellegrin

At Wed, 12 Nov 2008 14:19:02 +0000,
Ben Dooks wrote:
> 
> On Wed, Nov 12, 2008 at 11:55:47AM +0000, Mark Brown wrote:
> > From: Christian Pellegrin <chripell@gmail.com>
> > 
> > fixes playing/recording of 8 bit audio files.
> > 
> > Generated on  20081108  against v2.6.27
> > 
> > Signed-off-by: Christian Pellegrin <chripell@fsfe.org>
> > Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
> > ---
> >  sound/soc/s3c24xx/s3c24xx-i2s.c |    7 +++++++
> >  1 files changed, 7 insertions(+), 0 deletions(-)
> > 
> > diff --git a/sound/soc/s3c24xx/s3c24xx-i2s.c b/sound/soc/s3c24xx/s3c24xx-i2s.c
> > index ba4476b..c18977b 100644
> > --- a/sound/soc/s3c24xx/s3c24xx-i2s.c
> > +++ b/sound/soc/s3c24xx/s3c24xx-i2s.c
> > @@ -261,10 +261,17 @@ static int s3c24xx_i2s_hw_params(struct snd_pcm_substream *substream,
> >  
> >  	switch (params_format(params)) {
> >  	case SNDRV_PCM_FORMAT_S8:
> > +		iismod &= ~S3C2410_IISMOD_16BIT;
> > +		((struct s3c24xx_pcm_dma_params *)
> > +		  rtd->dai->cpu_dai->dma_data)->dma_size = 1;
> >  		break;
> >  	case SNDRV_PCM_FORMAT_S16_LE:
> >  		iismod |= S3C2410_IISMOD_16BIT;
> > +		((struct s3c24xx_pcm_dma_params *)
> > +		  rtd->dai->cpu_dai->dma_data)->dma_size = 2;
> >  		break;
> > +	default:
> > +		return -EINVAL;
> >  	}
> 
> Is playing with the dma parameters like that the correct way?

It will work, I guess.  But I don't say it's entirely correct :)


Takashi

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix
  2008-11-12 14:19     ` Ben Dooks
  2008-11-12 14:21       ` Takashi Iwai
@ 2008-11-12 14:59       ` Mark Brown
  2008-11-12 17:29       ` christian pellegrin
  2 siblings, 0 replies; 25+ messages in thread
From: Mark Brown @ 2008-11-12 14:59 UTC (permalink / raw)
  To: Ben Dooks
  Cc: Takashi Iwai, alsa-devel, Christian Pellegrin,
	Christian Pellegrin

On Wed, Nov 12, 2008 at 02:19:02PM +0000, Ben Dooks wrote:
> On Wed, Nov 12, 2008 at 11:55:47AM +0000, Mark Brown wrote:

> >  	case SNDRV_PCM_FORMAT_S8:
> > +		iismod &= ~S3C2410_IISMOD_16BIT;
> > +		((struct s3c24xx_pcm_dma_params *)
> > +		  rtd->dai->cpu_dai->dma_data)->dma_size = 1;
> >  		break;
> >  	case SNDRV_PCM_FORMAT_S16_LE:
> >  		iismod |= S3C2410_IISMOD_16BIT;
> > +		((struct s3c24xx_pcm_dma_params *)
> > +		  rtd->dai->cpu_dai->dma_data)->dma_size = 2;
> >  		break;

> Is playing with the dma parameters like that the correct way?

It makes the DMA size match the input data size which doesn't seem
totally unreasonable.

This is all internal to the s3c24xx I2S driver - what this does is
change the parameter passed by the DMA driver to s3c2410_dma_config()
for the I2S DMA channels which is just read blindly.  This parameter is
not exposed to user space.

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix
  2008-11-12 12:33     ` [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix Takashi Iwai
@ 2008-11-12 15:10       ` Mark Brown
  2008-11-12 15:16         ` Takashi Iwai
  0 siblings, 1 reply; 25+ messages in thread
From: Mark Brown @ 2008-11-12 15:10 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel, Christian Pellegrin, Christian Pellegrin

On Wed, Nov 12, 2008 at 01:33:34PM +0100, Takashi Iwai wrote:

> I still feel a bit uncomfortable with this as it changes the global
> variables.  Maybe better to assign the corresponding fields in the
> local struct.

The global variable is used to tell the DMA driver how to set the
hardware up for the port.  Since the variable is tied to the underlying
hardware channel it's used for there's no real win from duplicating it
into a variable - the hardware it is used to configure can't be shared.

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix
  2008-11-12 15:10       ` Mark Brown
@ 2008-11-12 15:16         ` Takashi Iwai
  2008-11-12 15:25           ` Mark Brown
  0 siblings, 1 reply; 25+ messages in thread
From: Takashi Iwai @ 2008-11-12 15:16 UTC (permalink / raw)
  To: Mark Brown; +Cc: alsa-devel, Christian Pellegrin, Christian Pellegrin

At Wed, 12 Nov 2008 15:10:38 +0000,
Mark Brown wrote:
> 
> On Wed, Nov 12, 2008 at 01:33:34PM +0100, Takashi Iwai wrote:
> 
> > I still feel a bit uncomfortable with this as it changes the global
> > variables.  Maybe better to assign the corresponding fields in the
> > local struct.
> 
> The global variable is used to tell the DMA driver how to set the
> hardware up for the port.  Since the variable is tied to the underlying
> hardware channel it's used for there's no real win from duplicating it
> into a variable - the hardware it is used to configure can't be shared.

I know it, but it's still uncomfortable that such secret mythes and
legends are underlying without explanation.  Could you add some more
comments around that code to avoid misunderstanding by readers?


thanks,

Takashi

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix
  2008-11-12 15:16         ` Takashi Iwai
@ 2008-11-12 15:25           ` Mark Brown
  0 siblings, 0 replies; 25+ messages in thread
From: Mark Brown @ 2008-11-12 15:25 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel, Christian Pellegrin, Christian Pellegrin

On Wed, Nov 12, 2008 at 04:16:08PM +0100, Takashi Iwai wrote:
> Mark Brown wrote:

> > The global variable is used to tell the DMA driver how to set the
> > hardware up for the port.  Since the variable is tied to the underlying
> > hardware channel it's used for there's no real win from duplicating it
> > into a variable - the hardware it is used to configure can't be shared.

> I know it, but it's still uncomfortable that such secret mythes and
> legends are underlying without explanation.  Could you add some more
> comments around that code to avoid misunderstanding by readers?

Hrm, that's a fairly standard idiom for ASoC DMA/DAI driver interaction
so probably more of a Documentation/ thing but doing it there is not too
helpful for addressing your concern.  I'll have a think.

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix
  2008-11-12 14:19     ` Ben Dooks
  2008-11-12 14:21       ` Takashi Iwai
  2008-11-12 14:59       ` Mark Brown
@ 2008-11-12 17:29       ` christian pellegrin
  2 siblings, 0 replies; 25+ messages in thread
From: christian pellegrin @ 2008-11-12 17:29 UTC (permalink / raw)
  To: Ben Dooks; +Cc: Takashi Iwai, alsa-devel, Mark Brown

On Wed, Nov 12, 2008 at 3:19 PM, Ben Dooks <ben-linux@fluff.org> wrote:

>
> Is playing with the dma parameters like that the correct way?
>

Well this worked for me. I'm opened to better solutions and to resend
a patch but it's no clear to me how to proceed.

Out of curiosity I did a search in Openmoko if someone noticed the
same problem and found some people that had 8 bit ringtones sounding
awful on the neo/forerunner. But they just resampled them to 16bit
44khz and lived happy. Unfortunately for consultants there is always
the customer that wants to play that old 8-bit 11khz wav with the
vocal announcement from 10 year ago.

-- 
Christian Pellegrin, see http://www.evolware.org/chri/
"Real Programmers don't play tennis, or any other sport which requires
you to change clothes. Mountain climbing is OK, and Real Programmers
wear their climbing boots to work in case a mountain should suddenly
spring up in the middle of the computer room."

^ permalink raw reply	[flat|nested] 25+ messages in thread

* [PATCH 0/4] ASoC updates
@ 2008-11-14 14:57 Mark Brown
  2008-11-14 16:03 ` Takashi Iwai
  0 siblings, 1 reply; 25+ messages in thread
From: Mark Brown @ 2008-11-14 14:57 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel

The following changes since commit fb0ef645f2c546f8297b2fbf9b2b8fff4a7455e8:
  Naresh Medisetty (1):
        ASoC: DaVinci: Audio: Fix swapping of channels at start of stereo playback

are available in the git repository at:

  git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

Jarkko Nikula (2):
      ASoC: Fix supported sample rates of TWL4030 audio codec
      ASoC: OMAP: Add more supported sample rates into McBSP DAI driver

Mark Brown (2):
      ASoC: Revert "ASoC: Add new parameter to s3c24xx_pcm_enqueue"
      ASoC: Add WM8728 codec driver

 sound/soc/codecs/Kconfig        |    4 +
 sound/soc/codecs/Makefile       |    2 +
 sound/soc/codecs/twl4030.c      |    2 +-
 sound/soc/codecs/wm8728.c       |  574 +++++++++++++++++++++++++++++++++++++++
 sound/soc/codecs/wm8728.h       |   30 ++
 sound/soc/omap/omap-mcbsp.c     |    4 +-
 sound/soc/s3c24xx/s3c24xx-pcm.c |   12 +-
 7 files changed, 616 insertions(+), 12 deletions(-)
 create mode 100644 sound/soc/codecs/wm8728.c
 create mode 100644 sound/soc/codecs/wm8728.h

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 0/4] ASoC updates
  2008-11-14 14:57 Mark Brown
@ 2008-11-14 16:03 ` Takashi Iwai
  0 siblings, 0 replies; 25+ messages in thread
From: Takashi Iwai @ 2008-11-14 16:03 UTC (permalink / raw)
  To: Mark Brown; +Cc: alsa-devel

At Fri, 14 Nov 2008 14:57:06 +0000,
Mark Brown wrote:
> 
> The following changes since commit fb0ef645f2c546f8297b2fbf9b2b8fff4a7455e8:
>   Naresh Medisetty (1):
>         ASoC: DaVinci: Audio: Fix swapping of channels at start of stereo playback
> 
> are available in the git repository at:
> 
>   git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

Thanks, applied now.


Takashi

^ permalink raw reply	[flat|nested] 25+ messages in thread

* [PATCH 0/4] ASoC updates
@ 2008-12-04 11:25 Mark Brown
  2008-12-04 14:29 ` Takashi Iwai
  0 siblings, 1 reply; 25+ messages in thread
From: Mark Brown @ 2008-12-04 11:25 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel

The following changes since commit 6f2a974bfc8d3be7a30674c71e2fef003b39a8d2:
  Daniel Mack (1):
        ASoC: tlv320aic3x: headset/button press support

are available in the git repository at:

  git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

Mark Brown (4):
      ASoC: Push debugfs files out of the snd_soc_device structure
      ASoC: Remove device from platform suspend and resume operations
      ASoC: Remove platform device from DAI suspend and resume operations
      ASoC: Remove obsolete declaration of struct snd_soc_clock_info

 include/sound/soc-dai.h         |    6 +--
 include/sound/soc.h             |   15 +++----
 sound/soc/atmel/atmel-pcm.c     |    6 +--
 sound/soc/atmel/atmel_ssc_dai.c |    6 +--
 sound/soc/au1x/psc-ac97.c       |    6 +--
 sound/soc/au1x/psc-i2s.c        |    6 +--
 sound/soc/blackfin/bf5xx-ac97.c |    6 +--
 sound/soc/blackfin/bf5xx-i2s.c  |    6 +--
 sound/soc/pxa/pxa-ssp.c         |    6 +--
 sound/soc/pxa/pxa2xx-ac97.c     |    6 +--
 sound/soc/pxa/pxa2xx-i2s.c      |    6 +--
 sound/soc/s3c24xx/s3c2412-i2s.c |   16 +++----
 sound/soc/s3c24xx/s3c24xx-i2s.c |    6 +--
 sound/soc/soc-core.c            |   85 +++++++++++++++++++++-----------------
 14 files changed, 83 insertions(+), 99 deletions(-)

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 0/4] ASoC updates
  2008-12-04 11:25 Mark Brown
@ 2008-12-04 14:29 ` Takashi Iwai
  0 siblings, 0 replies; 25+ messages in thread
From: Takashi Iwai @ 2008-12-04 14:29 UTC (permalink / raw)
  To: Mark Brown; +Cc: alsa-devel

At Thu, 4 Dec 2008 11:25:43 +0000,
Mark Brown wrote:
> 
> The following changes since commit 6f2a974bfc8d3be7a30674c71e2fef003b39a8d2:
>   Daniel Mack (1):
>         ASoC: tlv320aic3x: headset/button press support
> 
> are available in the git repository at:
> 
>   git://opensource.wolfsonmicro.com/linux-2.6-asoc for-tiwai

Pulled now.  Thanks.


Takashi

^ permalink raw reply	[flat|nested] 25+ messages in thread

* [PATCH 0/4] ASoC updates
@ 2008-12-18 17:30 Mark Brown
  2008-12-19  7:11 ` Takashi Iwai
  0 siblings, 1 reply; 25+ messages in thread
From: Mark Brown @ 2008-12-18 17:30 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: alsa-devel

The following changes since commit 49d92c7d5bbd158734bc34ed578a68b214a48583:
  Stanley.Miao (1):
        ASoC: TWL4030: hands-free start-up sequence.

are available in the git repository at:

  git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound-2.6.git for-tiwai

Alexander Beregalov (1):
      ASoC: switch davinci DPRINTK to pr_debug()

Mark Brown (3):
      ASoC: Ease merge difficulties from new architectures
      ASoC: Complain if we fail to create DAPM controls
      ASoC: Add WM8350 AudioPlus codec driver

 include/linux/mfd/wm8350/audio.h |   38 +-
 sound/soc/Kconfig                |   10 +-
 sound/soc/Makefile               |   12 +-
 sound/soc/codecs/Kconfig         |    4 +
 sound/soc/codecs/Makefile        |    2 +
 sound/soc/codecs/wm8350.c        | 1583 ++++++++++++++++++++++++++++++++++++++
 sound/soc/codecs/wm8350.h        |   20 +
 sound/soc/davinci/davinci-pcm.c  |   18 +-
 sound/soc/soc-dapm.c             |    6 +-
 9 files changed, 1669 insertions(+), 24 deletions(-)
 create mode 100644 sound/soc/codecs/wm8350.c
 create mode 100644 sound/soc/codecs/wm8350.h

^ permalink raw reply	[flat|nested] 25+ messages in thread

* Re: [PATCH 0/4] ASoC updates
  2008-12-18 17:30 Mark Brown
@ 2008-12-19  7:11 ` Takashi Iwai
  0 siblings, 0 replies; 25+ messages in thread
From: Takashi Iwai @ 2008-12-19  7:11 UTC (permalink / raw)
  To: Mark Brown; +Cc: alsa-devel

At Thu, 18 Dec 2008 17:30:21 +0000,
Mark Brown wrote:
> 
> The following changes since commit 49d92c7d5bbd158734bc34ed578a68b214a48583:
>   Stanley.Miao (1):
>         ASoC: TWL4030: hands-free start-up sequence.
> 
> are available in the git repository at:
> 
>   git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound-2.6.git for-tiwai

Applied now.  Thanks.


Takashi

> 
> Alexander Beregalov (1):
>       ASoC: switch davinci DPRINTK to pr_debug()
> 
> Mark Brown (3):
>       ASoC: Ease merge difficulties from new architectures
>       ASoC: Complain if we fail to create DAPM controls
>       ASoC: Add WM8350 AudioPlus codec driver
> 
>  include/linux/mfd/wm8350/audio.h |   38 +-
>  sound/soc/Kconfig                |   10 +-
>  sound/soc/Makefile               |   12 +-
>  sound/soc/codecs/Kconfig         |    4 +
>  sound/soc/codecs/Makefile        |    2 +
>  sound/soc/codecs/wm8350.c        | 1583 ++++++++++++++++++++++++++++++++++++++
>  sound/soc/codecs/wm8350.h        |   20 +
>  sound/soc/davinci/davinci-pcm.c  |   18 +-
>  sound/soc/soc-dapm.c             |    6 +-
>  9 files changed, 1669 insertions(+), 24 deletions(-)
>  create mode 100644 sound/soc/codecs/wm8350.c
>  create mode 100644 sound/soc/codecs/wm8350.h
> 

^ permalink raw reply	[flat|nested] 25+ messages in thread

end of thread, other threads:[~2008-12-19  7:11 UTC | newest]

Thread overview: 25+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-11-12 11:55 [PATCH 0/4] ASoC updates Mark Brown
2008-11-12 11:55 ` [PATCH 1/4] ASoC: TLV320AIC23B Support more sample rates Mark Brown
2008-11-12 11:55   ` [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix Mark Brown
2008-11-12 11:55     ` [PATCH 3/4] ASoC: Add Right-Justified mode and Codec clock master to davinci-i2s Mark Brown
2008-11-12 11:55       ` [PATCH 4/4] ASoC: DaVinci: Audio: Fix swapping of channels at start of stereo playback Mark Brown
2008-11-12 12:33     ` [PATCH 2/4] ASoC: s3c24xx 8 bit sound fix Takashi Iwai
2008-11-12 15:10       ` Mark Brown
2008-11-12 15:16         ` Takashi Iwai
2008-11-12 15:25           ` Mark Brown
2008-11-12 14:19     ` Ben Dooks
2008-11-12 14:21       ` Takashi Iwai
2008-11-12 14:59       ` Mark Brown
2008-11-12 17:29       ` christian pellegrin
2008-11-12 12:31 ` [PATCH 0/4] ASoC updates Takashi Iwai
  -- strict thread matches above, loose matches on Subject: below --
2008-12-18 17:30 Mark Brown
2008-12-19  7:11 ` Takashi Iwai
2008-12-04 11:25 Mark Brown
2008-12-04 14:29 ` Takashi Iwai
2008-11-14 14:57 Mark Brown
2008-11-14 16:03 ` Takashi Iwai
2008-11-06 11:38 Mark Brown
2008-11-06 11:57 ` Takashi Iwai
2008-11-05 18:52 Mark Brown
2008-09-24 11:59 Mark Brown
2008-09-24 12:43 ` Takashi Iwai

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.