1. 01 Jul, 2024 1 commit
    • Richard Fitzgerald's avatar
      firmware: cs_dsp: Fix overflow checking of wmfw header · 3019b86b
      Richard Fitzgerald authored
      Fix the checking that firmware file buffer is large enough for the
      wmfw header, to prevent overrunning the buffer.
      
      The original code tested that the firmware data buffer contained
      enough bytes for the sums of the size of the structs
      
      	wmfw_header + wmfw_adsp1_sizes + wmfw_footer
      
      But wmfw_adsp1_sizes is only used on ADSP1 firmware. For ADSP2 and
      Halo Core the equivalent struct is wmfw_adsp2_sizes, which is
      4 bytes longer. So the length check didn't guarantee that there
      are enough bytes in the firmware buffer for a header with
      wmfw_adsp2_sizes.
      
      This patch splits the length check into three separate parts. Each
      of the wmfw_header, wmfw_adsp?_sizes and wmfw_footer are checked
      separately before they are used.
      Signed-off-by: default avatarRichard Fitzgerald <rf@opensource.cirrus.com>
      Fixes: f6bc909e ("firmware: cs_dsp: add driver to support firmware loading on Cirrus Logic DSPs")
      Link: https://patch.msgid.link/20240627141432.93056-2-rf@opensource.cirrus.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      3019b86b
  2. 26 Jun, 2024 2 commits
  3. 24 Jun, 2024 1 commit
    • Chen-Yu Tsai's avatar
      ASoC: mediatek: mt8195: Add platform entry for ETDM1_OUT_BE dai link · 282a4482
      Chen-Yu Tsai authored
      Commit e70b8dd2 ("ASoC: mediatek: mt8195: Remove afe-dai component
      and rework codec link") removed the codec entry for the ETDM1_OUT_BE
      dai link entirely instead of replacing it with COMP_EMPTY(). This worked
      by accident as the remaining COMP_EMPTY() platform entry became the codec
      entry, and the platform entry became completely empty, effectively the
      same as COMP_DUMMY() since snd_soc_fill_dummy_dai() doesn't do anything
      for platform entries.
      
      This causes a KASAN out-of-bounds warning in mtk_soundcard_common_probe()
      in sound/soc/mediatek/common/mtk-soundcard-driver.c:
      
      	for_each_card_prelinks(card, i, dai_link) {
      		if (adsp_node && !strncmp(dai_link->name, "AFE_SOF", strlen("AFE_SOF")))
      			dai_link->platforms->of_node = adsp_node;
      		else if (!dai_link->platforms->name && !dai_link->platforms->of_node)
      			dai_link->platforms->of_node = platform_node;
      	}
      
      where the code expects the platforms array to have space for at least one entry.
      
      Add an COMP_EMPTY() entry so that dai_link->platforms has space.
      
      Fixes: e70b8dd2 ("ASoC: mediatek: mt8195: Remove afe-dai component and rework codec link")
      Signed-off-by: default avatarChen-Yu Tsai <wenst@chromium.org>
      Reviewed-by: default avatarAngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
      Link: https://patch.msgid.link/20240624061257.3115467-1-wenst@chromium.orgSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      282a4482
  4. 20 Jun, 2024 1 commit
  5. 19 Jun, 2024 3 commits
  6. 18 Jun, 2024 1 commit
  7. 14 Jun, 2024 2 commits
    • Srinivas Kandagatla's avatar
      ASoC: q6apm-lpass-dai: close graph on prepare errors · be1fae62
      Srinivas Kandagatla authored
      There is an issue around with error handling and graph management with
      the exising code, none of the error paths close the graph, which result in
      leaving the loaded graph in dsp, however the driver thinks otherwise.
      
      This can have a nasty side effect specially when we try to load the same
      graph to dsp, dsp returns error which leaves the board with no sound and
      requires restart.
      
      Fix this by properly closing the graph when we hit errors between
      open and close.
      
      Fixes: 30ad723b ("ASoC: qdsp6: audioreach: add q6apm lpass dai support")
      Signed-off-by: default avatarSrinivas Kandagatla <srinivas.kandagatla@linaro.org>
      Reviewed-by: default avatarDmitry Baryshkov <dmitry.baryshkov@linaro.org>
      Tested-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> # X13s
      Link: https://lore.kernel.org/r/20240613-q6apm-fixes-v1-1-d88953675ab3@linaro.orgSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      be1fae62
    • Richard Fitzgerald's avatar
      ASoC: cs35l56: Disconnect ASP1 TX sources when ASP1 DAI is hooked up · 8af49868
      Richard Fitzgerald authored
      If the ASP1 DAI is hooked up by the machine driver the ASP TX mixer
      sources should be initialized to disconnected. There aren't currently
      any available products using the ASP so this doesn't affect any
      existing systems.
      
      The cs35l56 does not have any fixed default for the mixer source
      registers. When the cs35l56 boots, its firmware patches these registers
      to setup a system-specific routing; this is so that Windows can use
      generic SDCA drivers instead of needing knowledge of chip-specific
      registers. The setup varies between end-products, which each have
      customized firmware, and so the default register state varies between
      end-products. It can also change if the firmware on an end-product is
      upgraded - for example if a change was needed to the routing for Windows
      use-cases. It must be emphasized that the settings applied by the
      firmware are not internal magic tuning; they are statically implementing
      use-case setup that on Linux would be done via ALSA controls.
      
      The driver is currently syncing the mixer controls with whatever
      initial state the firmware wrote to the registers, so that they report
      the actual audio routing. But if the ASP DAI is hooked up this can create
      a powered-up DAPM graph without anything intentionally setting up a path.
      This can lead to parts of the audio system powering up unexpectedly.
      
      For example when cs35l56 is connected to cs42l43 using a codec-codec link,
      this can create a complete DAPM graph which then powers-up cs42l43. But
      the cs42l43 can only be clocked from its SoundWire bus so this causes a
      bunch of errors in the kernel log where cs42l43 is unexpectedly powered-up
      without a clock.
      
      If the host is taking ownership of the ASP (either directly or as a
      codec-to-codec link) there is no need to keep the mixer settings that the
      firmware wrote. The driver has ALSA controls for setting these using
      standard Linux mechanisms. So if the machine driver hooks up the ASP the
      ASP mixers are initialized to "None" (no input). This prevents unintended
      DAPM-graph power-ups, and means the initial state of the mixers is
      always going to be None.
      
      Since the initial state of the mixers can vary from system to system and
      potentially between firmware upgrades, no use-case manager can currently
      assume that cs35l56 has a known initial state. The firmware could just as
      easily default them to "None" as to any input source. So defaulting them
      to "None" in the driver is not increasing the entropy of the system.
      Signed-off-by: default avatarRichard Fitzgerald <rf@opensource.cirrus.com>
      Link: https://lore.kernel.org/r/20240613132527.46537-1-rf@opensource.cirrus.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      8af49868
  8. 13 Jun, 2024 1 commit
  9. 12 Jun, 2024 3 commits
  10. 11 Jun, 2024 4 commits
  11. 10 Jun, 2024 5 commits
  12. 06 Jun, 2024 1 commit
  13. 05 Jun, 2024 2 commits
  14. 04 Jun, 2024 4 commits
  15. 03 Jun, 2024 6 commits
  16. 02 Jun, 2024 3 commits
    • Linus Torvalds's avatar
      Linux 6.10-rc2 · c3f38fa6
      Linus Torvalds authored
      c3f38fa6
    • Linus Torvalds's avatar
      Merge tag 'ata-6.10-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/libata/linux · 58d89ee8
      Linus Torvalds authored
      Pull ata fixes from Niklas Cassel:
      
       - Add a quirk for three different devices that have shown issues with
         LPM (link power management). These devices appear to not implement
         LPM properly, since we see command timeouts when enabling LPM. The
         quirk disables LPM for these problematic devices. (Me)
      
       - Do not apply the Intel PCS quirk on Alder Lake. The quirk is not
         needed and was originally added by mistake when LPM support was
         enabled for this AHCI controller. Enabling the quirk when not needed
         causes the the controller to not be able to detect the connected
         devices on some platforms.
      
      * tag 'ata-6.10-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/libata/linux:
        ata: libata-core: Add ATA_HORKAGE_NOLPM for Apacer AS340
        ata: libata-core: Add ATA_HORKAGE_NOLPM for AMD Radeon S3 SSD
        ata: libata-core: Add ATA_HORKAGE_NOLPM for Crucial CT240BX500SSD1
        ata: ahci: Do not apply Intel PCS quirk on Intel Alder Lake
      58d89ee8
    • Linus Torvalds's avatar
      Merge tag 'x86-urgent-2024-06-02' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · a693b9c9
      Linus Torvalds authored
      Pull x86 fixes from Ingo Molnar:
       "Miscellaneous topology parsing fixes:
      
         - Fix topology parsing regression on older CPUs in the new AMD/Hygon
           parser
      
         - Fix boot crash on odd Intel Quark and similar CPUs that do not fill
           out cpuinfo_x86::x86_clflush_size and zero out
           cpuinfo_x86::x86_cache_alignment as a result.
      
           Provide 32 bytes as a general fallback value.
      
         - Fix topology enumeration on certain rare CPUs where the BIOS locks
           certain CPUID leaves and the kernel unlocked them late, which broke
           with the new topology parsing code. Factor out this unlocking logic
           and move it earlier in the parsing sequence"
      
      * tag 'x86-urgent-2024-06-02' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/topology/intel: Unlock CPUID before evaluating anything
        x86/cpu: Provide default cache line size if not enumerated
        x86/topology/amd: Evaluate SMT in CPUID leaf 0x8000001e only on family 0x17 and greater
      a693b9c9