1. 25 Oct, 2023 5 commits
    • Hans de Goede's avatar
      HID: logitech-hidpp: Move g920_get_config() to just before hidpp_ff_init() · 219ccfb6
      Hans de Goede authored
      The data retrieved by g920_get_config() is only used by hidpp_ff_init().
      
      Now that the hw is kept open till the end of probe() the g920_get_config()
      call can be moved to just before hidpp_ff_init() to have all
      the HIDPP_QUIRK_CLASS_G920 together in a single place.
      
      This series has been tested on the following devices:
      Logitech Bluetooth Laser Travel Mouse (bluetooth, HID++ 1.0)
      Logitech M720 Triathlon (bluetooth, HID++ 4.5)
      Logitech M720 Triathlon (unifying, HID++ 4.5)
      Logitech K400 Pro (unifying, HID++ 4.1)
      Logitech K270 (eQUAD nano Lite, HID++ 2.0)
      Logitech M185 (eQUAD nano Lite, HID++ 4.5)
      Logitech LX501 keyboard (27 Mhz, HID++ builtin scroll-wheel, HID++ 1.0)
      Logitech M-RAZ105 mouse (27 Mhz, HID++ extra mouse buttons, HID++ 1.0)
      
      And by bentiss:
      Logitech Touchpad T650 (unifying)
      Logitech Touchpad T651 (bluetooth)
      Logitech MX Master 3B (BLE)
      Logitech G403 (plain USB / Gaming receiver)
      Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
      Link: https://lore.kernel.org/r/20231010102029.111003-6-hdegoede@redhat.comSigned-off-by: default avatarBenjamin Tissoires <bentiss@kernel.org>
      219ccfb6
    • Hans de Goede's avatar
      HID: logitech-hidpp: Remove wtp_get_config() call from probe() · a3643036
      Hans de Goede authored
      For WTP devices which start disconnected (paired with the unifying
      receiver, but not connected atm) hidpp_connect_event() takes care
      of calling wtp_get_config() when the device later connects.
      
      There is no need to have a separate code path for WTP devices which
      are connected at probe() time, these can use the same code-path since
      probe() will queue hidpp_connect_event() for those at probe time.
      
      Drop the unnecessary wtp_get_config() call from probe().
      
      This series has been tested on the following devices:
      Logitech Bluetooth Laser Travel Mouse (bluetooth, HID++ 1.0)
      Logitech M720 Triathlon (bluetooth, HID++ 4.5)
      Logitech M720 Triathlon (unifying, HID++ 4.5)
      Logitech K400 Pro (unifying, HID++ 4.1)
      Logitech K270 (eQUAD nano Lite, HID++ 2.0)
      Logitech M185 (eQUAD nano Lite, HID++ 4.5)
      Logitech LX501 keyboard (27 Mhz, HID++ builtin scroll-wheel, HID++ 1.0)
      Logitech M-RAZ105 mouse (27 Mhz, HID++ extra mouse buttons, HID++ 1.0)
      
      And by bentiss:
      Logitech Touchpad T650 (unifying)
      Logitech Touchpad T651 (bluetooth)
      Logitech MX Master 3B (BLE)
      Logitech G403 (plain USB / Gaming receiver)
      Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
      Link: https://lore.kernel.org/r/20231010102029.111003-5-hdegoede@redhat.comSigned-off-by: default avatarBenjamin Tissoires <bentiss@kernel.org>
      a3643036
    • Hans de Goede's avatar
      HID: logitech-hidpp: Move get_wireless_feature_index() check to hidpp_connect_event() · ba9de350
      Hans de Goede authored
      Calling get_wireless_feature_index() from probe() causes
      the wireless_feature_index to only get set for unifying devices which
      are already connected at probe() time. It does not get set for devices
      which connect later.
      
      Fix this by moving get_wireless_feature_index() to hidpp_connect_event(),
      this does not make a difference for devices connected at probe() since
      probe() will queue the hidpp_connect_event() for those at probe time.
      
      This series has been tested on the following devices:
      Logitech Bluetooth Laser Travel Mouse (bluetooth, HID++ 1.0)
      Logitech M720 Triathlon (bluetooth, HID++ 4.5)
      Logitech M720 Triathlon (unifying, HID++ 4.5)
      Logitech K400 Pro (unifying, HID++ 4.1)
      Logitech K270 (eQUAD nano Lite, HID++ 2.0)
      Logitech M185 (eQUAD nano Lite, HID++ 4.5)
      Logitech LX501 keyboard (27 Mhz, HID++ builtin scroll-wheel, HID++ 1.0)
      Logitech M-RAZ105 mouse (27 Mhz, HID++ extra mouse buttons, HID++ 1.0)
      
      And by bentiss:
      Logitech Touchpad T650 (unifying)
      Logitech Touchpad T651 (bluetooth)
      Logitech MX Master 3B (BLE)
      Logitech G403 (plain USB / Gaming receiver)
      
      Fixes: 0da0a63b ("HID: logitech-hidpp: Support WirelessDeviceStatus connect events")
      Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
      Link: https://lore.kernel.org/r/20231010102029.111003-4-hdegoede@redhat.comSigned-off-by: default avatarBenjamin Tissoires <bentiss@kernel.org>
      ba9de350
    • Hans de Goede's avatar
      HID: logitech-hidpp: Revert "Don't restart communication if not necessary" · 55bf7036
      Hans de Goede authored
      Commit 91cf9a98 ("HID: logitech-hidpp: make .probe usbhid capable")
      makes hidpp_probe() first call hid_hw_start(hdev, 0) to allow IO
      without connecting any hid subdrivers (hid-input, hidraw).
      
      This is done to allow to retrieve the device's name and serial number
      and store these in hdev->name and hdev->uniq.
      
      Then later on IO was stopped and started again with hid_hw_start(hdev,
      HID_CONNECT_DEFAULT) connecting hid-input and hidraw after the name
      and serial number have been setup.
      
      Commit 498ba206 ("HID: logitech-hidpp: Don't restart communication
      if not necessary") changed the probe() code to only do the start with
      a 0 connect-mask + restart later for unifying devices.
      
      But for non unifying devices hdev->name and hdev->uniq are updated too.
      So this change re-introduces the problem for which the start with
      a 0 connect-mask + restart later behavior was introduced.
      
      The previous patch in this series changes the unifying path to instead of
      restarting IO only call hid_connect() later. This avoids possible issues
      with restarting IO seen on non unifying devices.
      
      Revert the change to limit the restart behavior to unifying devices to
      fix hdev->name changing after userspace facing devices have already been
      registered.
      
      This series has been tested on the following devices:
      Logitech Bluetooth Laser Travel Mouse (bluetooth, HID++ 1.0)
      Logitech M720 Triathlon (bluetooth, HID++ 4.5)
      Logitech M720 Triathlon (unifying, HID++ 4.5)
      Logitech K400 Pro (unifying, HID++ 4.1)
      Logitech K270 (eQUAD nano Lite, HID++ 2.0)
      Logitech M185 (eQUAD nano Lite, HID++ 4.5)
      Logitech LX501 keyboard (27 Mhz, HID++ builtin scroll-wheel, HID++ 1.0)
      Logitech M-RAZ105 mouse (27 Mhz, HID++ extra mouse buttons, HID++ 1.0)
      
      And by bentiss:
      Logitech Touchpad T650 (unifying)
      Logitech Touchpad T651 (bluetooth)
      Logitech MX Master 3B (BLE)
      Logitech G403 (plain USB / Gaming receiver)
      
      Fixes: 498ba206 ("HID: logitech-hidpp: Don't restart communication if not necessary")
      Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
      Link: https://lore.kernel.org/r/20231010102029.111003-3-hdegoede@redhat.comSigned-off-by: default avatarBenjamin Tissoires <bentiss@kernel.org>
      55bf7036
    • Hans de Goede's avatar
      HID: logitech-hidpp: Don't restart IO, instead defer hid_connect() only · 11ca0322
      Hans de Goede authored
      Restarting IO causes 2 problems:
      
      1. Some devices do not like IO being restarted this was addressed in
         commit 498ba206 ("HID: logitech-hidpp: Don't restart communication
         if not necessary"), but that change has issues of its own and needs to
         be reverted.
      
      2. Restarting IO and specifically calling hid_device_io_stop() causes
         received packets to be missed, which may cause connect-events to
         get missed.
      
      Restarting IO was introduced in commit 91cf9a98 ("HID: logitech-hidpp:
      make .probe usbhid capable") to allow to retrieve the device's name and
      serial number and store these in hdev->name and hdev->uniq before
      connecting any hid subdrivers (hid-input, hidraw) exporting this info
      to userspace.
      
      But this does not require restarting IO, this merely requires deferring
      calling hid_connect(). Calling hid_hw_start() with a connect-mask of
      0 makes it skip calling hid_connect(), so hidpp_probe() can simply call
      hid_connect() later without needing to restart IO.
      
      Remove the stop + restart of IO and instead just call hid_connect() later
      to avoid the issues caused by restarting IO.
      
      Now that IO is no longer stopped, hid_hw_close() must be called at the end
      of probe() to balance the hid_hw_open() done at the beginning probe().
      
      This series has been tested on the following devices:
      Logitech Bluetooth Laser Travel Mouse (bluetooth, HID++ 1.0)
      Logitech M720 Triathlon (bluetooth, HID++ 4.5)
      Logitech M720 Triathlon (unifying, HID++ 4.5)
      Logitech K400 Pro (unifying, HID++ 4.1)
      Logitech K270 (eQUAD nano Lite, HID++ 2.0)
      Logitech M185 (eQUAD nano Lite, HID++ 4.5)
      Logitech LX501 keyboard (27 Mhz, HID++ builtin scroll-wheel, HID++ 1.0)
      Logitech M-RAZ105 mouse (27 Mhz, HID++ extra mouse buttons, HID++ 1.0)
      
      And by bentiss:
      Logitech Touchpad T650 (unifying)
      Logitech Touchpad T651 (bluetooth)
      Logitech MX Master 3B (BLE)
      Logitech G403 (plain USB / Gaming receiver)
      
      Fixes: 498ba206 ("HID: logitech-hidpp: Don't restart communication if not necessary")
      Suggested-by: default avatarBenjamin Tissoires <bentiss@kernel.org>
      Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
      Link: https://lore.kernel.org/r/20231010102029.111003-2-hdegoede@redhat.comSigned-off-by: default avatarBenjamin Tissoires <bentiss@kernel.org>
      11ca0322
  2. 11 Oct, 2023 3 commits
  3. 10 Oct, 2023 7 commits
    • Linus Torvalds's avatar
      Merge tag 'xsa441-6.6-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip · 1c8b86a3
      Linus Torvalds authored
      Pull xen fix from Juergen Gross:
       "A fix for the xen events driver:
      
        Closing of an event channel in the Linux kernel can result in a
        deadlock. This happens when the close is being performed in parallel
        to an unrelated Xen console action and the handling of a Xen console
        interrupt in an unprivileged guest.
      
        The closing of an event channel is e.g. triggered by removal of a
        paravirtual device on the other side. As this action will cause
        console messages to be issued on the other side quite often, the
        chance of triggering the deadlock is not negligible"
      
      * tag 'xsa441-6.6-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip:
        xen/events: replace evtchn_rwlock with RCU
      1c8b86a3
    • Sumit Garg's avatar
      KEYS: trusted: Remove redundant static calls usage · 01bbafc6
      Sumit Garg authored
      Static calls invocations aren't well supported from module __init and
      __exit functions. Especially the static call from cleanup_trusted() led
      to a crash on x86 kernel with CONFIG_DEBUG_VIRTUAL=y.
      
      However, the usage of static call invocations for trusted_key_init()
      and trusted_key_exit() don't add any value from either a performance or
      security perspective. Hence switch to use indirect function calls instead.
      
      Note here that although it will fix the current crash report, ultimately
      the static call infrastructure should be fixed to either support its
      future usage from module __init and __exit functions or not.
      Reported-and-tested-by: default avatarHyeonggon Yoo <42.hyeyoo@gmail.com>
      Link: https://lore.kernel.org/lkml/ZRhKq6e5nF%2F4ZIV1@fedora/#t
      Fixes: 5d0682be ("KEYS: trusted: Add generic trusted keys framework")
      Signed-off-by: default avatarSumit Garg <sumit.garg@linaro.org>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      01bbafc6
    • Linus Torvalds's avatar
      Merge tag 'irq-urgent-2023-10-10-v2' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 87813e13
      Linus Torvalds authored
      Pull irq fixes from Thomas Gleixner:
       "A set of updates for interrupt chip drivers:
      
         - Fix the fail of the Qualcomm PDC driver on v3.2 hardware which is
           caused by a control bit being moved to a different location
      
         - Update the SM8150 device tree PDC resource so the version register
           can be read
      
         - Make the Renesas RZG2L driver correct for interrupts which are
           outside of the LSB in the TSSR register by using the proper macro
           for calculating the mask
      
         - Document the Renesas RZ2GL device tree binding correctly and update
           them for a few devices which faul to boot otherwise
      
         - Use the proper accessor in the RZ2GL driver instead of blindly
           dereferencing an unchecked pointer
      
         - Make GICv3 handle the dma-non-coherent attribute correctly
      
         - Ensure that all interrupt controller nodes on RISCV are marked as
           initialized correctly
      
        Maintainer changes:
      
         - Add a new entry for GIC interrupt controllers and assign Marc
           Zyngier as the maintainer
      
         - Remove Marc Zyngier from the core and driver maintainer entries as
           he is burried in work and short of time to handle that.
      
        Thanks to Marc for all the great work he has done in the past couple
        of years!
      
        Also note that commit 5873d380 ("irqchip/qcom-pdc: Add support for
        v3.2 HW") has a incorrect SOB chain.
      
        The real author is Neil. His patch was posted by Dmitry once and Neil
        picked it up from the list and reposted it with the bogus SOB chain.
      
        Not a big deal, but worth to mention. I wanted to fix that up, but
        then got distracted and Marc piled more changes on top. So I decided
        to leave it as is instead of rebasing world"
      
      * tag 'irq-urgent-2023-10-10-v2' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        MAINTAINERS: Remove myself from the general IRQ subsystem maintenance
        MAINTAINERS: Add myself as the ARM GIC maintainer
        irqchip/renesas-rzg2l: Convert to irq_data_get_irq_chip_data()
        irqchip/stm32-exti: add missing DT IRQ flag translation
        irqchip/riscv-intc: Mark all INTC nodes as initialized
        irqchip/gic-v3: Enable non-coherent redistributors/ITSes DT probing
        irqchip/gic-v3-its: Split allocation from initialisation of its_node
        dt-bindings: interrupt-controller: arm,gic-v3: Add dma-noncoherent property
        dt-bindings: interrupt-controller: renesas,irqc: Add r8a779f0 support
        dt-bindings: interrupt-controller: renesas,rzg2l-irqc: Document RZ/G2UL SoC
        irqchip: renesas-rzg2l: Fix logic to clear TINT interrupt source
        dt-bindings: interrupt-controller: renesas,rzg2l-irqc: Update description for '#interrupt-cells' property
        arm64: dts: qcom: sm8150: extend the size of the PDC resource
        irqchip/qcom-pdc: Add support for v3.2 HW
      87813e13
    • Linus Torvalds's avatar
      Merge tag 'hyperv-fixes-signed-20231009' of... · b711538a
      Linus Torvalds authored
      Merge tag 'hyperv-fixes-signed-20231009' of git://git.kernel.org/pub/scm/linux/kernel/git/hyperv/linux
      
      Pull hyperv fixes from Wei Liu:
      
       - fixes for Hyper-V VTL code (Saurabh Sengar and Olaf Hering)
      
       - fix hv_kvp_daemon to support keyfile based connection profile
         (Shradha Gupta)
      
      * tag 'hyperv-fixes-signed-20231009' of git://git.kernel.org/pub/scm/linux/kernel/git/hyperv/linux:
        hv/hv_kvp_daemon:Support for keyfile based connection profile
        hyperv: reduce size of ms_hyperv_info
        x86/hyperv: Add common print prefix "Hyper-V" in hv_init
        x86/hyperv: Remove hv_vtl_early_init initcall
        x86/hyperv: Restrict get_vtl to only VTL platforms
      b711538a
    • Linus Torvalds's avatar
      Merge tag 'v6.6-p4' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6 · 832b5d0b
      Linus Torvalds authored
      Pull crypto fix from Herbert Xu:
       "Fix a regression in dm-crypt"
      
      * tag 'v6.6-p4' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6:
        dm crypt: Fix reqsize in crypt_iv_eboiv_gen
      832b5d0b
    • Linus Torvalds's avatar
      Merge tag 'sound-6.6-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound · 68d187ec
      Linus Torvalds authored
      Pull sound fixes from Takashi Iwai:
       "A collection of pending fixes since a couple of weeks ago, which
        became slightly bigger than usual due to my vacation.
      
        Most of changes are about ASoC device-specific fixes while USB- and
        HD-audio received quirks as usual. All fixes, including two ASoC core
        changes, are reasonably small and safe to apply"
      
      * tag 'sound-6.6-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: (23 commits)
        ALSA: usb-audio: Fix microphone sound on Nexigo webcam.
        ALSA: hda/realtek: Change model for Intel RVP board
        ALSA: usb-audio: Fix microphone sound on Opencomm2 Headset
        ALSA: hda: cs35l41: Cleanup and fix double free in firmware request
        ASoC: dt-bindings: fsl,micfil: Document #sound-dai-cells
        ASoC: amd: yc: Fix non-functional mic on Lenovo 82YM
        ASoC: tlv320adc3xxx: BUG: Correct micbias setting
        ASoC: rt5682: Fix regulator enable/disable sequence
        ASoC: hdmi-codec: Fix broken channel map reporting
        ASoC: core: Do not call link_exit() on uninitialized rtd objects
        ASoC: core: Print component name when printing log
        ASoC: SOF: amd: fix for firmware reload failure after playback
        ASoC: fsl-asoc-card: use integer type for fll_id and pll_id
        ASoC: fsl_sai: Don't disable bitclock for i.MX8MP
        dt-bindings: ASoC: rockchip: Add compatible for RK3128 spdif
        ASoC: soc-generic-dmaengine-pcm: Fix function name in comment
        ALSA: hda/realtek - ALC287 merge RTK codec with CS CS35L41 AMP
        ASoC: simple-card: fixup asoc_simple_probe() error handling
        ASoC: simple-card-utils: fixup simple_util_startup() error handling
        ASoC: Intel: sof_sdw: add support for SKU 0B14
        ...
      68d187ec
    • Shradha Gupta's avatar
      hv/hv_kvp_daemon:Support for keyfile based connection profile · 42999c90
      Shradha Gupta authored
      Ifcfg config file support in NetworkManger is deprecated. This patch
      provides support for the new keyfile config format for connection
      profiles in NetworkManager. The patch modifies the hv_kvp_daemon code
      to generate the new network configuration in keyfile
      format(.ini-style format) along with a ifcfg format configuration.
      The ifcfg format configuration is also retained to support easy
      backward compatibility for distro vendors. These configurations are
      stored in temp files which are further translated using the
      hv_set_ifconfig.sh script. This script is implemented by individual
      distros based on the network management commands supported.
      For example, RHEL's implementation could be found here:
      https://gitlab.com/redhat/centos-stream/src/hyperv-daemons/-/blob/c9s/hv_set_ifconfig.sh
      Debian's implementation could be found here:
      https://github.com/endlessm/linux/blob/master/debian/cloud-tools/hv_set_ifconfig
      
      The next part of this support is to let the Distro vendors consume
      these modified implementations to the new configuration format.
      
      Tested-on: Rhel9(Hyper-V, Azure)(nm and ifcfg files verified)
      Signed-off-by: default avatarShradha Gupta <shradhagupta@linux.microsoft.com>
      Reviewed-by: default avatarSaurabh Sengar <ssengar@linux.microsoft.com>
      Reviewed-by: default avatarAni Sinha <anisinha@redhat.com>
      Signed-off-by: default avatarWei Liu <wei.liu@kernel.org>
      Link: https://lore.kernel.org/r/1696847920-31125-1-git-send-email-shradhagupta@linux.microsoft.com
      42999c90
  4. 09 Oct, 2023 4 commits
    • Thomas Gleixner's avatar
      Merge tag 'irqchip-fixes-6.6-2' of... · 4dc5af1f
      Thomas Gleixner authored
      Merge tag 'irqchip-fixes-6.6-2' of git://git.kernel.org/pub/scm/linux/kernel/git/maz/arm-platforms into irq/urgent
      
      Pull irqchip fixes from Marc Zyngier:
      
        - DT binding updates for Renesas r8a779f0 and rzg2l
      
        - Let GICv3 honor the "dma-non-coherent" attribute for systems that
          rely on SW guessing what the HW supports
      
        - Fix the RISC-V INTC probing by marking all devices as initialised
          at once
      
        - Properly translate interrupt numbers from DT on stm32-exti
      
        - Use irq_data_get_irq_chip_data() in the rzg2l driver instead of
          blindly dereferencing the irq_data structure
      
        - Add a MAINTAINERS entry for the various ARM GIC irqchip drivers
      
        - Remove myself as the top-level irqchip/irqdomain maintainer
      
      Link: https://lore.kernel.org/all/20231007121933.3840357-1-maz@kernel.org
      4dc5af1f
    • John Ogness's avatar
      printk: flush consoles before checking progress · 054c22bd
      John Ogness authored
      Commit 9e70a5e1 ("printk: Add per-console suspended state")
      removed console lock usage during resume and replaced it with
      the clearly defined console_list_lock and srcu mechanisms.
      
      However, the console lock usage had an important side-effect
      of flushing the consoles. After its removal, consoles were no
      longer flushed before checking their progress.
      
      Add the console_lock/console_unlock dance to the beginning
      of __pr_flush() to actually flush the consoles before checking
      their progress. Also add comments to clarify this additional
      usage of the console lock.
      
      Note that console_unlock() does not guarantee flushing all messages
      since the commit dbdda842 ("printk: Add console owner and waiter
      logic to load balance console writes").
      Reported-by: default avatarTodd Brandt <todd.e.brandt@intel.com>
      Closes: https://bugzilla.kernel.org/show_bug.cgi?id=217955
      Fixes: 9e70a5e1 ("printk: Add per-console suspended state")
      Co-developed-by: default avatarPetr Mladek <pmladek@suse.com>
      Signed-off-by: default avatarPetr Mladek <pmladek@suse.com>
      Signed-off-by: default avatarJohn Ogness <john.ogness@linutronix.de>
      Link: https://lore.kernel.org/r/20231006082151.6969-2-pmladek@suse.com
      054c22bd
    • Juergen Gross's avatar
      xen/events: replace evtchn_rwlock with RCU · 87797fad
      Juergen Gross authored
      In unprivileged Xen guests event handling can cause a deadlock with
      Xen console handling. The evtchn_rwlock and the hvc_lock are taken in
      opposite sequence in __hvc_poll() and in Xen console IRQ handling.
      Normally this is no problem, as the evtchn_rwlock is taken as a reader
      in both paths, but as soon as an event channel is being closed, the
      lock will be taken as a writer, which will cause read_lock() to block:
      
      CPU0                     CPU1                CPU2
      (IRQ handling)           (__hvc_poll())      (closing event channel)
      
      read_lock(evtchn_rwlock)
                               spin_lock(hvc_lock)
                                                   write_lock(evtchn_rwlock)
                                                       [blocks]
      spin_lock(hvc_lock)
          [blocks]
                              read_lock(evtchn_rwlock)
                                  [blocks due to writer waiting,
                                   and not in_interrupt()]
      
      This issue can be avoided by replacing evtchn_rwlock with RCU in
      xen_free_irq(). Note that RCU is used only to delay freeing of the
      irq_info memory. There is no RCU based dereferencing or replacement of
      pointers involved.
      
      In order to avoid potential races between removing the irq_info
      reference and handling of interrupts, set the irq_info pointer to NULL
      only when freeing its memory. The IRQ itself must be freed at that
      time, too, as otherwise the same IRQ number could be allocated again
      before handling of the old instance would have been finished.
      
      This is XSA-441 / CVE-2023-34324.
      
      Fixes: 54c9de89 ("xen/events: add a new "late EOI" evtchn framework")
      Reported-by: default avatarMarek Marczykowski-Górecki <marmarek@invisiblethingslab.com>
      Signed-off-by: default avatarJuergen Gross <jgross@suse.com>
      Reviewed-by: default avatarJulien Grall <jgrall@amazon.com>
      Signed-off-by: default avatarJuergen Gross <jgross@suse.com>
      87797fad
    • Christos Skevis's avatar
      ALSA: usb-audio: Fix microphone sound on Nexigo webcam. · 4a63e68a
      Christos Skevis authored
      I own an external usb Webcam, model NexiGo N930AF, which had low mic volume and
      inconsistent sound quality. Video works as expected.
      
      (snip)
      [  +0.047857] usb 5-1: new high-speed USB device number 2 using xhci_hcd
      [  +0.003406] usb 5-1: New USB device found, idVendor=1bcf, idProduct=2283, bcdDevice=12.17
      [  +0.000007] usb 5-1: New USB device strings: Mfr=1, Product=2, SerialNumber=3
      [  +0.000004] usb 5-1: Product: NexiGo N930AF FHD Webcam
      [  +0.000003] usb 5-1: Manufacturer: SHENZHEN AONI ELECTRONIC CO., LTD
      [  +0.000004] usb 5-1: SerialNumber: 20201217011
      [  +0.003900] usb 5-1: Found UVC 1.00 device NexiGo N930AF FHD Webcam (1bcf:2283)
      [  +0.025726] usb 5-1: 3:1: cannot get usb sound sample rate freq at ep 0x86
      [  +0.071482] usb 5-1: 3:2: cannot get usb sound sample rate freq at ep 0x86
      [  +0.004679] usb 5-1: 3:3: cannot get usb sound sample rate freq at ep 0x86
      [  +0.051607] usb 5-1: Warning! Unlikely big volume range (=4096), cval->res is probably wrong.
      [  +0.000005] usb 5-1: [7] FU [Mic Capture Volume] ch = 1, val = 0/4096/1
      
      Set up quirk cval->res to 16 for 256 levels,
      Set GET_SAMPLE_RATE quirk flag to stop trying to get the sample rate.
      Confirmed that happened anyway later due to the backoff mechanism, after 3 failures
      
      All audio stream on device interfaces share the same values,
      apart from wMaxPacketSize and tSamFreq :
      
      (snip)
      Interface Descriptor:
            bLength                 9
            bDescriptorType         4
            bInterfaceNumber        3
            bAlternateSetting       3
            bNumEndpoints           1
            bInterfaceClass         1 Audio
            bInterfaceSubClass      2 Streaming
            bInterfaceProtocol      0
            iInterface              0
            AudioStreaming Interface Descriptor:
              bLength                 7
              bDescriptorType        36
              bDescriptorSubtype      1 (AS_GENERAL)
              bTerminalLink           8
              bDelay                  1 frames
              wFormatTag         0x0001 PCM
            AudioStreaming Interface Descriptor:
              bLength                11
              bDescriptorType        36
              bDescriptorSubtype      2 (FORMAT_TYPE)
              bFormatType             1 (FORMAT_TYPE_I)
              bNrChannels             1
              bSubframeSize           2
              bBitResolution         16
              bSamFreqType            1 Discrete
              tSamFreq[ 0]        44100
            Endpoint Descriptor:
              bLength                 9
              bDescriptorType         5
              bEndpointAddress     0x86  EP 6 IN
              bmAttributes            5
                Transfer Type            Isochronous
                Synch Type               Asynchronous
                Usage Type               Data
              wMaxPacketSize     0x005c  1x 92 bytes
              bInterval               4
              bRefresh                0
              bSynchAddress           0
              AudioStreaming Endpoint Descriptor:
                bLength                 7
                bDescriptorType        37
                bDescriptorSubtype      1 (EP_GENERAL)
                bmAttributes         0x01
                  Sampling Frequency
                bLockDelayUnits         0 Undefined
                wLockDelay         0x0000
      (snip)
      
      Based on the usb data about manufacturer, SPCA2281B3 is the most likely controller IC
      Manufacturer does not provide link for datasheet nor detailed specs.
      No way to confirm if the firmware supports any other way of getting the sample rate.
      
      Testing patch provides consistent good sound recording quality and volume range.
      
      (snip)
      [  +0.045764] usb 5-1: new high-speed USB device number 2 using xhci_hcd
      [  +0.106290] usb 5-1: New USB device found, idVendor=1bcf, idProduct=2283, bcdDevice=12.17
      [  +0.000006] usb 5-1: New USB device strings: Mfr=1, Product=2, SerialNumber=3
      [  +0.000004] usb 5-1: Product: NexiGo N930AF FHD Webcam
      [  +0.000003] usb 5-1: Manufacturer: SHENZHEN AONI ELECTRONIC CO., LTD
      [  +0.000004] usb 5-1: SerialNumber: 20201217011
      [  +0.043700] usb 5-1: set resolution quirk: cval->res = 16
      [  +0.002585] usb 5-1: Found UVC 1.00 device NexiGo N930AF FHD Webcam (1bcf:2283)
      Signed-off-by: default avatarChristos Skevis <xristos.thes@gmail.com>
      Link: https://lore.kernel.org/r/20231006155330.399393-1-xristos.thes@gmail.comSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
      4a63e68a
  5. 08 Oct, 2023 4 commits
  6. 07 Oct, 2023 17 commits