1. 29 Apr, 2020 1 commit
  2. 28 Apr, 2020 1 commit
  3. 27 Apr, 2020 1 commit
  4. 26 Apr, 2020 1 commit
  5. 24 Apr, 2020 4 commits
  6. 23 Apr, 2020 3 commits
  7. 22 Apr, 2020 1 commit
    • Takashi Iwai's avatar
      ALSA: usb-audio: Add connector notifier delegation · fef66ae7
      Takashi Iwai authored
      It turned out that ALC1220-VB USB-audio device gives the interrupt
      event to some PCM terminals while those don't allow the connector
      state request but only the actual I/O terminals return the request.
      The recent commit 7dc3c5a0 ("ALSA: usb-audio: Don't create jack
      controls for PCM terminals") excluded those phantom terminals, so
      those events are ignored, too.
      
      My first thought was that this could be easily deduced from the
      associated terminals, but some of them have even no associate terminal
      ID, hence it's not too trivial to figure out.
      
      Since the number of such terminals are small and limited, this patch
      implements another quirk table for the simple mapping of the
      connectors.  It's not really scalable, but let's hope that there will
      be not many such funky devices in future.
      
      Fixes: 7dc3c5a0 ("ALSA: usb-audio: Don't create jack controls for PCM terminals")
      BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=206873
      Link: https://lore.kernel.org/r/20200422113320.26664-1-tiwai@suse.deSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      fef66ae7
  8. 21 Apr, 2020 5 commits
  9. 20 Apr, 2020 9 commits
    • YueHaibing's avatar
      ASoC: wm89xx: Add missing dependency · 9bff3d30
      YueHaibing authored
      sound/soc/codecs/wm8900.o: In function `wm8900_i2c_probe':
      wm8900.c:(.text+0xa36): undefined reference to `__devm_regmap_init_i2c'
      sound/soc/codecs/wm8900.o: In function `wm8900_modinit':
      wm8900.c:(.init.text+0xb): undefined reference to `i2c_register_driver'
      sound/soc/codecs/wm8900.o: In function `wm8900_exit':
      wm8900.c:(.exit.text+0x8): undefined reference to `i2c_del_driver'
      sound/soc/codecs/wm8988.o: In function `wm8988_i2c_probe':
      wm8988.c:(.text+0x857): undefined reference to `__devm_regmap_init_i2c'
      sound/soc/codecs/wm8988.o: In function `wm8988_modinit':
      wm8988.c:(.init.text+0xb): undefined reference to `i2c_register_driver'
      sound/soc/codecs/wm8988.o: In function `wm8988_exit':
      wm8988.c:(.exit.text+0x8): undefined reference to `i2c_del_driver'
      sound/soc/codecs/wm8995.o: In function `wm8995_i2c_probe':
      wm8995.c:(.text+0x1c4f): undefined reference to `__devm_regmap_init_i2c'
      sound/soc/codecs/wm8995.o: In function `wm8995_modinit':
      wm8995.c:(.init.text+0xb): undefined reference to `i2c_register_driver'
      sound/soc/codecs/wm8995.o: In function `wm8995_exit':
      wm8995.c:(.exit.text+0x8): undefined reference to `i2c_del_driver'
      
      Add SND_SOC_I2C_AND_SPI dependency to fix this.
      
      Fixes: ea00d952 ("ASoC: Use imply for SND_SOC_ALL_CODECS")
      Reported-by: default avatarHulk Robot <hulkci@huawei.com>
      Signed-off-by: default avatarYueHaibing <yuehaibing@huawei.com>
      Acked-by: default avatarCharles Keepax <ckeepax@opensource.cirrus.com>
      Link: https://lore.kernel.org/r/20200420125343.20920-1-yuehaibing@huawei.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      9bff3d30
    • Mark Brown's avatar
      Merge series "ASoC: rsnd: multi-SSI setup fixes" from Matthias Blankertz... · bce32169
      Mark Brown authored
      Merge series "ASoC: rsnd: multi-SSI setup fixes" from Matthias Blankertz <matthias.blankertz@cetitec.com>:
      
      Fix rsnd_dai_call() operations being performed twice for the master SSI
      in multi-SSI setups, and fix the rsnd_ssi_stop operation for multi-SSI
      setups.
      The only visible effect of these issues was some "status check failed"
      spam when the rsnd_ssi_stop was called, but overall the code is cleaner
      now, and some questionable writes to the SSICR register which did not
      lead to any observable misbehaviour but were contrary to the datasheet
      are fixed.
      
      Mark:
      The first patch kind of reverts my "ASoC: rsnd: Fix parent SSI
      start/stop in multi-SSI mode" from a few days ago and achieves the same
      effect in a simpler fashion, if you would prefer a clean patch series
      based on v5.6 drop me a note.
      
      Greetings,
      	Matthias
      
      Matthias Blankertz (2):
        ASoC: rsnd: Don't treat master SSI in multi SSI setup as parent
        ASoC: rsnd: Fix "status check failed" spam for multi-SSI
      
       sound/soc/sh/rcar/ssi.c | 18 +++++++++++++-----
       1 file changed, 13 insertions(+), 5 deletions(-)
      
      base-commit: 15a5760c
      --
      2.26.1
      bce32169
    • Mark Brown's avatar
      Merge series "ASoC: meson: fix codec-to-codec link setup" from Jerome Brunet... · 036889b2
      Mark Brown authored
      Merge series "ASoC: meson: fix codec-to-codec link setup" from Jerome Brunet <jbrunet@baylibre.com>:
      
      This patchset fixes the problem reported by Marc in this thread [0]
      The problem was due to an error in the meson card drivers which had
      the "no_pcm" dai_link property set on codec-to-codec links
      
      [0]: https://lore.kernel.org/r/20200417122732.GC5315@sirena.org.uk
      
      Jerome Brunet (2):
        ASoC: meson: axg-card: fix codec-to-codec link setup
        ASoC: meson: gx-card: fix codec-to-codec link setup
      
       sound/soc/meson/axg-card.c | 4 +++-
       sound/soc/meson/gx-card.c  | 4 +++-
       2 files changed, 6 insertions(+), 2 deletions(-)
      
      --
      2.25.2
      036889b2
    • Gyeongtaek Lee's avatar
      ASoC: dapm: fixup dapm kcontrol widget · ebf14747
      Gyeongtaek Lee authored
      snd_soc_dapm_kcontrol widget which is created by autodisable control
      should contain correct on_val, mask and shift because it is set when the
      widget is powered and changed value is applied on registers by following
      code in dapm_seq_run_coalesced().
      
      		mask |= w->mask << w->shift;
      		if (w->power)
      			value |= w->on_val << w->shift;
      		else
      			value |= w->off_val << w->shift;
      
      Shift on the mask in dapm_kcontrol_data_alloc() is removed to prevent
      double shift.
      And, on_val in dapm_kcontrol_set_value() is modified to get correct
      value in the dapm_seq_run_coalesced().
      Signed-off-by: default avatarGyeongtaek Lee <gt82.lee@samsung.com>
      Cc: stable@vger.kernel.org
      Link: https://lore.kernel.org/r/000001d61537$b212f620$1638e260$@samsung.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      ebf14747
    • Matthias Blankertz's avatar
      ASoC: rsnd: Fix "status check failed" spam for multi-SSI · 54cb6221
      Matthias Blankertz authored
      Fix the rsnd_ssi_stop function to skip disabling the individual SSIs of
      a multi-SSI setup, as the actual stop is performed by rsnd_ssiu_stop_gen2
      - the same logic as in rsnd_ssi_start. The attempt to disable these SSIs
      was harmless, but caused a "status check failed" message to be printed
      for every SSI in the multi-SSI setup.
      The disabling of interrupts is still performed, as they are enabled for
      all SSIs in rsnd_ssi_init, but care is taken to not accidentally set the
      EN bit for an SSI where it was not set by rsnd_ssi_start.
      Signed-off-by: default avatarMatthias Blankertz <matthias.blankertz@cetitec.com>
      Acked-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
      Link: https://lore.kernel.org/r/20200417153017.1744454-3-matthias.blankertz@cetitec.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      54cb6221
    • Matthias Blankertz's avatar
      ASoC: rsnd: Don't treat master SSI in multi SSI setup as parent · 0c258657
      Matthias Blankertz authored
      The master SSI of a multi-SSI setup was attached both to the
      RSND_MOD_SSI slot and the RSND_MOD_SSIP slot of the rsnd_dai_stream.
      This is not correct wrt. the meaning of being "parent" in the rest of
      the SSI code, where it seems to indicate an SSI that provides clock and
      word sync but is not transmitting/receiving audio data.
      
      Not treating the multi-SSI master as parent allows removal of various
      special cases to the rsnd_ssi_is_parent conditions introduced in commit
      a09fb3f2 ("ASoC: rsnd: Fix parent SSI start/stop in multi-SSI mode").
      It also fixes the issue that operations performed via rsnd_dai_call()
      were performed twice for the master SSI. This caused some "status check
      failed" spam when stopping a multi-SSI stream as the driver attempted to
      stop the master SSI twice.
      Signed-off-by: default avatarMatthias Blankertz <matthias.blankertz@cetitec.com>
      Acked-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
      Link: https://lore.kernel.org/r/20200417153017.1744454-2-matthias.blankertz@cetitec.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      0c258657
    • Jerome Brunet's avatar
      ASoC: meson: gx-card: fix codec-to-codec link setup · de911b4e
      Jerome Brunet authored
      Since the addition of commit 9b5db059 ("ASoC: soc-pcm: dpcm: Only allow
      playback/capture if supported"), meson-axg cards which have codec-to-codec
      links fail to init and Oops.
      
        Unable to handle kernel NULL pointer dereference at virtual address 0000000000000128
        Internal error: Oops: 96000044 [#1] PREEMPT SMP
        CPU: 3 PID: 1582 Comm: arecord Not tainted 5.7.0-rc1
        pc : invalidate_paths_ep+0x30/0xe0
        lr : snd_soc_dapm_dai_get_connected_widgets+0x170/0x1a8
        Call trace:
         invalidate_paths_ep+0x30/0xe0
         snd_soc_dapm_dai_get_connected_widgets+0x170/0x1a8
         dpcm_path_get+0x38/0xd0
         dpcm_fe_dai_open+0x70/0x920
         snd_pcm_open_substream+0x564/0x840
         snd_pcm_open+0xfc/0x228
         snd_pcm_capture_open+0x4c/0x78
         snd_open+0xac/0x1a8
         ...
      
      While this error was initially reported the axg-card type, it also applies
      to the gx-card type.
      
      While initiliazing the links, ASoC treats the codec-to-codec links of this
      card type as a DPCM backend. This error eventually leads to the Oops.
      
      Most of the card driver code is shared between DPCM backends and
      codec-to-codec links. The property "no_pcm" marking DCPM BE was left set on
      codec-to-codec links, leading to this problem. This commit fixes that.
      
      Fixes: e37a0c31 ("ASoC: meson: gx: add sound card support")
      Signed-off-by: default avatarJerome Brunet <jbrunet@baylibre.com>
      Link: https://lore.kernel.org/r/20200420114511.450560-3-jbrunet@baylibre.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      de911b4e
    • Jerome Brunet's avatar
      ASoC: meson: axg-card: fix codec-to-codec link setup · 11642842
      Jerome Brunet authored
      Since the addition of commit 9b5db059 ("ASoC: soc-pcm: dpcm: Only allow
      playback/capture if supported"), meson-axg cards which have codec-to-codec
      links fail to init and Oops:
      
        Unable to handle kernel NULL pointer dereference at virtual address 0000000000000128
        Internal error: Oops: 96000044 [#1] PREEMPT SMP
        CPU: 3 PID: 1582 Comm: arecord Not tainted 5.7.0-rc1
        pc : invalidate_paths_ep+0x30/0xe0
        lr : snd_soc_dapm_dai_get_connected_widgets+0x170/0x1a8
        Call trace:
         invalidate_paths_ep+0x30/0xe0
         snd_soc_dapm_dai_get_connected_widgets+0x170/0x1a8
         dpcm_path_get+0x38/0xd0
         dpcm_fe_dai_open+0x70/0x920
         snd_pcm_open_substream+0x564/0x840
         snd_pcm_open+0xfc/0x228
         snd_pcm_capture_open+0x4c/0x78
         snd_open+0xac/0x1a8
         ...
      
      While initiliazing the links, ASoC treats the codec-to-codec links of this
      card type as a DPCM backend. This error eventually leads to the Oops.
      
      Most of the card driver code is shared between DPCM backends and
      codec-to-codec links. The property "no_pcm" marking DCPM BE was left set on
      codec-to-codec links, leading to this problem. This commit fixes that.
      
      Fixes: 0a8f1117 ("ASoC: meson: axg-card: add basic codec-to-codec link support")
      Signed-off-by: default avatarJerome Brunet <jbrunet@baylibre.com>
      Link: https://lore.kernel.org/r/20200420114511.450560-2-jbrunet@baylibre.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      11642842
    • Takashi Iwai's avatar
      ALSA: usb-audio: Add static mapping table for ALC1220-VB-based mobos · a43c1c41
      Takashi Iwai authored
      TRX40 mobos from MSI and others with ALC1220-VB USB-audio device need
      yet more quirks for the proper control names.
      
      This patch provides the mapping table for those boards, correcting the
      FU names for volume and mute controls as well as the terminal names
      for jack controls.  It also improves build_connector_control() not to
      add the directional suffix blindly if the string is given from the
      mapping table.
      
      With this patch applied, the new UCM profiles will be effective.
      
      BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=206873
      Link: https://lore.kernel.org/r/20200420062036.28567-1-tiwai@suse.deSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      a43c1c41
  10. 19 Apr, 2020 1 commit
  11. 18 Apr, 2020 2 commits
  12. 17 Apr, 2020 3 commits
  13. 16 Apr, 2020 4 commits
  14. 15 Apr, 2020 4 commits
    • Pierre-Louis Bossart's avatar
      ASoC: soc-dai: revert all changes to DAI startup/shutdown sequence · 5bd70440
      Pierre-Louis Bossart authored
      On Baytrail/Cherrytrail, the Atom/SST driver fails miserably:
      
      [    9.741953] intel_sst_acpi 80860F28:00: FW Version 01.0c.00.01
      [    9.832992] intel_sst_acpi 80860F28:00: FW sent error response 0x40034
      [    9.833019] intel_sst_acpi 80860F28:00: FW alloc failed ret -4
      [    9.833028] intel_sst_acpi 80860F28:00: sst_get_stream returned err -5
      [    9.833033] sst-mfld-platform sst-mfld-platform: ASoC: DAI prepare error: -5
      [    9.833037]  Baytrail Audio Port: ASoC: prepare FE Baytrail Audio Port failed
      [    9.853942] intel_sst_acpi 80860F28:00: FW sent error response 0x40034
      [    9.853974] intel_sst_acpi 80860F28:00: FW alloc failed ret -4
      [    9.853984] intel_sst_acpi 80860F28:00: sst_get_stream returned err -5
      [    9.853990] sst-mfld-platform sst-mfld-platform: ASoC: DAI prepare error: -5
      [    9.853994]  Baytrail Audio Port: ASoC: prepare FE Baytrail Audio Port failed
      
      Commit b56be800 ("ASoC: soc-pcm: call
      snd_soc_dai_startup()/shutdown() once") was the initial problematic
      commit.
      
      Commit 1ba616bd ("ASoC: soc-dai: fix DAI startup/shutdown sequence")
      was an attempt to fix things but it does not work on Baytrail,
      reverting all changes seems necessary for now.
      
      Fixes: 1ba616bd ("ASoC: soc-dai: fix DAI startup/shutdown sequence")
      Signed-off-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
      Tested-by: default avatarHans de Goede <hdegoede@redhat.com>
      Link: https://lore.kernel.org/r/20200415030437.23803-1-pierre-louis.bossart@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      5bd70440
    • Amadeusz Sławiński's avatar
      ASoC: topology: Fix endianness issue · 26d87881
      Amadeusz Sławiński authored
      As done in already existing cases, we should use le32_to_cpu macro while
      accessing hdr->magic. Found with sparse.
      Signed-off-by: default avatarAmadeusz Sławiński <amadeuszx.slawinski@linux.intel.com>
      Link: https://lore.kernel.org/r/20200415162435.31859-2-amadeuszx.slawinski@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      26d87881
    • Stephan Gerhold's avatar
      ASoC: q6dsp6: q6afe-dai: add missing channels to MI2S DAIs · 0c824ec0
      Stephan Gerhold authored
      For some reason, the MI2S DAIs do not have channels_min/max defined.
      This means that snd_soc_dai_stream_valid() returns false,
      i.e. the DAIs have neither valid playback nor capture stream.
      
      It's quite surprising that this ever worked correctly,
      but in 5.7-rc1 this is now failing badly: :)
      
      Commit 0e9cf4c4 ("ASoC: pcm: check if cpu-dai supports a given stream")
      introduced a check for snd_soc_dai_stream_valid() before calling
      hw_params(), which means that the q6i2s_hw_params() function
      was never called, eventually resulting in:
      
          qcom-q6afe aprsvc:q6afe:4:4: no line is assigned
      
      ... even though "qcom,sd-lines" is set in the device tree.
      
      Commit 9b5db059 ("ASoC: soc-pcm: dpcm: Only allow playback/capture if supported")
      now even avoids creating PCM devices if the stream is not supported,
      which means that it is failing even earlier with e.g.:
      
          Primary MI2S: ASoC: no backend playback stream
      
      Avoid all that trouble by adding channels_min/max for the MI2S DAIs.
      
      Fixes: 24c4cbcf ("ASoC: qdsp6: q6afe: Add q6afe dai driver")
      Signed-off-by: default avatarStephan Gerhold <stephan@gerhold.net>
      Reviewed-by: default avatarSrinivas Kandagatla <srinivas.kandagatla@linaro.org>
      Cc: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
      Link: https://lore.kernel.org/r/20200415150050.616392-1-stephan@gerhold.netSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      0c824ec0
    • Stephan Gerhold's avatar
      ASoC: soc-pcm: dpcm: Only allow playback/capture if supported · 9b5db059
      Stephan Gerhold authored
      At the moment, PCM devices for DPCM are only created based on the
      dpcm_playback/capture parameters of the DAI link, without considering
      if the CPU/FE DAI is actually capable of playback/capture.
      
      Normally the dpcm_playback/capture parameter should match the
      capabilities of the CPU DAI. However, there is no way to set that
      parameter from the device tree (e.g. with simple-audio-card or
      qcom sound cards). dpcm_playback/capture are always both set to 1.
      
      This causes problems when the CPU DAI does only support playback
      or capture. Attemting to open that PCM device with an unsupported
      stream type then results in a null pointer dereference:
      
          Unable to handle kernel NULL pointer dereference at virtual address 0000000000000128
          Internal error: Oops: 96000044 [#1] PREEMPT SMP
          CPU: 3 PID: 1582 Comm: arecord Not tainted 5.7.0-rc1
          pc : invalidate_paths_ep+0x30/0xe0
          lr : snd_soc_dapm_dai_get_connected_widgets+0x170/0x1a8
          Call trace:
           invalidate_paths_ep+0x30/0xe0
           snd_soc_dapm_dai_get_connected_widgets+0x170/0x1a8
           dpcm_path_get+0x38/0xd0
           dpcm_fe_dai_open+0x70/0x920
           snd_pcm_open_substream+0x564/0x840
           snd_pcm_open+0xfc/0x228
           snd_pcm_capture_open+0x4c/0x78
           snd_open+0xac/0x1a8
           ...
      
      ... because the DAI playback/capture_widget is not set in that case.
      
      We could add checks there to fix the problem (maybe we should
      anyway), but much easier is to not expose the device as
      playback/capture in the first place. Attemting to use that
      device would always fail later anyway.
      
      Add checks for snd_soc_dai_stream_valid() to the DPCM case
      to avoid exposing playback/capture if it is not supported.
      Signed-off-by: default avatarStephan Gerhold <stephan@gerhold.net>
      Link: https://lore.kernel.org/r/20200415104928.86091-1-stephan@gerhold.netSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      9b5db059