1. 05 Mar, 2024 1 commit
  2. 04 Mar, 2024 4 commits
  3. 01 Mar, 2024 2 commits
    • songxiebing's avatar
      ALSA: hda: optimize the probe codec process · 642b02b4
      songxiebing authored
      In azx_probe_codecs function, when bus->codec_mask is becomes to 0(no codecs),
      execute azx_init_chip, bus->codec_mask will be initialized to a value again,
      this causes snd_hda_codec_new function to run, the process is as follows:
      -->snd_hda_codec_new
      -->snd_hda_codec_device_init
      -->snd_hdac_device_init---snd_hdac_read_parm(...AC_PAR_VENDOR_ID) 2s
      		       ---snd_hdac_read_parm(...AC_PAR_VENDOR_ID) 2s
      		       ---snd_hdac_read_parm(...AC_PAR_SUBSYSTEM_ID) 2s
      		       ---snd_hdac_read_parm(...AC_PAR_REV_ID) 2s
      		       ---snd_hdac_read_parm(...AC_PAR_NODE_COUNT) 2s
      when no codecs, read communication is error, each command will be polled for
      2 second, a total of 10s, it is easy to some problem.
      like this:
        2 [   14.833404][ 6] [  T164] hda 0006:00: Codec #0 probe error; disabling it...
        3 [   14.844178][ 6] [  T164] hda 0006:00: codec_mask = 0x1
        4 [   14.880532][ 6] [  T164] hda 0006:00: too slow response, last cmd=0x0f0000
        5 [   15.891988][ 6] [  T164] hda 0006:00: too slow response, last cmd=0x0f0000
        6 [   16.978090][ 6] [  T164] hda 0006:00: too slow response, last cmd=0x0f0001
        7 [   18.140895][ 6] [  T164] hda 0006:00: too slow response, last cmd=0x0f0002
        8 [   19.135516][ 6] [  T164] hda 0006:00: too slow response, last cmd=0x0f0004
       10 [   19.900086][ 6] [  T164] hda 0006:00: no codecs initialized
       11 [   45.573398][ 2] [    C2] watchdog: BUG: soft lockup - CPU#2 stuck for 22s! [kworker/2:0:25]
      
      Here, when bus->codec_mask is 0, use a direct break to avoid execute snd_hda_codec_new function.
      Signed-off-by: default avatarsongxiebing <songxiebing@kylinos.cn>
      Link: https://lore.kernel.org/r/20240301011841.7247-1-soxiebing@163.comSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      642b02b4
    • Kailang Yang's avatar
      ALSA: hda/realtek - Fix headset Mic no show at resume back for Lenovo ALC897 platform · d397b6e5
      Kailang Yang authored
      Headset Mic will no show at resume back.
      This patch will fix this issue.
      
      Fixes: d7f32791 ("ALSA: hda/realtek - Add headset Mic support for Lenovo ALC897 platform")
      Cc: <stable@vger.kernel.org>
      Signed-off-by: default avatarKailang Yang <kailang@realtek.com>
      Link: https://lore.kernel.org/r/4713d48a372e47f98bba0c6120fd8254@realtek.comSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      d397b6e5
  4. 29 Feb, 2024 1 commit
    • Takashi Iwai's avatar
      Merge tag 'asoc-fix-v6.8-rc5' of... · 17c6a0c9
      Takashi Iwai authored
      Merge tag 'asoc-fix-v6.8-rc5' of https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-linus
      
      ASoC: Fixes for v6.8
      
      A few small fixes, some driver specific and one slightly larger one
      from Richard which adds a new core helper and updates a small clutch of
      drivers to deal with the fact that they were using a helper which
      requires that the lock for the list of controls without holding that
      lock.  We also have some quirks for new AMD based Lenovo systems.
      17c6a0c9
  5. 28 Feb, 2024 2 commits
  6. 27 Feb, 2024 1 commit
  7. 26 Feb, 2024 1 commit
  8. 25 Feb, 2024 1 commit
  9. 23 Feb, 2024 3 commits
    • Richard Fitzgerald's avatar
      ASoC: soc-card: Fix missing locking in snd_soc_card_get_kcontrol() · eba2eb24
      Richard Fitzgerald authored
      snd_soc_card_get_kcontrol() must be holding a read lock on
      card->controls_rwsem while walking the controls list.
      
      Compare with snd_ctl_find_numid().
      
      The existing function is renamed snd_soc_card_get_kcontrol_locked()
      so that it can be called from contexts that are already holding
      card->controls_rwsem (for example, control get/put functions).
      
      There are few direct or indirect callers of
      snd_soc_card_get_kcontrol(), and most are safe. Three require
      changes, which have been included in this patch:
      
      codecs/cs35l45.c:
        cs35l45_activate_ctl() is called from a control put() function so
        is changed to call snd_soc_card_get_kcontrol_locked().
      
      codecs/cs35l56.c:
        cs35l56_sync_asp1_mixer_widgets_with_firmware() is called from
        control get()/put() functions so is changed to call
        snd_soc_card_get_kcontrol_locked().
      
      fsl/fsl_xcvr.c:
        fsl_xcvr_activate_ctl() is called from three places, one of which
        already holds card->controls_rwsem:
        1. fsl_xcvr_mode_put(), a control put function, which will
           already be holding card->controls_rwsem.
        2. fsl_xcvr_startup(), a DAI startup function.
        3. fsl_xcvr_shutdown(), a DAI shutdown function.
      
        To fix this, fsl_xcvr_activate_ctl() has been changed to call
        snd_soc_card_get_kcontrol_locked() so that it is safe to call
        directly from fsl_xcvr_mode_put().
        The fsl_xcvr_startup() and fsl_xcvr_shutdown() functions have been
        changed to take a read lock on card->controls_rsem() around calls
        to fsl_xcvr_activate_ctl(). While this is not very elegant, it
        keeps the change small, to avoid this patch creating a large
        collateral churn in fsl/fsl_xcvr.c.
      
      Analysis of other callers of snd_soc_card_get_kcontrol() is that
      they do not need any changes, they are not holding card->controls_rwsem
      when they call snd_soc_card_get_kcontrol().
      
      Direct callers of snd_soc_card_get_kcontrol():
        fsl/fsl_spdif.c: fsl_spdif_dai_probe() - DAI probe function
        fsl/fsl_micfil.c: voice_detected_fn() - IRQ handler
      
      Indirect callers via soc_component_notify_control():
        codecs/cs42l43: cs42l43_mic_shutter() - IRQ handler
        codecs/cs42l43: cs42l43_spk_shutter() - IRQ handler
        codecs/ak4118.c: ak4118_irq_handler() - IRQ handler
        codecs/wm_adsp.c: wm_adsp_write_ctl() - not currently used
      
      Indirect callers via snd_soc_limit_volume():
        qcom/sc8280xp.c: sc8280xp_snd_init() - DAIlink init function
        ti/rx51.c: rx51_aic34_init() - DAI init function
      
      I don't have hardware to test the fsl/*, qcom/sc828xp.c, ti/rx51.c
      and ak4118.c changes.
      
      Backport note:
      The fsl/, qcom/, cs35l45, cs35l56 and cs42l43 callers were added
      since the Fixes commit so won't all be present on older kernels.
      Signed-off-by: default avatarRichard Fitzgerald <rf@opensource.cirrus.com>
      Fixes: 209c6cdf ("ASoC: soc-card: move snd_soc_card_get_kcontrol() to soc-card")
      Link: https://lore.kernel.org/r/20240221123710.690224-1-rf@opensource.cirrus.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      eba2eb24
    • Gergo Koteles's avatar
      ALSA: hda/realtek: tas2781: enable subwoofer volume control · c1947ce6
      Gergo Koteles authored
      The volume of subwoofer channels is always at maximum with the
      ALC269_FIXUP_THINKPAD_ACPI chain.
      
      Use ALC285_FIXUP_THINKPAD_HEADSET_JACK to align it to the master volume.
      
      Link: https://bugzilla.kernel.org/show_bug.cgi?id=208555#c827
      
      Fixes: 3babae91 ("ALSA: hda/tas2781: Add tas2781 HDA driver")
      Cc: <stable@vger.kernel.org>
      Signed-off-by: default avatarGergo Koteles <soyer@irl.hu>
      Link: https://lore.kernel.org/r/7ffae10ebba58601d25fe2ff8381a6ae3a926e62.1708687813.git.soyer@irl.huSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      c1947ce6
    • Jaroslav Kysela's avatar
      ALSA: pcm: clarify and fix default msbits value for all formats · 85df6b5a
      Jaroslav Kysela authored
      Return used most significant bits from sample bit-width rather than the whole
      physical sample word size. The starting bit offset is defined in the format
      itself.
      
      The behaviour is not changed for 32-bit formats like S32_LE. But with this
      change - msbits value 24 instead 32 is returned for 24-bit formats like S24_LE
      etc.
      
      Also, commit 2112aa03 ("ALSA: pcm: Introduce MSBITS subformat interface")
      compares sample bit-width not physical sample bit-width to reset MSBITS_MAX bit
      from the subformat bitmask.
      
      Probably no applications are using msbits value for other than S32_LE/U32_LE
      formats, because no drivers are reducing msbits value for other formats (with
      the msb offset) at the moment.
      
      For sanity, increase PCM protocol version, letting the user space to detect
      the changed behaviour.
      Signed-off-by: default avatarJaroslav Kysela <perex@perex.cz>
      Link: https://lore.kernel.org/r/20240222173649.1447549-1-perex@perex.czSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      85df6b5a
  10. 21 Feb, 2024 3 commits
  11. 20 Feb, 2024 1 commit
  12. 19 Feb, 2024 4 commits
  13. 15 Feb, 2024 3 commits
  14. 14 Feb, 2024 3 commits
  15. 13 Feb, 2024 8 commits
  16. 12 Feb, 2024 2 commits