1. 02 Feb, 2022 1 commit
    • Daniel Thompson's avatar
      HID: i2c-hid: goodix: Fix a lockdep splat · 2787710f
      Daniel Thompson authored
      I'm was on the receiving end of a lockdep splat from this driver and after
      scratching my head I couldn't be entirely sure it was a false positive
      given we would also have to think about whether the regulator locking is
      safe (since the notifier is called whilst holding regulator locks which
      are also needed for regulator_is_enabled() ).
      
      Regardless of whether it is a real bug or not, the mutex isn't needed.
      We can use reference counting tricks instead to avoid races with the
      notifier calls.
      
      The observed splat follows:
      
      ------------------------------------------------------
      kworker/u16:3/127 is trying to acquire lock:
      ffff00008021fb20 (&ihid_goodix->regulator_mutex){+.+.}-{4:4}, at: ihid_goodix_vdd_notify+0x30/0x94
      
      but task is already holding lock:
      ffff0000835c60c0 (&(&rdev->notifier)->rwsem){++++}-{4:4}, at: blocking_notifier_call_chain+0x30/0x70
      
      which lock already depends on the new lock.
      
      the existing dependency chain (in reverse order) is:
      
      -> #1 (&(&rdev->notifier)->rwsem){++++}-{4:4}:
             down_write+0x68/0x8c
             blocking_notifier_chain_register+0x54/0x70
             regulator_register_notifier+0x1c/0x24
             devm_regulator_register_notifier+0x58/0x98
             i2c_hid_of_goodix_probe+0xdc/0x158
             i2c_device_probe+0x25d/0x270
             really_probe+0x174/0x2cc
             __driver_probe_device+0xc0/0xd8
             driver_probe_device+0x50/0xe4
             __device_attach_driver+0xa8/0xc0
             bus_for_each_drv+0x9c/0xc0
             __device_attach_async_helper+0x6c/0xbc
             async_run_entry_fn+0x38/0x100
             process_one_work+0x294/0x438
             worker_thread+0x180/0x258
             kthread+0x120/0x130
             ret_from_fork+0x10/0x20
      
      -> #0 (&ihid_goodix->regulator_mutex){+.+.}-{4:4}:
             __lock_acquire+0xd24/0xfe8
             lock_acquire+0x288/0x2f4
             __mutex_lock+0xa0/0x338
             mutex_lock_nested+0x3c/0x5c
             ihid_goodix_vdd_notify+0x30/0x94
             notifier_call_chain+0x6c/0x8c
             blocking_notifier_call_chain+0x48/0x70
             _notifier_call_chain.isra.0+0x18/0x20
             _regulator_enable+0xc0/0x178
             regulator_enable+0x40/0x7c
             goodix_i2c_hid_power_up+0x18/0x20
             i2c_hid_core_power_up.isra.0+0x1c/0x2c
             i2c_hid_core_probe+0xd8/0x3d4
             i2c_hid_of_goodix_probe+0x14c/0x158
             i2c_device_probe+0x25c/0x270
             really_probe+0x174/0x2cc
             __driver_probe_device+0xc0/0xd8
             driver_probe_device+0x50/0xe4
             __device_attach_driver+0xa8/0xc0
             bus_for_each_drv+0x9c/0xc0
             __device_attach_async_helper+0x6c/0xbc
             async_run_entry_fn+0x38/0x100
             process_one_work+0x294/0x438
             worker_thread+0x180/0x258
             kthread+0x120/0x130
             ret_from_fork+0x10/0x20
      
      other info that might help us debug this:
      
       Possible unsafe locking scenario:
      
             CPU0                    CPU1
             ----                    ----
        lock(&(&rdev->notifier)->rwsem);
                                     lock(&ihid_goodix->regulator_mutex);
                                     lock(&(&rdev->notifier)->rwsem);
        lock(&ihid_goodix->regulator_mutex);
      
       *** DEADLOCK ***
      Signed-off-by: default avatarDaniel Thompson <daniel.thompson@linaro.org>
      Fixes: 18eeef46 ("HID: i2c-hid: goodix: Tie the reset line to true state of the regulator")
      Reviewed-by: default avatarDouglas Anderson <dianders@chromium.org>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      2787710f
  2. 24 Jan, 2022 1 commit
  3. 21 Jan, 2022 4 commits
    • Alex Henrie's avatar
      HID: apple: Set the tilde quirk flag on the Wellspring 5 and later · e26a7805
      Alex Henrie authored
      Markus reports that his 2011 MacBook with a German ISO keyboard (USB
      product code 05ac:0246, HID country code 13) has the tilde key quirk.
      Seeing as all of the standalone Apple ISO keyboards since about 2008
      have the quirk, it seems reasonable to assume that once the integrated
      laptop keyboards started having the quirk, they likewise never stopped
      having it.
      Reported-by: default avatarMarkus Wageringel <markus.wageringel@gmail.com>
      Signed-off-by: default avatarAlex Henrie <alexhenrie24@gmail.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      e26a7805
    • Jason Gerecke's avatar
      HID: wacom: Avoid using stale array indicies to read contact count · 20f3cf5f
      Jason Gerecke authored
      If we ever see a touch report with contact count data we initialize
      several variables used to read the contact count in the pre-report
      phase. These variables are never reset if we process a report which
      doesn't contain a contact count, however. This can cause the pre-
      report function to trigger a read of arbitrary memory (e.g. NULL
      if we're lucky) and potentially crash the driver.
      
      This commit restores resetting of the variables back to default
      "none" values that were used prior to the commit mentioned
      below.
      
      Link: https://github.com/linuxwacom/input-wacom/issues/276
      Fixes: 003f50ab (HID: wacom: Update last_slot_field during pre_report phase)
      CC: stable@vger.kernel.org
      Signed-off-by: default avatarJason Gerecke <jason.gerecke@wacom.com>
      Reviewed-by: default avatarPing Cheng <ping.cheng@wacom.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      20f3cf5f
    • Jason Gerecke's avatar
      HID: wacom: Ignore the confidence flag when a touch is removed · df03e9bd
      Jason Gerecke authored
      AES hardware may internally re-classify a contact that it thought was
      intentional as a palm. Intentional contacts are reported as "down" with
      the confidence bit set. When this re-classification occurs, however, the
      state transitions to "up" with the confidence bit cleared. This kind of
      transition appears to be legal according to Microsoft docs, but we do
      not handle it correctly. Because the confidence bit is clear, we don't
      call `wacom_wac_finger_slot` and update userspace. This causes hung
      touches that confuse userspace and interfere with pen arbitration.
      
      This commit adds a special case to ignore the confidence flag if a contact
      is reported as removed. This ensures we do not leave a hung touch if one
      of these re-classification events occured. Ideally we'd have some way to
      also let userspace know that the touch has been re-classified as a palm
      and needs to be canceled, but that's not possible right now :)
      
      Link: https://github.com/linuxwacom/input-wacom/issues/288
      Fixes: 7fb0413b (HID: wacom: Use "Confidence" flag to prevent reporting invalid contacts)
      CC: stable@vger.kernel.org
      Signed-off-by: default avatarJason Gerecke <jason.gerecke@wacom.com>
      Reviewed-by: default avatarPing Cheng <ping.cheng@wacom.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      df03e9bd
    • Jason Gerecke's avatar
      HID: wacom: Reset expected and received contact counts at the same time · 546e41ac
      Jason Gerecke authored
      These two values go hand-in-hand and must be valid for the driver to
      behave correctly. We are currently lazy about updating the values and
      rely on the "expected" code flow to take care of making sure they're
      valid at the point they're needed. The "expected" flow changed somewhat
      with commit f8b6a747 ("HID: wacom: generic: Support multiple tools
      per report"), however. This led to problems with the DTH-2452 due (in
      part) to *all* contacts being fully processed -- even those past the
      expected contact count. Specifically, the received count gets reset to
      0 once all expected fingers are processed, but not the expected count.
      The rest of the contacts in the report are then *also* processed since
      now the driver thinks we've only processed 0 of N expected contacts.
      
      Later commits such as 7fb0413b (HID: wacom: Use "Confidence" flag to
      prevent reporting invalid contacts) worked around the DTH-2452 issue by
      skipping the invalid contacts at the end of the report, but this is not
      a complete fix. The confidence flag cannot be relied on when a contact
      is removed (see the following patch), and dealing with that condition
      re-introduces the DTH-2452 issue unless we also address this contact
      count laziness. By resetting expected and received counts at the same
      time we ensure the driver understands that there are 0 more contacts
      expected in the report. Similarly, we also make sure to reset the
      received count if for some reason we're out of sync in the pre-report
      phase.
      
      Link: https://github.com/linuxwacom/input-wacom/issues/288
      Fixes: f8b6a747 ("HID: wacom: generic: Support multiple tools per report")
      CC: stable@vger.kernel.org
      Signed-off-by: default avatarJason Gerecke <jason.gerecke@wacom.com>
      Reviewed-by: default avatarPing Cheng <ping.cheng@wacom.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      546e41ac
  4. 19 Jan, 2022 2 commits
    • Jann Horn's avatar
      HID: uhid: Use READ_ONCE()/WRITE_ONCE() for ->running · c8e7ff41
      Jann Horn authored
      The flag uhid->running can be set to false by uhid_device_add_worker()
      without holding the uhid->devlock. Mark all reads/writes of the flag
      that might race with READ_ONCE()/WRITE_ONCE() for clarity and
      correctness.
      Signed-off-by: default avatarJann Horn <jannh@google.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      c8e7ff41
    • Jann Horn's avatar
      HID: uhid: Fix worker destroying device without any protection · 4ea5763f
      Jann Horn authored
      uhid has to run hid_add_device() from workqueue context while allowing
      parallel use of the userspace API (which is protected with ->devlock).
      But hid_add_device() can fail. Currently, that is handled by immediately
      destroying the associated HID device, without using ->devlock - but if
      there are concurrent requests from userspace, that's wrong and leads to
      NULL dereferences and/or memory corruption (via use-after-free).
      
      Fix it by leaving the HID device as-is in the worker. We can clean it up
      later, either in the UHID_DESTROY command handler or in the ->release()
      handler.
      
      Cc: stable@vger.kernel.org
      Fixes: 67f8ecc5 ("HID: uhid: fix timeout when probe races with IO")
      Signed-off-by: default avatarJann Horn <jannh@google.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      4ea5763f
  5. 14 Jan, 2022 2 commits
    • Stephen Boyd's avatar
      HID: vivaldi: Minor cleanups · e24aeff6
      Stephen Boyd authored
      Perform some minor cleanups on this driver. Include header files for
      struct definitions that are used, drop a forward declaration that isn't
      useful, and mark a sysfs attribute static as it isn't used outside this
      file.
      
      Cc: Sean O'Brien <seobrien@chromium.org>
      Cc: Ting Shen <phoenixshen@chromium.org>
      Signed-off-by: default avatarStephen Boyd <swboyd@chromium.org>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      e24aeff6
    • Dmitry Torokhov's avatar
      HID: vivaldi: fix handling devices not using numbered reports · 3fe6acd4
      Dmitry Torokhov authored
      Unfortunately details of USB HID transport bled into HID core and
      handling of numbered/unnumbered reports is quite a mess, with
      hid_report_len() calculating the length according to USB rules,
      and hid_hw_raw_request() adding report ID to the buffer for both
      numbered and unnumbered reports.
      
      Untangling it all requres a lot of changes in HID, so for now let's
      handle this in the driver.
      
      [jkosina@suse.cz: microoptimize field->report->id to report->id]
      Fixes: 14c9c014 ("HID: add vivaldi HID driver")
      Signed-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
      Tested-by: Stephen Boyd <swboyd@chromium.org> # CoachZ
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      3fe6acd4
  6. 12 Jan, 2022 1 commit
    • Karl Kurbjun's avatar
      HID: Ignore battery for Elan touchscreen on HP Envy X360 15t-dr100 · f3193ea1
      Karl Kurbjun authored
      Battery status on Elan tablet driver is reported for the HP ENVY x360
      15t-dr100. There is no separate battery for the Elan controller resulting in a
      battery level report of 0% or 1% depending on whether a stylus has interacted
      with the screen. These low battery level reports causes a variety of bad
      behavior in desktop environments. This patch adds the appropriate quirk to
      indicate that the batery status is unused for this target.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarKarl Kurbjun <kkurbjun@gmail.com>
      Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
      f3193ea1
  7. 11 Jan, 2022 19 commits
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid · 26b88fba
      Linus Torvalds authored
      Pull HID updates from Jiri Kosina:
       "Highlights:
      
         - support for USI style pens (Tero Kristo, Mika Westerberg)
      
         - quirk for devices that need inverted X/Y axes (Alistair Francis)
      
         - small core code cleanups and deduplication (Benjamin Tissoires)
      
         - Apple Magic Keyboard support improvements (José Expósito, Alex
           Henrie, Benjamin Berg)
      
         - locking performance improvement for hidraw code (André Almeida)
      
         - PM wakeup support for i2c-hid driver (Matthias Kaehlcke
      
         - new driver to support for LetSketch device (Hans de Goede)
      
         - proper batter reporting for hid-magicmouse USB-connected devices
           (José Expósito)"
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid: (32 commits)
        HID: magicmouse: Fix an error handling path in magicmouse_probe()
        HID: address kernel-doc warnings
        HID: intel-ish-hid: ishtp-fw-loader: Fix a kernel-doc formatting issue
        HID: intel-ish-hid: ipc: Specify no cache snooping on TGL and ADL
        HID: hid-uclogic-params: Invalid parameter check in uclogic_params_frame_init_v1_buttonpad
        HID: hid-uclogic-params: Invalid parameter check in uclogic_params_huion_init
        HID: hid-uclogic-params: Invalid parameter check in uclogic_params_get_str_desc
        HID: hid-uclogic-params: Invalid parameter check in uclogic_params_init
        HID: Add new Letsketch tablet driver
        HID: apple: Add Magic Keyboard 2021 with fingerprint reader FN key mapping
        HID: apple: Add 2021 magic keyboard FN key mapping
        HID: magicmouse: set Magic Trackpad 2021 name
        HID: magicmouse: set device name when it has been personalized
        HID: apple: Add 2021 Magic Keyboard with number pad
        HID: apple: Add 2021 Magic Keyboard with fingerprint reader
        HID: i2c-hid-of: Expose the touchscreen-inverted properties
        HID: quirks: Allow inverting the absolute X/Y values
        HID: hidraw: Replace hidraw device table mutex with a rwsem
        HID: thrustmaster use swap() to make code cleaner
        HID: debug: Add USI usages
        ...
      26b88fba
    • Linus Torvalds's avatar
      Merge tag 'hwmon-for-v5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/linux-staging · 4a110907
      Linus Torvalds authored
      Pull hwmon updates from Guenter Roeck:
       "New drivers:
      
         - PMBus driver for MPS Multi-phase mp5023
      
         - PMBus driver for Delta AHE-50DC fan control module
      
         - Driver for NZXT RGB&Fan Controller/Smart Device v2
      
         - Driver for Texas Instruments INA238
      
         - Driver to support X370 Asus WMI
      
         - Driver to support B550 Asus WMI
      
        Other notable changes:
      
         - Cleanup of ntc_thermistor driver, and added support for Samsung
           1404-001221 NTC
      
         - Improve detection of LM84, MAX1617, and MAX1617A in adm1021 driver
      
         - Clean up tmp401 driver, and convert to with_info API
      
         - Add support for regulators and IR38060, IR38164 IR38263 to ir38064
           PMBus driver
      
         - Add support for AMD Family 19h Models 10h-1Fh and A0h-AFh to
           k10temp driver
      
         - Add support for F81966 to f71882fg driver
      
         - Add support for ONSEMI N34TS04 to jc42 driver
      
         - Clean up and simplify dell-smm driver
      
         - Add support for ROG STRIX B550-A/X570-I GAMING to nct6775 driver
      
        And various other minor improvements and fixes"
      
      * tag 'hwmon-for-v5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/linux-staging: (49 commits)
        hwmon: (nzxt-smart2) make array detect_fans_report static const
        hwmon: (xgene-hwmon) Add free before exiting xgene_hwmon_probe
        hwmon: (nzxt-smart2) Fix "unused function" warning
        hwmon: (dell-smm) Pack the whole smm_regs struct
        hwmon: (nct6775) Additional check for ChipID before ASUS WMI usage
        hwmon: (mr75203) fix wrong power-up delay value
        hwmon/pmbus: (ir38064) Fix spelling mistake "comaptible" -> "compatible"
        hwmon/pmbus: (ir38064) Expose a regulator
        hwmon/pmbus: (ir38064) Add of_match_table
        hwmon/pmbus: (ir38064) Add support for IR38060, IR38164 IR38263
        hwmon: add driver for NZXT RGB&Fan Controller/Smart Device v2.
        hwmon: (nct6775) add ROG STRIX B550-A/X570-I GAMING
        hwmon: (pmbus) Add support for MPS Multi-phase mp5023
        dt-bindings: add Delta AHE-50DC fan control module
        hwmon: (pmbus) Add Delta AHE-50DC fan control module driver
        hwmon: prefix kernel-doc comments for structs with struct
        hwmon: (ntc_thermistor) Add Samsung 1404-001221 NTC
        hwmon: (ntc_thermistor) Drop OF dependency
        hwmon: (dell-smm) Unify i8k_ioctl() and i8k_ioctl_unlocked()
        hwmon: (dell-smm) Simplify ioctl handler
        ...
      4a110907
    • Linus Torvalds's avatar
      Merge branch 'linus' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6 · 5c947d0d
      Linus Torvalds authored
      Pull crypto updates from Herbert Xu:
       "Algorithms:
      
         - Drop alignment requirement for data in aesni
      
         - Use synchronous seeding from the /dev/random in DRBG
      
         - Reseed nopr DRBGs every 5 minutes from /dev/random
      
         - Add KDF algorithms currently used by security/DH
      
         - Fix lack of entropy on some AMD CPUs with jitter RNG
      
        Drivers:
      
         - Add support for the D1 variant in sun8i-ce
      
         - Add SEV_INIT_EX support in ccp
      
         - PFVF support for GEN4 host driver in qat
      
         - Compression support for GEN4 devices in qat
      
         - Add cn10k random number generator support"
      
      * 'linus' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6: (145 commits)
        crypto: af_alg - rewrite NULL pointer check
        lib/mpi: Add the return value check of kcalloc()
        crypto: qat - fix definition of ring reset results
        crypto: hisilicon - cleanup warning in qm_get_qos_value()
        crypto: kdf - select SHA-256 required for self-test
        crypto: x86/aesni - don't require alignment of data
        crypto: ccp - remove unneeded semicolon
        crypto: stm32/crc32 - Fix kernel BUG triggered in probe()
        crypto: s390/sha512 - Use macros instead of direct IV numbers
        crypto: sparc/sha - remove duplicate hash init function
        crypto: powerpc/sha - remove duplicate hash init function
        crypto: mips/sha - remove duplicate hash init function
        crypto: sha256 - remove duplicate generic hash init function
        crypto: jitter - add oversampling of noise source
        MAINTAINERS: update SEC2 driver maintainers list
        crypto: ux500 - Use platform_get_irq() to get the interrupt
        crypto: hisilicon/qm - disable qm clock-gating
        crypto: omap-aes - Fix broken pm_runtime_and_get() usage
        MAINTAINERS: update caam crypto driver maintainers list
        crypto: octeontx2 - prevent underflow in get_cores_bmap()
        ...
      5c947d0d
    • Linus Torvalds's avatar
      Merge tag 'docs-5.17' of git://git.lwn.net/linux · 6f38be8f
      Linus Torvalds authored
      Pull documentation updates from Jonathan Corbet:
       "This isn't a hugely busy cycle for documentation, but a few
        significant things still showed up:
      
         - A documentation section for ARC processors
      
         - Reworked and enhanced KUnit documentation
      
         - The ability to pick your own theme for HTML builds; if the default
           "Read the Docs" theme isn't ugly enough for you, you can now pick
           an uglier one.
      
         - More Chinese translation work
      
        Plus the usual assortment of fixes and cleanups"
      
      * tag 'docs-5.17' of git://git.lwn.net/linux: (53 commits)
        scripts: sphinx-pre-install: Fix ctex support on Debian
        docs: discourage use of list tables
        docs: 5.Posting.rst: describe Fixes: and Link: tags
        Documentation: kgdb: Replace deprecated remotebaud
        docs: automarkup.py: Fix invalid HTML link output and broken URI fragments
        Documentation: refer to config RANDOMIZE_BASE for kernel address-space randomization
        Documentation: kgdb: properly capitalize the MAGIC_SYSRQ config
        docs/zh_CN: Update and fix a couple of typos
        scripts: sphinx-pre-install: add required ctex dependency
        Documentation: KUnit: Restyled Frequently Asked Questions
        Documentation: KUnit: Restyle Test Style and Nomenclature page
        Documentation: KUnit: Rework writing page to focus on writing tests
        Documentation: kunit: Reorganize documentation related to running tests
        Documentation: KUnit: Added KUnit Architecture
        Documentation: KUnit: Rewrite getting started
        Documentation: KUnit: Rewrite main page
        docs/zh_CN: Add zh_CN/accounting/delay-accounting.rst
        Documentation/sphinx: fix typos of "its"
        docs/zh_CN: Add sched-domains translation
        doc: fs: remove bdev_try_to_free_page related doc
        ...
      6f38be8f
    • Linus Torvalds's avatar
      Merge tag 'kcsan.2022.01.09a' of git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu · 1be5bdf8
      Linus Torvalds authored
      Pull KCSAN updates from Paul McKenney:
       "This provides KCSAN fixes and also the ability to take memory barriers
        into account for weakly-ordered systems. This last can increase the
        probability of detecting certain types of data races"
      
      * tag 'kcsan.2022.01.09a' of git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu: (29 commits)
        kcsan: Only test clear_bit_unlock_is_negative_byte if arch defines it
        kcsan: Avoid nested contexts reading inconsistent reorder_access
        kcsan: Turn barrier instrumentation into macros
        kcsan: Make barrier tests compatible with lockdep
        kcsan: Support WEAK_MEMORY with Clang where no objtool support exists
        compiler_attributes.h: Add __disable_sanitizer_instrumentation
        objtool, kcsan: Remove memory barrier instrumentation from noinstr
        objtool, kcsan: Add memory barrier instrumentation to whitelist
        sched, kcsan: Enable memory barrier instrumentation
        mm, kcsan: Enable barrier instrumentation
        x86/qspinlock, kcsan: Instrument barrier of pv_queued_spin_unlock()
        x86/barriers, kcsan: Use generic instrumentation for non-smp barriers
        asm-generic/bitops, kcsan: Add instrumentation for barriers
        locking/atomics, kcsan: Add instrumentation for barriers
        locking/barriers, kcsan: Support generic instrumentation
        locking/barriers, kcsan: Add instrumentation for barriers
        kcsan: selftest: Add test case to check memory barrier instrumentation
        kcsan: Ignore GCC 11+ warnings about TSan runtime support
        kcsan: test: Add test cases for memory barrier instrumentation
        kcsan: test: Match reordered or normal accesses
        ...
      1be5bdf8
    • Linus Torvalds's avatar
      Merge tag 'lkmm.2022.01.09a' of git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu · 1c824bf7
      Linus Torvalds authored
      Pull memory model documentation updates from Paul McKenney:
       "This series contains documentation and litmus tests for locking,
        courtesy of Boqun Feng"
      
      * tag 'lkmm.2022.01.09a' of git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu:
        tools/memory-model: litmus: Add two tests for unlock(A)+lock(B) ordering
        tools/memory-model: doc: Describe the requirement of the litmus-tests directory
        tools/memory-model: Provide extra ordering for unlock+lock pair on the same CPU
      1c824bf7
    • Linus Torvalds's avatar
      Merge tag 'rcu.2022.01.09a' of git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu · e7d38f16
      Linus Torvalds authored
      Pull RCU updates from Paul McKenney:
      
       - Documentation updates, perhaps most notably Neil Brown's writeup of
         the reference-counting analogy to RCU.
      
       - Expedited grace-period cleanups.
      
       - Remove CONFIG_RCU_FAST_NO_HZ due to lack of valid users. I have asked
         around, posted a blog entry, and sent this series to LKML without
         result.
      
       - Miscellaneous fixes.
      
       - RCU callback offloading updates, perhaps most notably Frederic
         Weisbecker's updates allowing CPUs booted in the de-offloaded state
         to be offloaded at runtime.
      
       - nolibc fixes from Willy Tarreau and Anmar Faizi, but also including
         Mark Brown's addition of gettid().
      
       - RCU Tasks Trace fixes, including changes that increase the
         scalability of call_rcu_tasks_trace() for the BPF folks (Martin Lau
         and KP Singh).
      
       - Various fixes including those from Wander Lairson Costa and Li
         Zhijian.
      
       - Fixes plus addition of tests for the increased call_rcu_tasks_trace()
         scalability.
      
      * tag 'rcu.2022.01.09a' of git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu: (87 commits)
        rcu/nocb: Merge rcu_spawn_cpu_nocb_kthread() and rcu_spawn_one_nocb_kthread()
        rcu/nocb: Allow empty "rcu_nocbs" kernel parameter
        rcu/nocb: Create kthreads on all CPUs if "rcu_nocbs=" or "nohz_full=" are passed
        rcu/nocb: Optimize kthreads and rdp initialization
        rcu/nocb: Prepare nocb_cb_wait() to start with a non-offloaded rdp
        rcu/nocb: Remove rcu_node structure from nocb list when de-offloaded
        rcu-tasks: Use fewer callbacks queues if callback flood ends
        rcu-tasks: Use separate ->percpu_dequeue_lim for callback dequeueing
        rcu-tasks: Use more callback queues if contention encountered
        rcu-tasks: Avoid raw-spinlocked wakeups from call_rcu_tasks_generic()
        rcu-tasks: Count trylocks to estimate call_rcu_tasks() contention
        rcu-tasks: Add rcupdate.rcu_task_enqueue_lim to set initial queueing
        rcu-tasks: Make rcu_barrier_tasks*() handle multiple callback queues
        rcu-tasks: Use workqueues for multiple rcu_tasks_invoke_cbs() invocations
        rcu-tasks: Abstract invocations of callbacks
        rcu-tasks: Abstract checking of callback lists
        rcu-tasks: Add a ->percpu_enqueue_lim to the rcu_tasks structure
        rcu-tasks: Inspect stalled task's trc state in locked state
        rcu-tasks: Use spin_lock_rcu_node() and friends
        rcutorture: Combine n_max_cbs from all kthreads in a callback flood
        ...
      e7d38f16
    • Linus Torvalds's avatar
      Merge tag 'printk-for-5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/printk/linux · a2293277
      Linus Torvalds authored
      Pull printk updates from Petr Mladek:
      
       - Remove some twists in the console registration code. It does not
         change the existing behavior except for one corner case. The proper
         default console (with tty binding) will be registered again even when
         it has been removed in the meantime. It is actually a bug fix.
         Anyway, this modified behavior requires some manual interaction.
      
       - Optimize gdb extension for huge ring buffers.
      
       - Do not use atomic operations for a local bitmap variable.
      
       - Update git links in MAINTAINERS.
      
      * tag 'printk-for-5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/printk/linux:
        MAINTAIERS/printk: Add link to printk git
        MAINTAINERS/vsprintf: Update link to printk git tree
        scripts/gdb: lx-dmesg: read records individually
        printk/console: Clean up boot console handling in register_console()
        printk/console: Remove need_default_console variable
        printk/console: Remove unnecessary need_default_console manipulation
        printk/console: Rename has_preferred_console to need_default_console
        printk/console: Split out code that enables default console
        vsprintf: Use non-atomic bitmap API when applicable
      a2293277
    • Linus Torvalds's avatar
      Merge branch 'for-5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq · e9e64f85
      Linus Torvalds authored
      Pull workqueue updates from Tejun Heo:
      
       - The code around workqueue scheduler hooks got reorganized early 2019
         which unfortuately introdued a couple subtle and rare race conditions
         where preemption can mangle internal workqueue state triggering a
         WARN and possibly causing a stall or at least delay in execution.
      
         Frederic fixed both early December and the fixes were sitting in
         for-5.16-fixes which I forgot to push. They are here now. I'll
         forward them to stable after they land.
      
       - The scheduler hook reorganization has more implicatoins for workqueue
         code in that the hooks are now more strictly synchronized and thus
         the interacting operations can become more straight-forward.
      
         Lai is in the process of simplifying workqueue code and this pull
         request contains some of the patches.
      
      * 'for-5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq:
        workqueue: Remove the cacheline_aligned for nr_running
        workqueue: Move the code of waking a worker up in unbind_workers()
        workqueue: Remove schedule() in unbind_workers()
        workqueue: Remove outdated comment about exceptional workers in unbind_workers()
        workqueue: Remove the advanced kicking of the idle workers in rebind_workers()
        workqueue: Remove the outdated comment before wq_worker_sleeping()
        workqueue: Fix unbind_workers() VS wq_worker_sleeping() race
        workqueue: Fix unbind_workers() VS wq_worker_running() race
        workqueue: Upgrade queue_work_on() comment
      e9e64f85
    • Linus Torvalds's avatar
      Merge branch 'for-5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup · ea1ca66d
      Linus Torvalds authored
      Pull cgroup updates from Tejun Heo:
       "Nothing too interesting. The only two noticeable changes are a subtle
        cpuset behavior fix and trace event id field being expanded to u64
        from int. Most others are code cleanups"
      
      * 'for-5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup:
        cpuset: convert 'allowed' in __cpuset_node_allowed() to be boolean
        cgroup/rstat: check updated_next only for root
        cgroup: rstat: explicitly put loop variant in while
        cgroup: return early if it is already on preloaded list
        cgroup/cpuset: Don't let child cpusets restrict parent in default hierarchy
        cgroup: Trace event cgroup id fields should be u64
        cgroup: fix a typo in comment
        cgroup: get the wrong css for css_alloc() during cgroup_init_subsys()
        cgroup: rstat: Mark benign data race to silence KCSAN
      ea1ca66d
    • Jan Kara's avatar
      select: Fix indefinitely sleeping task in poll_schedule_timeout() · 68514dac
      Jan Kara authored
      A task can end up indefinitely sleeping in do_select() ->
      poll_schedule_timeout() when the following race happens:
      
        TASK1 (thread1)             TASK2                   TASK1 (thread2)
        do_select()
          setup poll_wqueues table
          with 'fd'
                                    write data to 'fd'
                                      pollwake()
                                        table->triggered = 1
                                                            closes 'fd' thread1 is
                                                              waiting for
          poll_schedule_timeout()
            - sees table->triggered
            table->triggered = 0
            return -EINTR
          loop back in do_select()
      
      But at this point when TASK1 loops back, the fdget() in the setup of
      poll_wqueues fails.  So now so we never find 'fd' is ready for reading
      and sleep in poll_schedule_timeout() indefinitely.
      
      Treat an fd that got closed as a fd on which some event happened.  This
      makes sure cannot block indefinitely in do_select().
      
      Another option would be to return -EBADF in this case but that has a
      potential of subtly breaking applications that excercise this behavior
      and it happens to work for them.  So returning fd as active seems like a
      safer choice.
      Suggested-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      CC: stable@vger.kernel.org
      Signed-off-by: default avatarJan Kara <jack@suse.cz>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      68514dac
    • Linus Torvalds's avatar
      Merge tag 'devprop-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · fe8152b3
      Linus Torvalds authored
      Pull device properties framework updates from Rafael Wysocki:
       "These update the handling of software nodes and graph properties, and
        the MAINTAINERS entry for the former.
      
        Specifics:
      
         - Remove device_add_properties() which does not work correctly if
           software nodes holding additional device properties are shared or
           reused (Heikki Krogerus).
      
         - Fix nargs_prop property handling for software nodes (Clément
           Léger).
      
         - Update documentation of ACPI device properties (Sakari Ailus).
      
         - Update the handling of graph properties in the generic framework to
           match the DT case (Sakari Ailus).
      
         - Update software nodes entry in MAINTAINERS (Andy Shevchenko)"
      
      * tag 'devprop-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
        software node: Update MAINTAINERS data base
        software node: fix wrong node passed to find nargs_prop
        device property: Drop fwnode_graph_get_remote_node()
        device property: Use fwnode_graph_for_each_endpoint() macro
        device property: Implement fwnode_graph_get_endpoint_count()
        Documentation: ACPI: Update references
        Documentation: ACPI: Fix data node reference documentation
        device property: Fix documentation for FWNODE_GRAPH_DEVICE_DISABLED
        device property: Fix fwnode_graph_devcon_match() fwnode leak
        device property: Remove device_add_properties() API
        driver core: Don't call device_remove_properties() from device_del()
        PCI: Convert to device_create_managed_software_node()
      fe8152b3
    • Linus Torvalds's avatar
      Merge tag 'thermal-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · fe2437cc
      Linus Torvalds authored
      Pull thermal control updates from Rafael Wysocki:
       "These add a new driver for Renesas RZ/G2L TSU, update a few existing
        thermal control drivers and clean up the tmon utility.
      
        Specifics:
      
         - Add new TSU driver and DT bindings for the Renesas RZ/G2L platform
           (Biju Das).
      
         - Fix missing check when calling reset_control_deassert() in the
           rz2gl thermal driver (Biju Das).
      
         - In preparation for FORTIFY_SOURCE performing compile-time and
           run-time field bounds checking for memcpy(), avoid intentionally
           writing across neighboring fields in the int340x thermal control
           driver (Kees Cook).
      
         - Fix RFIM mailbox write commands handling in the int340x thermal
           control driver (Sumeet Pawnikar).
      
         - Fix PM issue occurring in the iMX thermal control driver during
           suspend/resume by implementing PM runtime support in it (Oleksij
           Rempel).
      
         - Add 'const' annotation to thermal_cooling_ops in the Intel
           powerclamp driver (Rikard Falkeborn).
      
         - Fix missing ADC bit set in the iMX8MP thermal driver to enable the
           sensor (Paul Gerber).
      
         - Drop unused local variable definition from tmon (ran jianping)"
      
      * tag 'thermal-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
        thermal/drivers/int340x: Fix RFIM mailbox write commands
        thermal/drivers/rz2gl: Add error check for reset_control_deassert()
        thermal/drivers/imx8mm: Enable ADC when enabling monitor
        thermal/drivers: Add TSU driver for RZ/G2L
        dt-bindings: thermal: Document Renesas RZ/G2L TSU
        thermal/drivers/intel_powerclamp: Constify static thermal_cooling_device_ops
        thermal/drivers/imx: Implement runtime PM support
        thermal: tools: tmon: remove unneeded local variable
        thermal: int340x: Use struct_group() for memcpy() region
      fe2437cc
    • Linus Torvalds's avatar
      Merge tag 'pm-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · b35b6d4d
      Linus Torvalds authored
      Pull power management updates from Rafael Wysocki:
       "The most signigicant change here is the addition of a new cpufreq
        'P-state' driver for AMD processors as a better replacement for the
        venerable acpi-cpufreq driver.
      
        There are also other cpufreq updates (in the core, intel_pstate, ARM
        drivers), PM core updates (mostly related to adding new macros for
        declaring PM operations which should make the lives of driver
        developers somewhat easier), and a bunch of assorted fixes and
        cleanups.
      
        Summary:
      
         - Add new P-state driver for AMD processors (Huang Rui).
      
         - Fix initialization of min and max frequency QoS requests in the
           cpufreq core (Rafael Wysocki).
      
         - Fix EPP handling on Alder Lake in intel_pstate (Srinivas
           Pandruvada).
      
         - Make intel_pstate update cpuinfo.max_freq when notified of HWP
           capabilities changes and drop a redundant function call from that
           driver (Rafael Wysocki).
      
         - Improve IRQ support in the Qcom cpufreq driver (Ard Biesheuvel,
           Stephen Boyd, Vladimir Zapolskiy).
      
         - Fix double devm_remap() in the Mediatek cpufreq driver (Hector
           Yuan).
      
         - Introduce thermal pressure helpers for cpufreq CPU cooling (Lukasz
           Luba).
      
         - Make cpufreq use default_groups in kobj_type (Greg Kroah-Hartman).
      
         - Make cpuidle use default_groups in kobj_type (Greg Kroah-Hartman).
      
         - Fix two comments in cpuidle code (Jason Wang, Yang Li).
      
         - Allow model-specific normal EPB value to be used in the intel_epb
           sysfs attribute handling code (Srinivas Pandruvada).
      
         - Simplify locking in pm_runtime_put_suppliers() (Rafael Wysocki).
      
         - Add safety net to supplier device release in the runtime PM core
           code (Rafael Wysocki).
      
         - Capture device status before disabling runtime PM for it (Rafael
           Wysocki).
      
         - Add new macros for declaring PM operations to allow drivers to
           avoid guarding them with CONFIG_PM #ifdefs or __maybe_unused and
           update some drivers to use these macros (Paul Cercueil).
      
         - Allow ACPI hardware signature to be honoured during restore from
           hibernation (David Woodhouse).
      
         - Update outdated operating performance points (OPP) documentation
           (Tang Yizhou).
      
         - Reduce log severity for informative message regarding frequency
           transition failures in devfreq (Tzung-Bi Shih).
      
         - Add DRAM frequency controller devfreq driver for Allwinner sunXi
           SoCs (Samuel Holland).
      
         - Add missing COMMON_CLK dependency to sun8i devfreq driver (Arnd
           Bergmann).
      
         - Add support for new layout of Psys PowerLimit Register on SPR to
           the Intel RAPL power capping driver (Zhang Rui).
      
         - Fix typo in a comment in idle_inject.c (Jason Wang).
      
         - Remove unused function definition from the DTPM (Dynamit Thermal
           Power Management) power capping framework (Daniel Lezcano).
      
         - Reduce DTPM trace verbosity (Daniel Lezcano)"
      
      * tag 'pm-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (53 commits)
        x86, sched: Fix undefined reference to init_freq_invariance_cppc() build error
        cpufreq: amd-pstate: Fix Kconfig dependencies for AMD P-State
        cpufreq: amd-pstate: Fix struct amd_cpudata kernel-doc comment
        cpuidle: use default_groups in kobj_type
        x86: intel_epb: Allow model specific normal EPB value
        MAINTAINERS: Add AMD P-State driver maintainer entry
        Documentation: amd-pstate: Add AMD P-State driver introduction
        cpufreq: amd-pstate: Add AMD P-State performance attributes
        cpufreq: amd-pstate: Add AMD P-State frequencies attributes
        cpufreq: amd-pstate: Add boost mode support for AMD P-State
        cpufreq: amd-pstate: Add trace for AMD P-State module
        cpufreq: amd-pstate: Introduce the support for the processors with shared memory solution
        cpufreq: amd-pstate: Add fast switch function for AMD P-State
        cpufreq: amd-pstate: Introduce a new AMD P-State driver to support future processors
        ACPI: CPPC: Add CPPC enable register function
        ACPI: CPPC: Check present CPUs for determining _CPC is valid
        ACPI: CPPC: Implement support for SystemIO registers
        x86/msr: Add AMD CPPC MSR definitions
        x86/cpufeatures: Add AMD Collaborative Processor Performance Control feature flag
        cpufreq: use default_groups in kobj_type
        ...
      b35b6d4d
    • Linus Torvalds's avatar
      Merge tag 'acpi-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · bca21755
      Linus Torvalds authored
      Pull ACPI updates from Rafael Wysocki:
       "These are usual ACPICA code updates (although there are more of them
        than in the last few releases), a noticeable EC driver update (which
        mostly consists of cleanups, though), the device enumeration quirks
        handling rework from Hans, some updates eliminating unnecessary CPU
        cache flushing in some places (processor idle and system-wide PM code)
        and a bunch of assorted cleanups and fixes.
      
        Specifics:
      
         - Update ACPICA code in the kernel to the 20211217 upstream release
           including the following changes:
      
            - iASL/Disassembler: Additional support for NHLT table (Bob
              Moore).
            - Change a return_ACPI_STATUS (AE_BAD_PARAMETER) (Bob Moore).
            - Fix a couple of warnings under MSVC (Bob Moore).
            - iASL: Add TDEL table to both compiler/disassembler (Bob Moore).
            - iASL/NHLT table: "Specific Data" field support (Bob Moore).
            - Use original data_table_region pointer for accesses (Jessica
              Clarke).
            - Use original pointer for virtual origin tables (Jessica Clarke).
            - Macros: Remove ACPI_PHYSADDR_TO_PTR (Jessica Clarke).
            - Avoid subobject buffer overflow when validating RSDP signature
              (Jessica Clarke).
            - iASL: Add suppport for AGDI table (Ilkka Koskinen).
            - Hardware: Do not flush CPU cache when entering S4 and S5 (Kirill
              A. Shutemov).
            - Expand the ACPI_ACCESS_ definitions (Mark Langsdorf).
            - Utilities: Avoid deleting the same object twice in a row (Rafael
              Wysocki).
            - Executer: Fix REFCLASS_REFOF case in acpi_ex_opcode_1A_0T_1R()
              (Rafael Wysocki).
            - Fix AEST Processor generic resource substructure data field byte
              length (Shuuichirou Ishii).
            - Fix wrong interpretation of PCC address (Sudeep Holla).
            - Add support for PCC Opregion special context data (Sudeep
              Holla).
      
         - Implement OperationRegion handler for PCC Type 3 subtype (Sudeep
           Holla).
      
         - Introduce acpi_fetch_acpi_dev() as a replacement for
           acpi_bus_get_device() and use it in the ACPI subsystem (Rafael
           Wysocki).
      
         - Avoid using _CID for device enumaration if _HID is missing or
           invalid (Rafael Wysocki).
      
         - Rework quirk handling during ACPI device enumeration and add some
           new quirks for known broken platforms (Hans de Goede).
      
         - Avoid unnecessary or redundant CPU cache flushing during system PM
           transitions (Kirill A. Shutemov).
      
         - Add PM debug messages related to power resources (Rafael Wysocki).
      
         - Fix kernel-doc comment in the PCI host bridge ACPI driver (Yang
           Li).
      
         - Rework flushing of EC work while suspended to idle and clean up the
           handling of events in the ACPI EC driver (Rafael Wysocki).
      
         - Prohibit ec_sys module parameter write_support from being used when
           the system is locked down (Hans de Goede).
      
         - Make the ACPI processor thermal driver use cpufreq_cpu_get() to
           check for presence of cpufreq policy (Manfred Spraul).
      
         - Avoid unnecessary CPU cache flushing in the ACPI processor idle
           driver (Kirill A. Shutemov).
      
         - Replace kernel.h with the necessary inclusions in the ACPI
           processor driver (Andy Shevchenko).
      
         - Use swap() instead of open coding it in the ACPI processor idle
           driver (Guo Zhengkui).
      
         - Fix the handling of defective LPAT in the ACPI xpower PMIC driver
           and clean up some definitions of PMIC data structures (Hans de
           Goede).
      
         - Fix outdated comment in the ACPI DPTF driver (Sumeet Pawnikar).
      
         - Add AEST to the list of known ACPI table signatures (Shuuichirou
           Ishii).
      
         - Make ACPI NUMA code take hotpluggable memblocks into account when
           CONFIG_MEMORY_HOTPLUG is not set (Vitaly Kuznetsov).
      
         - Use default_groups in kobj_type in the ACPI sysfs code (Greg
           Kroah-Hartman).
      
         - Rearrange _CPC structure documentation (Andy Shevchenko).
      
         - Drop an always true check from the ACPI thermal driver (Adam
           Borowski).
      
         - Add new "not charging" quirk for Lenovo ThinkPads to the ACPI
           battery driver (Thomas Weißschuh)"
      
      * tag 'acpi-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (64 commits)
        ACPI: PCC: Implement OperationRegion handler for the PCC Type 3 subtype
        ACPI / x86: Skip AC and battery devices on x86 Android tablets with broken DSDTs
        ACPI / x86: Introduce an acpi_quirk_skip_acpi_ac_and_battery() helper
        ACPI: processor: thermal: avoid cpufreq_get_policy()
        serdev: Do not instantiate serdevs on boards with known bogus DSDT entries
        i2c: acpi: Do not instantiate I2C-clients on boards with known bogus DSDT entries
        ACPI / x86: Add acpi_quirk_skip_[i2c_client|serdev]_enumeration() helpers
        ACPI: scan: Create platform device for BCM4752 and LNV4752 ACPI nodes
        PCI/ACPI: Fix acpi_pci_osc_control_set() kernel-doc comment
        ACPI: battery: Add the ThinkPad "Not Charging" quirk
        ACPI: sysfs: use default_groups in kobj_type
        ACPICA: Update version to 20211217
        ACPICA: iASL/NHLT table: "Specific Data" field support
        ACPICA: iASL: Add suppport for AGDI table
        ACPICA: iASL: Add TDEL table to both compiler/disassembler
        ACPICA: Fixed a couple of warnings under MSVC
        ACPICA: Change a return_ACPI_STATUS (AE_BAD_PARAMETER)
        ACPICA: Hardware: Do not flush CPU cache when entering S4 and S5
        ACPICA: Add support for PCC Opregion special context data
        ACPICA: Fix wrong interpretation of PCC address
        ...
      bca21755
    • Linus Torvalds's avatar
      netfilter: nf_tables: don't use 'data_size' uninitialized · 63045bfd
      Linus Torvalds authored
      Commit 2c865a8a ("netfilter: nf_tables: add rule blob layout") never
      initialized the new 'data_size' variable.
      
      I'm not sure how it ever worked, but it might have worked almost by
      accident - gcc seems to occasionally miss these kinds of 'variable used
      uninitialized' situations, but I've seen it do so because it ended up
      zero-initializing them due to some other simplification.
      
      But clang is very unhappy about it all, and correctly reports
      
          net/netfilter/nf_tables_api.c:8278:4: error: variable 'data_size' is uninitialized when used here [-Werror,-Wuninitialized]
                                  data_size += sizeof(*prule) + rule->dlen;
                                  ^~~~~~~~~
          net/netfilter/nf_tables_api.c:8263:30: note: initialize the variable 'data_size' to silence this warning
                  unsigned int size, data_size;
                                              ^
                                               = 0
          1 error generated.
      
      and this fix just initializes 'data_size' to zero before the loop.
      
      Fixes: 2c865a8a ("netfilter: nf_tables: add rule blob layout")
      Cc: Pablo Neira Ayuso <pablo@netfilter.org>
      Cc: Jakub Kicinski <kuba@kernel.org>
      Cc: David Miller <davem@davemloft.net>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      63045bfd
    • Linus Torvalds's avatar
      Merge tag '5.17-net-next' of git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next · 8efd0d9c
      Linus Torvalds authored
      Pull networking updates from Jakub Kicinski:
       "Core
        ----
      
         - Defer freeing TCP skbs to the BH handler, whenever possible, or at
           least perform the freeing outside of the socket lock section to
           decrease cross-CPU allocator work and improve latency.
      
         - Add netdevice refcount tracking to locate sources of netdevice and
           net namespace refcount leaks.
      
         - Make Tx watchdog less intrusive - avoid pausing Tx and restarting
           all queues from a single CPU removing latency spikes.
      
         - Various small optimizations throughout the stack from Eric Dumazet.
      
         - Make netdev->dev_addr[] constant, force modifications to go via
           appropriate helpers to allow us to keep addresses in ordered data
           structures.
      
         - Replace unix_table_lock with per-hash locks, improving performance
           of bind() calls.
      
         - Extend skb drop tracepoint with a drop reason.
      
         - Allow SO_MARK and SO_PRIORITY setsockopt under CAP_NET_RAW.
      
        BPF
        ---
      
         - New helpers:
            - bpf_find_vma(), find and inspect VMAs for profiling use cases
            - bpf_loop(), runtime-bounded loop helper trading some execution
              time for much faster (if at all converging) verification
            - bpf_strncmp(), improve performance, avoid compiler flakiness
            - bpf_get_func_arg(), bpf_get_func_ret(), bpf_get_func_arg_cnt()
              for tracing programs, all inlined by the verifier
      
         - Support BPF relocations (CO-RE) in the kernel loader.
      
         - Further the support for BTF_TYPE_TAG annotations.
      
         - Allow access to local storage in sleepable helpers.
      
         - Convert verifier argument types to a composable form with different
           attributes which can be shared across types (ro, maybe-null).
      
         - Prepare libbpf for upcoming v1.0 release by cleaning up APIs,
           creating new, extensible ones where missing and deprecating those
           to be removed.
      
        Protocols
        ---------
      
         - WiFi (mac80211/cfg80211):
            - notify user space about long "come back in N" AP responses,
              allow it to react to such temporary rejections
            - allow non-standard VHT MCS 10/11 rates
            - use coarse time in airtime fairness code to save CPU cycles
      
         - Bluetooth:
            - rework of HCI command execution serialization to use a common
              queue and work struct, and improve handling errors reported in
              the middle of a batch of commands
            - rework HCI event handling to use skb_pull_data, avoiding packet
              parsing pitfalls
            - support AOSP Bluetooth Quality Report
      
         - SMC:
            - support net namespaces, following the RDMA model
            - improve connection establishment latency by pre-clearing buffers
            - introduce TCP ULP for automatic redirection to SMC
      
         - Multi-Path TCP:
            - support ioctls: SIOCINQ, OUTQ, and OUTQNSD
            - support socket options: IP_TOS, IP_FREEBIND, IP_TRANSPARENT,
              IPV6_FREEBIND, and IPV6_TRANSPARENT, TCP_CORK and TCP_NODELAY
            - support cmsgs: TCP_INQ
            - improvements in the data scheduler (assigning data to subflows)
            - support fastclose option (quick shutdown of the full MPTCP
              connection, similar to TCP RST in regular TCP)
      
         - MCTP (Management Component Transport) over serial, as defined by
           DMTF spec DSP0253 - "MCTP Serial Transport Binding".
      
        Driver API
        ----------
      
         - Support timestamping on bond interfaces in active/passive mode.
      
         - Introduce generic phylink link mode validation for drivers which
           don't have any quirks and where MAC capability bits fully express
           what's supported. Allow PCS layer to participate in the validation.
           Convert a number of drivers.
      
         - Add support to set/get size of buffers on the Rx rings and size of
           the tx copybreak buffer via ethtool.
      
         - Support offloading TC actions as first-class citizens rather than
           only as attributes of filters, improve sharing and device resource
           utilization.
      
         - WiFi (mac80211/cfg80211):
            - support forwarding offload (ndo_fill_forward_path)
            - support for background radar detection hardware
            - SA Query Procedures offload on the AP side
      
        New hardware / drivers
        ----------------------
      
         - tsnep - FPGA based TSN endpoint Ethernet MAC used in PLCs with
           real-time requirements for isochronous communication with protocols
           like OPC UA Pub/Sub.
      
         - Qualcomm BAM-DMUX WWAN - driver for data channels of modems
           integrated into many older Qualcomm SoCs, e.g. MSM8916 or MSM8974
           (qcom_bam_dmux).
      
         - Microchip LAN966x multi-port Gigabit AVB/TSN Ethernet Switch driver
           with support for bridging, VLANs and multicast forwarding
           (lan966x).
      
         - iwlmei driver for co-operating between Intel's WiFi driver and
           Intel's Active Management Technology (AMT) devices.
      
         - mse102x - Vertexcom MSE102x Homeplug GreenPHY chips
      
         - Bluetooth:
            - MediaTek MT7921 SDIO devices
            - Foxconn MT7922A
            - Realtek RTL8852AE
      
        Drivers
        -------
      
         - Significantly improve performance in the datapaths of: lan78xx,
           ax88179_178a, lantiq_xrx200, bnxt.
      
         - Intel Ethernet NICs:
            - igb: support PTP/time PEROUT and EXTTS SDP functions on
              82580/i354/i350 adapters
            - ixgbevf: new PF -> VF mailbox API which avoids the risk of
              mailbox corruption with ESXi
            - iavf: support configuration of VLAN features of finer
              granularity, stacked tags and filtering
            - ice: PTP support for new E822 devices with sub-ns precision
            - ice: support firmware activation without reboot
      
         - Mellanox Ethernet NICs (mlx5):
            - expose control over IRQ coalescing mode (CQE vs EQE) via ethtool
            - support TC forwarding when tunnel encap and decap happen between
              two ports of the same NIC
            - dynamically size and allow disabling various features to save
              resources for running in embedded / SmartNIC scenarios
      
         - Broadcom Ethernet NICs (bnxt):
            - use page frag allocator to improve Rx performance
            - expose control over IRQ coalescing mode (CQE vs EQE) via ethtool
      
         - Other Ethernet NICs:
            - amd-xgbe: add Ryzen 6000 (Yellow Carp) Ethernet support
      
         - Microsoft cloud/virtual NIC (mana):
            - add XDP support (PASS, DROP, TX)
      
         - Mellanox Ethernet switches (mlxsw):
            - initial support for Spectrum-4 ASICs
            - VxLAN with IPv6 underlay
      
         - Marvell Ethernet switches (prestera):
            - support flower flow templates
            - add basic IP forwarding support
      
         - NXP embedded Ethernet switches (ocelot & felix):
            - support Per-Stream Filtering and Policing (PSFP)
            - enable cut-through forwarding between ports by default
            - support FDMA to improve packet Rx/Tx to CPU
      
         - Other embedded switches:
            - hellcreek: improve trapping management (STP and PTP) packets
            - qca8k: support link aggregation and port mirroring
      
         - Qualcomm 802.11ax WiFi (ath11k):
            - qca6390, wcn6855: enable 802.11 power save mode in station mode
            - BSS color change support
            - WCN6855 hw2.1 support
            - 11d scan offload support
            - scan MAC address randomization support
            - full monitor mode, only supported on QCN9074
            - qca6390/wcn6855: report signal and tx bitrate
            - qca6390: rfkill support
            - qca6390/wcn6855: regdb.bin support
      
         - Intel WiFi (iwlwifi):
            - support SAR GEO Offset Mapping (SGOM) and Time-Aware-SAR (TAS)
              in cooperation with the BIOS
            - support for Optimized Connectivity Experience (OCE) scan
            - support firmware API version 68
            - lots of preparatory work for the upcoming Bz device family
      
         - MediaTek WiFi (mt76):
            - Specific Absorption Rate (SAR) support
            - mt7921: 160 MHz channel support
      
         - RealTek WiFi (rtw88):
            - Specific Absorption Rate (SAR) support
            - scan offload
      
         - Other WiFi NICs
            - ath10k: support fetching (pre-)calibration data from nvmem
            - brcmfmac: configure keep-alive packet on suspend
            - wcn36xx: beacon filter support"
      
      * tag '5.17-net-next' of git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next: (2048 commits)
        tcp: tcp_send_challenge_ack delete useless param `skb`
        net/qla3xxx: Remove useless DMA-32 fallback configuration
        rocker: Remove useless DMA-32 fallback configuration
        hinic: Remove useless DMA-32 fallback configuration
        lan743x: Remove useless DMA-32 fallback configuration
        net: enetc: Remove useless DMA-32 fallback configuration
        cxgb4vf: Remove useless DMA-32 fallback configuration
        cxgb4: Remove useless DMA-32 fallback configuration
        cxgb3: Remove useless DMA-32 fallback configuration
        bnx2x: Remove useless DMA-32 fallback configuration
        et131x: Remove useless DMA-32 fallback configuration
        be2net: Remove useless DMA-32 fallback configuration
        vmxnet3: Remove useless DMA-32 fallback configuration
        bna: Simplify DMA setting
        net: alteon: Simplify DMA setting
        myri10ge: Simplify DMA setting
        qlcnic: Simplify DMA setting
        net: allwinner: Fix print format
        page_pool: remove spinlock in page_pool_refill_alloc_cache()
        amt: fix wrong return type of amt_send_membership_update()
        ...
      8efd0d9c
    • Linus Torvalds's avatar
      Merge tag 'media/v5.17-1' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media · 9bcbf894
      Linus Torvalds authored
      Pull media updates from Mauro Carvalho Chehab:
      
       - New sensor driver: ov5693
      
       - A new driver for STM32 Chrom-ART Accelerator
      
       - Added V4L2 core helper functions for VP9 codec
      
       - Hantro driver has gained support for VP9 codecs
      
       - Added support for Maxim MAX96712 Quad GMSL2 Deserializer
      
       - The staging atomisp driver has gained lots of improvements, fixes and
         cleanups. It now works with userptr
      
       - Lots of random driver improvements as usual
      
      * tag 'media/v5.17-1' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media: (397 commits)
        media: ipu3-cio2: Add support for instantiating i2c-clients for VCMs
        media: ipu3-cio2: Call cio2_bridge_init() before anything else
        media: ipu3-cio2: Defer probing until the PMIC is fully setup
        media: hantro: Add support for Allwinner H6
        media: dt-bindings: allwinner: document H6 Hantro G2 binding
        media: hantro: Convert imx8m_vpu_g2_irq to helper
        media: hantro: move postproc enablement for old cores
        media: hantro: vp9: add support for legacy register set
        media: hantro: vp9: use double buffering if needed
        media: hantro: add support for reset lines
        media: hantro: Fix probe func error path
        media: i2c: hi846: use pm_runtime_force_suspend/resume for system suspend
        media: i2c: hi846: check return value of regulator_bulk_disable()
        media: hi556: Support device probe in non-zero ACPI D state
        media: ov5675: Support device probe in non-zero ACPI D state
        media: imx208: Support device probe in non-zero ACPI D state
        media: ov2740: support device probe in non-zero ACPI D state
        media: ov5670: Support device probe in non-zero ACPI D state
        media: ov8856: support device probe in non-zero ACPI D state
        media: ov8865: Disable only enabled regulators on error path
        ...
      9bcbf894
    • Linus Torvalds's avatar
      Revert "drm/amd/display: Fix for otg synchronization logic" · 75b950ef
      Linus Torvalds authored
      This reverts commit a896f870.
      
      It causes odd flickering on my Radeon RX580 (PCI ID 1002:67df rev e7,
      subsystem ID 1da2:e353).
      
      Bisected right to this commit, and reverting it fixes things.
      
      Link: https://lore.kernel.org/all/CAHk-=wg9hDde_L3bK9tAfdJ4N=TJJ+SjO3ZDONqH5=bVoy_Mzg@mail.gmail.com/
      Cc: Alex Deucher <alexdeucher@gmail.com>
      Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
      Cc: Harry Wentland <harry.wentland@amd.com>
      Cc: Dave Airlie <airlied@gmail.com>
      Cc: Christian Koenig <christian.koenig@amd.com>
      Cc: Jun Lei <Jun.Lei@amd.com>
      Cc: Mustapha Ghaddar <mustapha.ghaddar@amd.com>
      Cc: Bhawanpreet Lakha <Bhawanpreet.Lakha@amd.com>
      Cc: meenakshikumar somasundaram <meenakshikumar.somasundaram@amd.com>
      Cc: Daniel Wheeler <daniel.wheeler@amd.com>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      75b950ef
  8. 10 Jan, 2022 10 commits
    • Linus Torvalds's avatar
      Merge tag 'drm-next-2022-01-07' of git://anongit.freedesktop.org/drm/drm · 8d0749b4
      Linus Torvalds authored
      Pull drm updates from Dave Airlie:
       "Highlights are support for privacy screens found in new laptops, a
        bunch of nomodeset refactoring, and i915 enables ADL-P systems by
        default, while starting to add RPL-S support.
      
        vmwgfx adds GEM and support for OpenGL 4.3 features in userspace.
      
        Lots of internal refactorings around dma reservations, and lots of
        driver refactoring as well.
      
        Summary:
      
        core:
         - add privacy screen support
         - move nomodeset option into drm subsystem
         - clean up nomodeset handling in drivers
         - make drm_irq.c legacy
         - fix stack_depot name conflicts
         - remove DMA_BUF_SET_NAME ioctl restrictions
         - sysfs: send hotplug event
         - replace several DRM_* logging macros with drm_*
         - move hashtable to legacy code
         - add error return from gem_create_object
         - cma-helper: improve interfaces, drop CONFIG_DRM_KMS_CMA_HELPER
         - kernel.h related include cleanups
         - support XRGB2101010 source buffers
      
        ttm:
         - don't include drm hashtable
         - stop pruning fences after wait
         - documentation updates
      
        dma-buf:
         - add dma_resv selftest
         - add debugfs helpers
         - remove dma_resv_get_excl_unlocked
         - documentation
         - make fences mandatory in dma_resv_add_excl_fence
      
        dp:
         - add link training delay helpers
      
        gem:
         - link shmem/cma helpers into separate modules
         - use dma_resv iteratior
         - import dma-buf namespace into gem helper modules
      
        scheduler:
         - fence grab fix
         - lockdep fixes
      
        bridge:
         - switch to managed MIPI DSI helpers
         - register and attach during probe fixes
         - convert to YAML in several places.
      
        panel:
         - add bunch of new panesl
      
        simpledrm:
         - support FB_DAMAGE_CLIPS
         - support virtual screen sizes
         - add Apple M1 support
      
        amdgpu:
         - enable seamless boot for DCN 3.01
         - runtime PM fixes
         - use drm_kms_helper_connector_hotplug_event
         - get all fences at once
         - use generic drm fb helpers
         - PSR/DPCD/LTTPR/DSC/PM/RAS/OLED/SRIOV fixes
         - add smart trace buffer (STB) for supported GPUs
         - display debugfs entries
         - new SMU debug option
         - Documentation update
      
        amdkfd:
         - IP discovery enumeration refactor
         - interface between driver fixes
         - SVM fixes
         - kfd uapi header to define some sysfs bitfields.
      
        i915:
         - support VESA panel backlights
         - enable ADL-P by default
         - add eDP privacy screen support
         - add Raptor Lake S (RPL-S) support
         - DG2 page table support
         - lots of GuC/HuC fw refactoring
         - refactored i915->gt interfaces
         - CD clock squashing support
         - enable 10-bit gamma support
         - update ADL-P DMC fw to v2.14
         - enable runtime PM autosuspend by default
         - ADL-P DSI support
         - per-lane DP drive settings for ICL+
         - add support for pipe C/D DMC firmware
         - Atomic gamma LUT updates
         - remove CCS FB stride restrictions on ADL-P
         - VRR platform support for display 11
         - add support for display audio codec keepalive
         - lots of display refactoring
         - fix runtime PM handling during PXP suspend
         - improved eviction performance with async TTM moves
         - async VMA unbinding improvements
         - VMA locking refactoring
         - improved error capture robustness
         - use per device iommu checks
         - drop bits stealing from i915_sw_fence function ptr
         - remove dma_resv_prune
         - add IC cache invalidation on DG2
      
        nouveau:
         - crc fixes
         - validate LUTs in atomic check
         - set HDMI AVI RGB quant to full
      
        tegra:
         - buffer objects reworks for dma-buf compat
         - NVDEC driver uAPI support
         - power management improvements
      
        etnaviv:
         - IOMMU enabled system support
         - fix > 4GB command buffer mapping
         - close a DoS vector
         - fix spurious GPU resets
      
        ast:
         - fix i2c initialization
      
        rcar-du:
         - DSI output support
      
        exynos:
         - replace legacy gpio interface
         - implement generic GEM object mmap
      
        msm:
         - dpu plane state cleanup in prep for multirect
         - dpu debugfs cleanups
         - dp support for sc7280
         - a506 support
         - removal of struct_mutex
         - remove old eDP sub-driver
      
        anx7625:
         - support MIPI DSI input
         - support HDMI audio
         - fix reading EDID
      
        lvds:
         - fix bridge DT bindings
      
        megachips:
         - probe both bridges before registering
      
        dw-hdmi:
         - allow interlace on bridge
      
        ps8640:
         - enable runtime PM
         - support aux-bus
      
        tx358768:
         - enable reference clock
         - add pulse mode support
      
        ti-sn65dsi86:
         - use regmap bulk write
         - add PWM support
      
        etnaviv:
         - get all fences at once
      
        gma500:
         - gem object cleanups
      
        kmb:
         - enable fb console
      
        radeon:
         - use dma_resv_wait_timeout
      
        rockchip:
         - add DSP hold timeout
         - suspend/resume fixes
         - PLL clock fixes
         - implement mmap in GEM object functions
         - use generic fbdev emulation
      
        sun4i:
         - use CMA helpers without vmap support
      
        vc4:
         - fix HDMI-CEC hang with display is off
         - power on HDMI controller while disabling
         - support 4K@60Hz modes
         - support 10-bit YUV 4:2:0 output
      
        vmwgfx:
         - fix leak on probe errors
         - fail probing on broken hosts
         - new placement for MOB page tables
         - hide internal BOs from userspace
         - implement GEM support
         - implement GL 4.3 support
      
        virtio:
         - overflow fixes
      
        xen:
         - implement mmap as GEM object function
      
        omapdrm:
         - fix scatterlist export
         - support virtual planes
      
        mediatek:
         - MT8192 support
         - CMDQ refinement"
      
      * tag 'drm-next-2022-01-07' of git://anongit.freedesktop.org/drm/drm: (1241 commits)
        drm/amdgpu: no DC support for headless chips
        drm/amd/display: fix dereference before NULL check
        drm/amdgpu: always reset the asic in suspend (v2)
        drm/amdgpu: put SMU into proper state on runpm suspending for BOCO capable platform
        drm/amd/display: Fix the uninitialized variable in enable_stream_features()
        drm/amdgpu: fix runpm documentation
        amdgpu/pm: Make sysfs pm attributes as read-only for VFs
        drm/amdgpu: save error count in RAS poison handler
        drm/amdgpu: drop redundant semicolon
        drm/amd/display: get and restore link res map
        drm/amd/display: support dynamic HPO DP link encoder allocation
        drm/amd/display: access hpo dp link encoder only through link resource
        drm/amd/display: populate link res in both detection and validation
        drm/amd/display: define link res and make it accessible to all link interfaces
        drm/amd/display: 3.2.167
        drm/amd/display: [FW Promotion] Release 0.0.98
        drm/amd/display: Undo ODM combine
        drm/amd/display: Add reg defs for DCN303
        drm/amd/display: Changed pipe split policy to allow for multi-display pipe split
        drm/amd/display: Set optimize_pwr_state for DCN31
        ...
      8d0749b4
    • Linus Torvalds's avatar
      Merge tag 'linux-kselftest-kunit-5.17-rc1' of... · bf4eebf8
      Linus Torvalds authored
      Merge tag 'linux-kselftest-kunit-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull KUnit updates from Shuah Khan:
       "This consists of several fixes and enhancements. A few highlights:
      
         - Option --kconfig_add option allows easily tweaking kunitconfigs
      
         - make build subcommand can reconfigure if needed
      
         - doesn't error on tests without test plans
      
         - doesn't crash if no parameters are generated
      
         - defaults --jobs to # of cups
      
         - reports test parameter results as (K)TAP subtests"
      
      * tag 'linux-kselftest-kunit-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest:
        kunit: tool: Default --jobs to number of CPUs
        kunit: tool: fix newly introduced typechecker errors
        kunit: tool: make `build` subcommand also reconfigure if needed
        kunit: tool: delete kunit_parser.TestResult type
        kunit: tool: use dataclass instead of collections.namedtuple
        kunit: tool: suggest using decode_stacktrace.sh on kernel crash
        kunit: tool: reconfigure when the used kunitconfig changes
        kunit: tool: revamp message for invalid kunitconfig
        kunit: tool: add --kconfig_add to allow easily tweaking kunitconfigs
        kunit: tool: move Kconfig read_from_file/parse_from_string to package-level
        kunit: tool: print parsed test results fully incrementally
        kunit: Report test parameter results as (K)TAP subtests
        kunit: Don't crash if no parameters are generated
        kunit: tool: Report an error if any test has no subtests
        kunit: tool: Do not error on tests without test plans
        kunit: add run_checks.py script to validate kunit changes
        Documentation: kunit: remove claims that kunit is a mocking framework
        kunit: tool: fix --json output for skipped tests
      bf4eebf8
    • Linus Torvalds's avatar
      Merge tag 'linux-kselftest-next-5.17-rc1' of... · 4369b3ce
      Linus Torvalds authored
      Merge tag 'linux-kselftest-next-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull Kselftest update from Shuah Khan:
       "Fixes to build errors, false negatives, and several code cleanups,
        including the ARRAY_SIZE cleanup that removes 25+ duplicates
        ARRAY_SIZE defines from individual tests"
      
      * tag 'linux-kselftest-next-5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest:
        selftests/vm: remove ARRAY_SIZE define from individual tests
        selftests/timens: remove ARRAY_SIZE define from individual tests
        selftests/sparc64: remove ARRAY_SIZE define from adi-test
        selftests/seccomp: remove ARRAY_SIZE define from seccomp_benchmark
        selftests/rseq: remove ARRAY_SIZE define from individual tests
        selftests/net: remove ARRAY_SIZE define from individual tests
        selftests/landlock: remove ARRAY_SIZE define from common.h
        selftests/ir: remove ARRAY_SIZE define from ir_loopback.c
        selftests/core: remove ARRAY_SIZE define from close_range_test.c
        selftests/cgroup: remove ARRAY_SIZE define from cgroup_util.h
        selftests/arm64: remove ARRAY_SIZE define from vec-syscfg.c
        tools: fix ARRAY_SIZE defines in tools and selftests hdrs
        selftests: cgroup: build error multiple outpt files
        selftests/move_mount_set_group remove unneeded conversion to bool
        selftests/mount: remove unneeded conversion to bool
        selftests: harness: avoid false negatives if test has no ASSERTs
        selftests/ftrace: make kprobe profile testcase description unique
        selftests: clone3: clone3: add case CLONE3_ARGS_NO_TEST
        selftests: timers: Remove unneeded semicolon
        kselftests: timers:Remove unneeded semicolon
      4369b3ce
    • Linus Torvalds's avatar
      Merge tag 'slab-for-5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/vbabka/slab · ca1a46d6
      Linus Torvalds authored
      Pull slab updates from Vlastimil Babka:
      
       - Separate struct slab from struct page - an offshot of the page folio
         work.
      
         Struct page fields used by slab allocators are moved from struct page
         to a new struct slab, that uses the same physical storage. Similar to
         struct folio, it always is a head page. This brings better type
         safety, separation of large kmalloc allocations from true slabs, and
         cleanup of related objcg code.
      
       - A SLAB_MERGE_DEFAULT config optimization.
      
      * tag 'slab-for-5.17' of git://git.kernel.org/pub/scm/linux/kernel/git/vbabka/slab: (33 commits)
        mm/slob: Remove unnecessary page_mapcount_reset() function call
        bootmem: Use page->index instead of page->freelist
        zsmalloc: Stop using slab fields in struct page
        mm/slub: Define struct slab fields for CONFIG_SLUB_CPU_PARTIAL only when enabled
        mm/slub: Simplify struct slab slabs field definition
        mm/sl*b: Differentiate struct slab fields by sl*b implementations
        mm/kfence: Convert kfence_guarded_alloc() to struct slab
        mm/kasan: Convert to struct folio and struct slab
        mm/slob: Convert SLOB to use struct slab and struct folio
        mm/memcg: Convert slab objcgs from struct page to struct slab
        mm: Convert struct page to struct slab in functions used by other subsystems
        mm/slab: Finish struct page to struct slab conversion
        mm/slab: Convert most struct page to struct slab by spatch
        mm/slab: Convert kmem_getpages() and kmem_freepages() to struct slab
        mm/slub: Finish struct page to struct slab conversion
        mm/slub: Convert most struct page to struct slab by spatch
        mm/slub: Convert pfmemalloc_match() to take a struct slab
        mm/slub: Convert __free_slab() to use struct slab
        mm/slub: Convert alloc_slab_page() to return a struct slab
        mm/slub: Convert print_page_info() to print_slab_info()
        ...
      ca1a46d6
    • Linus Torvalds's avatar
      Merge branch 'random-5.17-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/crng/random · d93aebbd
      Linus Torvalds authored
      Pull random number generator updates from Jason Donenfeld:
       "These a bit more numerous than usual for the RNG, due to folks
        resubmitting patches that had been pending prior and generally renewed
        interest.
      
        There are a few categories of patches in here:
      
         1) Dominik Brodowski and I traded a series back and forth for a some
            weeks that fixed numerous issues related to seeds being provided
            at extremely early boot by the firmware, before other parts of the
            kernel or of the RNG have been initialized, both fixing some
            crashes and addressing correctness around early boot randomness.
            One of these is marked for stable.
      
         2) I replaced the RNG's usage of SHA-1 with BLAKE2s in the entropy
            extractor, and made the construction a bit safer and more
            standard. This was sort of a long overdue low hanging fruit, as we
            were supposed to have phased out SHA-1 usage quite some time ago
            (even if all we needed here was non-invertibility). Along the way
            it also made extraction 131% faster. This required a bit of
            Kconfig and symbol plumbing to make things work well with the
            crypto libraries, which is one of the reasons why I'm sending you
            this pull early in the cycle.
      
         3) I got rid of a truly superfluous call to RDRAND in the hot path,
            which resulted in a whopping 370% increase in performance.
      
         4) Sebastian Andrzej Siewior sent some patches regarding PREEMPT_RT,
            the full series of which wasn't ready yet, but the first two
            preparatory cleanups were good on their own. One of them touches
            files in kernel/irq/, which is the other reason why I'm sending
            you this pull early in the cycle.
      
         5) Other assorted correctness fixes from Eric Biggers, Jann Horn,
            Mark Brown, Dominik Brodowski, and myself"
      
      * 'random-5.17-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/crng/random:
        random: don't reset crng_init_cnt on urandom_read()
        random: avoid superfluous call to RDRAND in CRNG extraction
        random: early initialization of ChaCha constants
        random: use IS_ENABLED(CONFIG_NUMA) instead of ifdefs
        random: harmonize "crng init done" messages
        random: mix bootloader randomness into pool
        random: do not throw away excess input to crng_fast_load
        random: do not re-init if crng_reseed completes before primary init
        random: fix crash on multiple early calls to add_bootloader_randomness()
        random: do not sign extend bytes for rotation when mixing
        random: use BLAKE2s instead of SHA1 in extraction
        lib/crypto: blake2s: include as built-in
        random: fix data race on crng init time
        random: fix data race on crng_node_pool
        irq: remove unused flags argument from __handle_irq_event_percpu()
        random: remove unused irq_flags argument from add_interrupt_randomness()
        random: document add_hwgenerator_randomness() with other input functions
        MAINTAINERS: add git tree for random.c
      d93aebbd
    • Linus Torvalds's avatar
      Merge tag 'seccomp-v5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux · 9d3a1e0a
      Linus Torvalds authored
      Pull seccomp updates from Kees Cook:
       "The core seccomp code hasn't changed for this cycle, but the selftests
        were improved while helping to debug the recent signal handling
        refactoring work Eric did.
      
        Summary:
      
         - Improve seccomp selftests in support of signal handler refactoring
           (Kees Cook)"
      
      * tag 'seccomp-v5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
        selftests/seccomp: Report event mismatches more clearly
        selftests/seccomp: Stop USER_NOTIF test if kcmp() fails
      9d3a1e0a
    • Linus Torvalds's avatar
      Merge tag 'pstore-v5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux · 404dbad3
      Linus Torvalds authored
      Pull pstore update from Kees Cook:
      
       - Add boot param for early ftrace recording in pstore (Uwe
         Kleine-König)
      
      * tag 'pstore-v5.17-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
        pstore/ftrace: Allow immediate recording
      404dbad3
    • Linus Torvalds's avatar
      Merge tag 'edac_updates_for_v5.17_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/ras/ras · ff8be964
      Linus Torvalds authored
      Pull EDAC updates from Borislav Petkov:
      
       - Add support for version 3 of the Synopsys DDR controller to
         synopsys_edac
      
       - Add support for DRR5 and new models 0x10-0x1f and 0x50-0x5f of AMD
         family 0x19 CPUs to amd64_edac
      
       - The usual set of fixes and cleanups
      
      * tag 'edac_updates_for_v5.17_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/ras/ras:
        EDAC/amd64: Add support for family 19h, models 50h-5fh
        EDAC/sb_edac: Remove redundant initialization of variable rc
        RAS/CEC: Remove a repeated 'an' in a comment
        EDAC/amd64: Add support for AMD Family 19h Models 10h-1Fh and A0h-AFh
        EDAC: Add RDDR5 and LRDDR5 memory types
        EDAC/sifive: Fix non-kernel-doc comment
        dt-bindings: memory: Add entry for version 3.80a
        EDAC/synopsys: Enable the driver on Intel's N5X platform
        EDAC/synopsys: Add support for version 3 of the Synopsys EDAC DDR
        EDAC/synopsys: Use the quirk for version instead of ddr version
      ff8be964
    • Linus Torvalds's avatar
      Merge tag 'ras_core_for_v5.17_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 7e740ae6
      Linus Torvalds authored
      Pull RAS updates from Borislav Petkov:
       "A relatively big amount of movements in RAS-land this time around:
      
         - First part of a series to move the AMD address translation code
           from arch/x86/ to amd64_edac as that is its only user anyway
      
         - Some MCE error injection improvements to the AMD side
      
         - Reorganization of the #MC handler code and the facilities it calls
           to make it noinstr-safe
      
         - Add support for new AMD MCA bank types and non-uniform banks layout
      
         - The usual set of cleanups and fixes"
      
      * tag 'ras_core_for_v5.17_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (24 commits)
        x86/mce: Reduce number of machine checks taken during recovery
        x86/mce/inject: Avoid out-of-bounds write when setting flags
        x86/MCE/AMD, EDAC/mce_amd: Support non-uniform MCA bank type enumeration
        x86/MCE/AMD, EDAC/mce_amd: Add new SMCA bank types
        x86/mce: Check regs before accessing it
        x86/mce: Mark mce_start() noinstr
        x86/mce: Mark mce_timed_out() noinstr
        x86/mce: Move the tainting outside of the noinstr region
        x86/mce: Mark mce_read_aux() noinstr
        x86/mce: Mark mce_end() noinstr
        x86/mce: Mark mce_panic() noinstr
        x86/mce: Prevent severity computation from being instrumented
        x86/mce: Allow instrumentation during task work queueing
        x86/mce: Remove noinstr annotation from mce_setup()
        x86/mce: Use mce_rdmsrl() in severity checking code
        x86/mce: Remove function-local cpus variables
        x86/mce: Do not use memset to clear the banks bitmaps
        x86/mce/inject: Set the valid bit in MCA_STATUS before error injection
        x86/mce/inject: Check if a bank is populated before injecting
        x86/mce: Get rid of cpu_missing
        ...
      7e740ae6
    • Linus Torvalds's avatar
      Merge tag 'core_entry_for_v5.17_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 48a60bdb
      Linus Torvalds authored
      Pull thread_info flag accessor helper updates from Borislav Petkov:
       "Add a set of thread_info.flags accessors which snapshot it before
        accesing it in order to prevent any potential data races, and convert
        all users to those new accessors"
      
      * tag 'core_entry_for_v5.17_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        powerpc: Snapshot thread flags
        powerpc: Avoid discarding flags in system_call_exception()
        openrisc: Snapshot thread flags
        microblaze: Snapshot thread flags
        arm64: Snapshot thread flags
        ARM: Snapshot thread flags
        alpha: Snapshot thread flags
        sched: Snapshot thread flags
        entry: Snapshot thread flags
        x86: Snapshot thread flags
        thread_info: Add helpers to snapshot thread flags
      48a60bdb