1. 10 May, 2024 2 commits
  2. 09 May, 2024 1 commit
  3. 06 May, 2024 1 commit
  4. 03 May, 2024 1 commit
    • Vijendar Mukunda's avatar
      ASoC: amd: acp: fix for acp platform device creation failure · 09068d62
      Vijendar Mukunda authored
      ACP pin configuration varies based on acp version.
      ACP PCI driver should read the ACP PIN config value and based on config
      value, it has to create a platform device in below two conditions.
      1) If ACP PDM configuration is selected from BIOS and ACP PDM controller
      exists.
      2) If ACP I2S configuration is selected from BIOS.
      
      Other than above scenarios, ACP PCI driver should skip the platform
      device creation logic, i.e. ACP PCI driver probe sequence should never
      fail if other acp pin configuration is selected. It should skip platform
      device creation logic.
      
      check_acp_pdm() function was implemented for ACP6.x platforms to check
      ACP PDM configuration. Previously, this code was safe guarded by
      FLAG_AMD_LEGACY_ONLY_DMIC flag check.
      
      This implementation breaks audio use cases for Huawei Matebooks which are
      based on ACP3.x varaint uses I2S configuration.
      In current scenario, check_acp_pdm() function returns -ENODEV value
      which results in ACP PCI driver probe failure without creating a platform
      device even in case of valid ACP pin configuration.
      
      Implement check_acp_config() as a common function which invokes platform
      specific acp pin configuration check functions for ACP3.x, ACP6.0 & ACP6.3
      & ACP7.0 variants and checks for ACP PDM controller.
      
      Closes: https://bugzilla.kernel.org/show_bug.cgi?id=218780
      Fixes: 4af565de ("ASoC: amd: acp: fix for acp pdm configuration check")
      Signed-off-by: default avatarVijendar Mukunda <Vijendar.Mukunda@amd.com>
      Link: https://lore.kernel.org/r/20240502140340.4049021-1-Vijendar.Mukunda@amd.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      09068d62
  5. 30 Apr, 2024 1 commit
    • Mark Brown's avatar
      ASoC: meson: tdm fixes · c5782bb5
      Mark Brown authored
      Merge series from Jerome Brunet <jbrunet@baylibre.com>:
      
      This patchset fixes 2 problems on TDM which both find a solution
      by properly implementing the .trigger() callback for the TDM backend.
      
      ATM, enabling the TDM formatters is done by the .prepare() callback
      because handling the formatter is slow due to necessary calls to CCF.
      
      The first problem affects the TDMIN. Because .prepare() is called on DPCM
      backend first, the formatter are started before the FIFOs and this may
      cause a random channel shifts if the TDMIN use multiple lanes with more
      than 2 slots per lanes. Using trigger() allows to set the FE/BE order,
      solving the problem.
      
      There has already been an attempt to fix this 3y ago [1] and reverted [2]
      It triggered a 'sleep in irq' error on the period IRQ. The solution is
      to just use the bottom half of threaded IRQ. This is patch #1. Patch #2
      and #3 remain mostly the same as 3y ago.
      
      For TDMOUT, the problem is on pause. ATM pause only stops the FIFO and
      the TDMOUT just starves. When it does, it will actually repeat the last
      sample continuously. Depending on the platform, if there is no high-pass
      filter on the analog path, this may translate to a constant position of
      the speaker membrane. There is no audible glitch but it may damage the
      speaker coil.
      
      Properly stopping the TDMOUT in pause solves the problem. There is
      behaviour change associated with that fix. Clocks used to be continuous
      on pause because of the problem above. They will now be gated on pause by
      default, as they should. The last change introduce the proper support for
      continuous clocks, if needed.
      
      [1]: https://lore.kernel.org/linux-amlogic/20211020114217.133153-1-jbrunet@baylibre.com
      [2]: https://lore.kernel.org/linux-amlogic/20220421155725.2589089-1-narmstrong@baylibre.com
      c5782bb5
  6. 29 Apr, 2024 7 commits
  7. 23 Apr, 2024 2 commits
  8. 20 Apr, 2024 1 commit
  9. 19 Apr, 2024 2 commits
    • Joao Paulo Goncalves's avatar
      ASoC: ti: davinci-mcasp: Fix race condition during probe · d18ca863
      Joao Paulo Goncalves authored
      When using davinci-mcasp as CPU DAI with simple-card, there are some
      conditions that cause simple-card to finish registering a sound card before
      davinci-mcasp finishes registering all sound components. This creates a
      non-working sound card from userspace with no problem indication apart
      from not being able to play/record audio on a PCM stream. The issue
      arises during simultaneous probe execution of both drivers. Specifically,
      the simple-card driver, awaiting a CPU DAI, proceeds as soon as
      davinci-mcasp registers its DAI. However, this process can lead to the
      client mutex lock (client_mutex in soc-core.c) being held or davinci-mcasp
      being preempted before PCM DMA registration on davinci-mcasp finishes.
      This situation occurs when the probes of both drivers run concurrently.
      Below is the code path for this condition. To solve the issue, defer
      davinci-mcasp CPU DAI registration to the last step in the audio part of
      it. This way, simple-card CPU DAI parsing will be deferred until all
      audio components are registered.
      
      Fail Code Path:
      
      simple-card.c: probe starts
      simple-card.c: simple_dai_link_of: simple_parse_node(..,cpu,..) returns EPROBE_DEFER, no CPU DAI yet
      davinci-mcasp.c: probe starts
      davinci-mcasp.c: devm_snd_soc_register_component() register CPU DAI
      simple-card.c: probes again, finish CPU DAI parsing and call devm_snd_soc_register_card()
      simple-card.c: finish probe
      davinci-mcasp.c: *dma_pcm_platform_register() register PCM  DMA
      davinci-mcasp.c: probe finish
      
      Cc: stable@vger.kernel.org
      Fixes: 9fbd58cf ("ASoC: davinci-mcasp: Choose PCM driver based on configured DMA controller")
      Signed-off-by: default avatarJoao Paulo Goncalves <joao.goncalves@toradex.com>
      Acked-by: default avatarPeter Ujfalusi <peter.ujfalusi@gmail.com>
      Reviewed-by: default avatarJai Luthra <j-luthra@ti.com>
      Link: https://lore.kernel.org/r/20240417184138.1104774-1-jpaulo.silvagoncalves@gmail.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      d18ca863
    • Amadeusz Sławiński's avatar
      ASoC: Intel: avs: Set name of control as in topology · 4cbb5050
      Amadeusz Sławiński authored
      When creating controls attached to widgets, there are a lot of rules if
      they get their name prefixed with widget name or not. Due to that
      controls ended up with weirdly looking names like "ssp0_fe DSP Volume",
      while topology set it to "DSP Volume".
      
      Fix this by setting no_wname_in_kcontrol_name to true in avs topology
      widgets which disables unwanted behaviour.
      
      Fixes: be2b81b5 ("ASoC: Intel: avs: Parse control tuples")
      Signed-off-by: default avatarAmadeusz Sławiński <amadeuszx.slawinski@linux.intel.com>
      Link: https://lore.kernel.org/r/20240418142621.2487478-1-amadeuszx.slawinski@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      4cbb5050
  10. 17 Apr, 2024 1 commit
  11. 15 Apr, 2024 1 commit
  12. 11 Apr, 2024 1 commit
  13. 09 Apr, 2024 15 commits
  14. 08 Apr, 2024 4 commits
    • Richard Fitzgerald's avatar
      ASoC: cs35l56: Prevent overwriting firmware ASP config · dfd2ffb3
      Richard Fitzgerald authored
      Only populate the ASP1 config registers in the regmap cache if the
      ASP DAI is used. This prevents regcache_sync() from overwriting
      these registers with their defaults when the firmware owns
      control of these registers.
      
      On a SoundWire system the ASP could be owned by the firmware to
      share reference audio with the firmware on other cs35l56. Or it
      can be used as a normal codec-codec interface owned by the driver.
      The driver must not overwrite the registers if the firmware has
      control of them.
      
      The original implementation for this in commit 07f7d6e7
      ("ASoC: cs35l56: Fix for initializing ASP1 mixer registers") was
      to still provide defaults for these registers, assuming that if
      they were never reconfigured from defaults then regcache_sync()
      would not write them out because they are not dirty. Unfortunately
      regcache_sync() is not that smart. If the chip has not reset (so
      the driver has not called regcache_mark_dirty()) a regcache_sync()
      could write out registers that are not dirty.
      
      To avoid accidental overwriting of the ASP registers, they are
      removed from the table of defaults and instead are populated with
      defaults only if one of the ASP DAI configuration functions is
      called. So if the DAI has never been configured, the firmware is
      assumed to have ownership of these registers, and the regmap cache
      will not contain any entries for them.
      Signed-off-by: default avatarRichard Fitzgerald <rf@opensource.cirrus.com>
      Fixes: 07f7d6e7 ("ASoC: cs35l56: Fix for initializing ASP1 mixer registers")
      Link: https://msgid.link/r/20240408101803.43183-5-rf@opensource.cirrus.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      dfd2ffb3
    • Richard Fitzgerald's avatar
      ASoC: cs35l56: Fix unintended bus access while resetting amp · d4884fd4
      Richard Fitzgerald authored
      Use the new regmap_read_bypassed() so that the regmap can be left
      in cache-only mode while it is booting, but the driver can still
      read boot-status and chip-id information during this time.
      
      This fixes race conditions where some writes could be issued to the
      silicon while it is still rebooting, before the driver has determined
      that the boot is complete.
      
      This is typically prevented by putting regmap into cache-only until the
      hardware is ready. But this assumes that the driver does not need to
      access device registers to determine when it is "ready". For cs35l56
      this involves polling a register and the original implementation relied
      on having special handlers to block racing callbacks until dsp_work()
      is complete. However, some cases were missed, most notably the ASP DAI
      functions.
      
      The regmap_read_bypassed() function allows the fix for this to be
      simplified to putting regmap into cache-only during the reset. The
      initial boot stages (poll HALO_STATE and read the chip ID) are all done
      bypassed. Only when the amp is seen to be booted is the cache-only
      revoked.
      
      Changes are:
      - cs35l56_system_reset() now leaves the regmap in cache-only status.
      
      - cs35l56_wait_for_firmware_boot() polls using regmap_read_bypassed().
      
      - cs35l56_init() revokes cache-only either via cs35l56_hw_init() or
        when firmware has rebooted after a soft reset.
      
      - cs35l56_hw_init() exits cache-only after it has determined that the
        amp has booted.
      
      - cs35l56_sdw_init() doesn't disable cache-only, since this must be
        deferred to cs35l56_init().
      
      - cs35l56_runtime_resume_common() waits for firmware boot before exiting
        cache-only.
      
      These changes cover three situations where the registers are not
      accessible:
      
      1) SoundWire first-time enumeration. The regmap is kept in cache-only
         until the chip is fully booted. The original code had to exit
         cache-only to read chip status in cs35l56_init() and cs35l56_hw_init()
         but this is now deferred to after the firmware has rebooted.
      
         In this case cs35l56_sdw_probe() leaves regmap in cache-only
         (unchanged behaviour) and cs35l56_hw_init() exits cache-only after the
         firmware is booted and the chip identified.
      
      2) Soft reset during first-time initialization. cs35l56_init() calls
         cs35l56_system_reset(), which puts regmap into cache-only.
         On I2C/SPI cs35l56_init() then flows through to call
         cs35l56_wait_for_firmware_boot() and exit cache-only. On SoundWire
         the re-enumeration will enter cs35l56_init() again, which then drops
         down to call cs35l56_wait_for_firmware_boot() and exit cache-only.
      
      3) Soft reset after firmware download. dsp_work() calls
         cs35l56_system_reset(), which puts regmap into cache-only. After this
         the flow is the same as (2).
      Signed-off-by: default avatarRichard Fitzgerald <rf@opensource.cirrus.com>
      Fixes: 8a731fd3 ("ASoC: cs35l56: Move utility functions to shared file")
      Link: https://msgid.link/r/20240408101803.43183-4-rf@opensource.cirrus.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      d4884fd4
    • Richard Fitzgerald's avatar
      ALSA: hda: cs35l56: Exit cache-only after cs35l56_wait_for_firmware_boot() · 73580ec6
      Richard Fitzgerald authored
      Adds calls to disable regmap cache-only after a successful return from
      cs35l56_wait_for_firmware_boot().
      
      This is to prepare for a change in the shared ASoC module that will
      leave regmap in cache-only mode after cs35l56_system_reset(). This is
      to prevent register accesses going to the hardware while it is
      rebooting.
      Signed-off-by: default avatarRichard Fitzgerald <rf@opensource.cirrus.com>
      Link: https://msgid.link/r/20240408101803.43183-3-rf@opensource.cirrus.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      73580ec6
    • Richard Fitzgerald's avatar
      regmap: Add regmap_read_bypassed() · 70ee853e
      Richard Fitzgerald authored
      Add a regmap_read_bypassed() to allow reads from the hardware registers
      while the regmap is in cache-only mode.
      
      A typical use for this is to keep the cache in cache-only mode until
      the hardware has reached a valid state, but one or more status registers
      must be polled to determine when this state is reached.
      
      For example, firmware download on the cs35l56 can take several seconds if
      there are multiple amps sharing limited bus bandwidth. This is too long
      to block in probe() so it is done as a background task. The device must
      be soft-reset to reboot the firmware and during this time the registers are
      not accessible, so the cache should be in cache-only. But the driver must
      poll a register to detect when reboot has completed.
      Signed-off-by: default avatarRichard Fitzgerald <rf@opensource.cirrus.com>
      Fixes: 8a731fd3 ("ASoC: cs35l56: Move utility functions to shared file")
      Link: https://msgid.link/r/20240408101803.43183-2-rf@opensource.cirrus.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      70ee853e