1. 19 Apr, 2024 1 commit
  2. 17 Apr, 2024 1 commit
  3. 15 Apr, 2024 1 commit
  4. 11 Apr, 2024 1 commit
  5. 09 Apr, 2024 15 commits
  6. 08 Apr, 2024 7 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
    • Hans de Goede's avatar
      ASoC: Intel: bytcr_rt5640: Apply Asus T100TA quirk to Asus T100TAM too · e50729d7
      Hans de Goede authored
      The Asus T100TA quirk has been using an exact match on a product-name of
      "T100TA" but there are also T100TAM variants with a slightly higher
      clocked CPU and a metal backside which need the same quirk.
      
      Sort the existing T100TA (stereo speakers) below the more specific
      T100TAF (mono speaker) quirk and switch from exact matching to
      substring matching so that the T100TA quirk will also match on
      the T100TAM models.
      Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
      Link: https://msgid.link/r/20240407191559.21596-1-hdegoede@redhat.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      e50729d7
    • Sameer Pujar's avatar
      ASoC: tegra: Fix DSPK 16-bit playback · 2e93a29b
      Sameer Pujar authored
      DSPK configuration is wrong for 16-bit playback and this happens because
      the client config is always fixed at 24-bit in hw_params(). Fix this by
      updating the client config to 16-bit for the respective playback.
      
      Fixes: 327ef647 ("ASoC: tegra: Add Tegra186 based DSPK driver")
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarSameer Pujar <spujar@nvidia.com>
      Acked-by: default avatarThierry Reding <treding@nvidia.com>
      Link: https://msgid.link/r/20240405104306.551036-1-spujar@nvidia.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      2e93a29b
    • Cezary Rojewski's avatar
      ASoC: Intel: avs: Fix debug window description · 7a1625c1
      Cezary Rojewski authored
      Recent changes addressed PAGE_SIZE ambiguity in 2/3 locations for struct
      avs_icl_memwnd2. The unaddressed one causes build errors when
      PAGE_SIZE != SZ_4K.
      Reported-by: default avatarkernel test robot <lkp@intel.com>
      Closes: https://lore.kernel.org/oe-kbuild-all/202404070100.i3t3Jf7d-lkp@intel.com/
      Fixes: 275b583d ("ASoC: Intel: avs: ICL-based platforms support")
      Signed-off-by: default avatarCezary Rojewski <cezary.rojewski@intel.com>
      Link: https://msgid.link/r/20240408081840.1319431-1-cezary.rojewski@intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
      7a1625c1
  7. 07 Apr, 2024 4 commits
  8. 06 Apr, 2024 10 commits
    • Linus Torvalds's avatar
      Merge tag 'nfsd-6.9-2' of git://git.kernel.org/pub/scm/linux/kernel/git/cel/linux · f2f80ac8
      Linus Torvalds authored
      Pull nfsd fixes from Chuck Lever:
      
       - Address a slow memory leak with RPC-over-TCP
      
       - Prevent another NFS4ERR_DELAY loop during CREATE_SESSION
      
      * tag 'nfsd-6.9-2' of git://git.kernel.org/pub/scm/linux/kernel/git/cel/linux:
        nfsd: hold a lighter-weight client reference over CB_RECALL_ANY
        SUNRPC: Fix a slow server-side memory leak with RPC-over-TCP
      f2f80ac8
    • Linus Torvalds's avatar
      Merge tag 'i2c-for-6.9-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux · cf17b950
      Linus Torvalds authored
      Pull i2c fix from Wolfram Sang:
       "A host driver build fix"
      
      * tag 'i2c-for-6.9-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux:
        i2c: pxa: hide unused icr_bits[] variable
      cf17b950
    • Linus Torvalds's avatar
      Merge tag 'xfs-6.9-fixes-2' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux · 9520c192
      Linus Torvalds authored
      Pull xfs fix from Chandan Babu:
      
       - Allow creating new links to special files which were not associated
         with a project quota
      
      * tag 'xfs-6.9-fixes-2' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux:
        xfs: allow cross-linking special files without project quota
      9520c192
    • Linus Torvalds's avatar
      Merge tag '6.9-rc2-smb3-client-fixes' of git://git.samba.org/sfrench/cifs-2.6 · 119c2894
      Linus Torvalds authored
      Pull smb client fixes from Steve French:
      
       - fix to retry close to avoid potential handle leaks when server
         returns EBUSY
      
       - DFS fixes including a fix for potential use after free
      
       - fscache fix
      
       - minor strncpy cleanup
      
       - reconnect race fix
      
       - deal with various possible UAF race conditions tearing sessions down
      
      * tag '6.9-rc2-smb3-client-fixes' of git://git.samba.org/sfrench/cifs-2.6:
        smb: client: fix potential UAF in cifs_signal_cifsd_for_reconnect()
        smb: client: fix potential UAF in smb2_is_network_name_deleted()
        smb: client: fix potential UAF in is_valid_oplock_break()
        smb: client: fix potential UAF in smb2_is_valid_oplock_break()
        smb: client: fix potential UAF in smb2_is_valid_lease_break()
        smb: client: fix potential UAF in cifs_stats_proc_show()
        smb: client: fix potential UAF in cifs_stats_proc_write()
        smb: client: fix potential UAF in cifs_dump_full_key()
        smb: client: fix potential UAF in cifs_debug_files_proc_show()
        smb3: retrying on failed server close
        smb: client: serialise cifs_construct_tcon() with cifs_mount_mutex
        smb: client: handle DFS tcons in cifs_construct_tcon()
        smb: client: refresh referral without acquiring refpath_lock
        smb: client: guarantee refcounted children from parent session
        cifs: Fix caching to try to do open O_WRONLY as rdwr on server
        smb: client: fix UAF in smb2_reconnect_server()
        smb: client: replace deprecated strncpy with strscpy
      119c2894
    • Borislav Petkov (AMD)'s avatar
      x86/retpoline: Add NOENDBR annotation to the SRSO dummy return thunk · b377c66a
      Borislav Petkov (AMD) authored
      srso_alias_untrain_ret() is special code, even if it is a dummy
      which is called in the !SRSO case, so annotate it like its real
      counterpart, to address the following objtool splat:
      
        vmlinux.o: warning: objtool: .export_symbol+0x2b290: data relocation to !ENDBR: srso_alias_untrain_ret+0x0
      
      Fixes: 4535e1a4 ("x86/bugs: Fix the SRSO mitigation on Zen3/4")
      Signed-off-by: default avatarBorislav Petkov (AMD) <bp@alien8.de>
      Signed-off-by: default avatarIngo Molnar <mingo@kernel.org>
      Cc: Linus Torvalds <torvalds@linux-foundation.org>
      Link: https://lore.kernel.org/r/20240405144637.17908-1-bp@kernel.org
      b377c66a
    • Ingo Molnar's avatar
      Merge branch 'linus' into x86/urgent, to pick up dependent commit · 5f2ca44e
      Ingo Molnar authored
      We want to fix:
      
        0e110732 ("x86/retpoline: Do the necessary fixup to the Zen3/4 srso return thunk for !SRSO")
      
      So merge in Linus's latest into x86/urgent to have it available.
      Signed-off-by: default avatarIngo Molnar <mingo@kernel.org>
      5f2ca44e
    • Wolfram Sang's avatar
      Merge tag 'i2c-host-fixes-6.9-rc3' of... · 5ceeabb0
      Wolfram Sang authored
      Merge tag 'i2c-host-fixes-6.9-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/andi.shyti/linux into i2c/for-current
      
      An unused const variable kind of error has been fixed by placing
      the definition of icr_bits[] inside the ifdef block where it is
      used.
      5ceeabb0
    • Linus Torvalds's avatar
      Merge tag 'firewire-fixes-6.9-rc2' of... · 6c6e47d6
      Linus Torvalds authored
      Merge tag 'firewire-fixes-6.9-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394
      
      Pull firewire fixes from Takashi Sakamoto:
       "The firewire-ohci kernel module has a parameter for verbose kernel
        logging. It is well-known that it logs the spurious IRQ for bus-reset
        event due to the unmasked register for IRQ event. This update fixes
        the issue"
      
      * tag 'firewire-fixes-6.9-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394:
        firewire: ohci: mask bus reset interrupts between ISR and bottom half
      6c6e47d6
    • Adam Goldman's avatar
      firewire: ohci: mask bus reset interrupts between ISR and bottom half · 752e3c53
      Adam Goldman authored
      In the FireWire OHCI interrupt handler, if a bus reset interrupt has
      occurred, mask bus reset interrupts until bus_reset_work has serviced and
      cleared the interrupt.
      
      Normally, we always leave bus reset interrupts masked. We infer the bus
      reset from the self-ID interrupt that happens shortly thereafter. A
      scenario where we unmask bus reset interrupts was introduced in 2008 in
      a007bb85: If
      OHCI_PARAM_DEBUG_BUSRESETS (8) is set in the debug parameter bitmask, we
      will unmask bus reset interrupts so we can log them.
      
      irq_handler logs the bus reset interrupt. However, we can't clear the bus
      reset event flag in irq_handler, because we won't service the event until
      later. irq_handler exits with the event flag still set. If the
      corresponding interrupt is still unmasked, the first bus reset will
      usually freeze the system due to irq_handler being called again each
      time it exits. This freeze can be reproduced by loading firewire_ohci
      with "modprobe firewire_ohci debug=-1" (to enable all debugging output).
      Apparently there are also some cases where bus_reset_work will get called
      soon enough to clear the event, and operation will continue normally.
      
      This freeze was first reported a few months after a007bb85 was committed,
      but until now it was never fixed. The debug level could safely be set
      to -1 through sysfs after the module was loaded, but this would be
      ineffectual in logging bus reset interrupts since they were only
      unmasked during initialization.
      
      irq_handler will now leave the event flag set but mask bus reset
      interrupts, so irq_handler won't be called again and there will be no
      freeze. If OHCI_PARAM_DEBUG_BUSRESETS is enabled, bus_reset_work will
      unmask the interrupt after servicing the event, so future interrupts
      will be caught as desired.
      
      As a side effect to this change, OHCI_PARAM_DEBUG_BUSRESETS can now be
      enabled through sysfs in addition to during initial module loading.
      However, when enabled through sysfs, logging of bus reset interrupts will
      be effective only starting with the second bus reset, after
      bus_reset_work has executed.
      Signed-off-by: default avatarAdam Goldman <adamg@pobox.com>
      Signed-off-by: default avatarTakashi Sakamoto <o-takashi@sakamocchi.jp>
      752e3c53
    • Linus Torvalds's avatar
      Merge tag 'spi-fix-v6.9-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi · 104db052
      Linus Torvalds authored
      Pull spi fixes from Mark Brown:
       "A few small driver specific fixes, the most important being the
        s3c64xx change which is likely to be hit during normal operation"
      
      * tag 'spi-fix-v6.9-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi:
        spi: mchp-pci1xxx: Fix a possible null pointer dereference in pci1xxx_spi_probe
        spi: spi-fsl-lpspi: remove redundant spi_controller_put call
        spi: s3c64xx: Use DMA mode from fifo size
      104db052