1. 11 Nov, 2021 12 commits
    • Valentin Schneider's avatar
      preempt: Restore preemption model selection configs · a8b76910
      Valentin Schneider authored
      Commit c597bfdd ("sched: Provide Kconfig support for default dynamic
      preempt mode") changed the selectable config names for the preemption
      model. This means a config file must now select
      
        CONFIG_PREEMPT_BEHAVIOUR=y
      
      rather than
      
        CONFIG_PREEMPT=y
      
      to get a preemptible kernel. This means all arch config files would need to
      be updated - right now they'll all end up with the default
      CONFIG_PREEMPT_NONE_BEHAVIOUR.
      
      Rather than touch a good hundred of config files, restore usage of
      CONFIG_PREEMPT{_NONE, _VOLUNTARY}. Make them configure:
      o The build-time preemption model when !PREEMPT_DYNAMIC
      o The default boot-time preemption model when PREEMPT_DYNAMIC
      
      Add siblings of those configs with the _BUILD suffix to unconditionally
      designate the build-time preemption model (PREEMPT_DYNAMIC is built with
      the "highest" preemption model it supports, aka PREEMPT). Downstream
      configs should by now all be depending / selected by CONFIG_PREEMPTION
      rather than CONFIG_PREEMPT, so only a few sites need patching up.
      Signed-off-by: default avatarValentin Schneider <valentin.schneider@arm.com>
      Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
      Acked-by: default avatarMarco Elver <elver@google.com>
      Link: https://lore.kernel.org/r/20211110202448.4054153-2-valentin.schneider@arm.com
      a8b76910
    • Wang ShaoBo's avatar
      arch_topology: Fix missing clear cluster_cpumask in remove_cpu_topology() · 4cc4cc28
      Wang ShaoBo authored
      When testing cpu online and offline, warning happened like this:
      
      [  146.746743] WARNING: CPU: 92 PID: 974 at kernel/sched/topology.c:2215 build_sched_domains+0x81c/0x11b0
      [  146.749988] CPU: 92 PID: 974 Comm: kworker/92:2 Not tainted 5.15.0 #9
      [  146.750402] Hardware name: Huawei TaiShan 2280 V2/BC82AMDDA, BIOS 1.79 08/21/2021
      [  146.751213] Workqueue: events cpuset_hotplug_workfn
      [  146.751629] pstate: 00400009 (nzcv daif +PAN -UAO -TCO -DIT -SSBS BTYPE=--)
      [  146.752048] pc : build_sched_domains+0x81c/0x11b0
      [  146.752461] lr : build_sched_domains+0x414/0x11b0
      [  146.752860] sp : ffff800040a83a80
      [  146.753247] x29: ffff800040a83a80 x28: ffff20801f13a980 x27: ffff20800448ae00
      [  146.753644] x26: ffff800012a858e8 x25: ffff800012ea48c0 x24: 0000000000000000
      [  146.754039] x23: ffff800010ab7d60 x22: ffff800012f03758 x21: 000000000000005f
      [  146.754427] x20: 000000000000005c x19: ffff004080012840 x18: ffffffffffffffff
      [  146.754814] x17: 3661613030303230 x16: 30303078303a3239 x15: ffff800011f92b48
      [  146.755197] x14: ffff20be3f95cef6 x13: 2e6e69616d6f642d x12: 6465686373204c4c
      [  146.755578] x11: ffff20bf7fc83a00 x10: 0000000000000040 x9 : 0000000000000000
      [  146.755957] x8 : 0000000000000002 x7 : ffffffffe0000000 x6 : 0000000000000002
      [  146.756334] x5 : 0000000090000000 x4 : 00000000f0000000 x3 : 0000000000000001
      [  146.756705] x2 : 0000000000000080 x1 : ffff800012f03860 x0 : 0000000000000001
      [  146.757070] Call trace:
      [  146.757421]  build_sched_domains+0x81c/0x11b0
      [  146.757771]  partition_sched_domains_locked+0x57c/0x978
      [  146.758118]  rebuild_sched_domains_locked+0x44c/0x7f0
      [  146.758460]  rebuild_sched_domains+0x2c/0x48
      [  146.758791]  cpuset_hotplug_workfn+0x3fc/0x888
      [  146.759114]  process_one_work+0x1f4/0x480
      [  146.759429]  worker_thread+0x48/0x460
      [  146.759734]  kthread+0x158/0x168
      [  146.760030]  ret_from_fork+0x10/0x20
      [  146.760318] ---[ end trace 82c44aad6900e81a ]---
      
      For some architectures like risc-v and arm64 which use common code
      clear_cpu_topology() in shutting down CPUx, When CONFIG_SCHED_CLUSTER
      is set, cluster_sibling in cpu_topology of each sibling adjacent
      to CPUx is missed clearing, this causes checking failed in
      topology_span_sane() and rebuilding topology failure at end when CPU online.
      
      Different sibling's cluster_sibling in cpu_topology[] when CPU92 offline
      (CPU 92, 93, 94, 95 are in one cluster):
      
      Before revision:
      CPU                 [92]      [93]      [94]      [95]
      cluster_sibling     [92]     [92-95]   [92-95]   [92-95]
      
      After revision:
      CPU                 [92]      [93]      [94]      [95]
      cluster_sibling     [92]     [93-95]   [93-95]   [93-95]
      Signed-off-by: default avatarWang ShaoBo <bobo.shaobowang@huawei.com>
      Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
      Reviewed-by: default avatarDietmar Eggemann <dietmar.eggemann@arm.com>
      Acked-by: default avatarBarry Song <song.bao.hua@hisilicon.com>
      Tested-by: default avatarDietmar Eggemann <dietmar.eggemann@arm.com>
      Link: https://lore.kernel.org/r/20211110095856.469360-1-bobo.shaobowang@huawei.com
      4cc4cc28
    • Mathias Krause's avatar
      sched/fair: Prevent dead task groups from regaining cfs_rq's · b027789e
      Mathias Krause authored
      Kevin is reporting crashes which point to a use-after-free of a cfs_rq
      in update_blocked_averages(). Initial debugging revealed that we've
      live cfs_rq's (on_list=1) in an about to be kfree()'d task group in
      free_fair_sched_group(). However, it was unclear how that can happen.
      
      His kernel config happened to lead to a layout of struct sched_entity
      that put the 'my_q' member directly into the middle of the object
      which makes it incidentally overlap with SLUB's freelist pointer.
      That, in combination with SLAB_FREELIST_HARDENED's freelist pointer
      mangling, leads to a reliable access violation in form of a #GP which
      made the UAF fail fast.
      
      Michal seems to have run into the same issue[1]. He already correctly
      diagnosed that commit a7b359fc ("sched/fair: Correctly insert
      cfs_rq's to list on unthrottle") is causing the preconditions for the
      UAF to happen by re-adding cfs_rq's also to task groups that have no
      more running tasks, i.e. also to dead ones. His analysis, however,
      misses the real root cause and it cannot be seen from the crash
      backtrace only, as the real offender is tg_unthrottle_up() getting
      called via sched_cfs_period_timer() via the timer interrupt at an
      inconvenient time.
      
      When unregister_fair_sched_group() unlinks all cfs_rq's from the dying
      task group, it doesn't protect itself from getting interrupted. If the
      timer interrupt triggers while we iterate over all CPUs or after
      unregister_fair_sched_group() has finished but prior to unlinking the
      task group, sched_cfs_period_timer() will execute and walk the list of
      task groups, trying to unthrottle cfs_rq's, i.e. re-add them to the
      dying task group. These will later -- in free_fair_sched_group() -- be
      kfree()'ed while still being linked, leading to the fireworks Kevin
      and Michal are seeing.
      
      To fix this race, ensure the dying task group gets unlinked first.
      However, simply switching the order of unregistering and unlinking the
      task group isn't sufficient, as concurrent RCU walkers might still see
      it, as can be seen below:
      
          CPU1:                                      CPU2:
            :                                        timer IRQ:
            :                                          do_sched_cfs_period_timer():
            :                                            :
            :                                            distribute_cfs_runtime():
            :                                              rcu_read_lock();
            :                                              :
            :                                              unthrottle_cfs_rq():
          sched_offline_group():                             :
            :                                                walk_tg_tree_from(…,tg_unthrottle_up,…):
            list_del_rcu(&tg->list);                           :
       (1)  :                                                  list_for_each_entry_rcu(child, &parent->children, siblings)
            :                                                    :
       (2)  list_del_rcu(&tg->siblings);                         :
            :                                                    tg_unthrottle_up():
            unregister_fair_sched_group():                         struct cfs_rq *cfs_rq = tg->cfs_rq[cpu_of(rq)];
              :                                                    :
              list_del_leaf_cfs_rq(tg->cfs_rq[cpu]);               :
              :                                                    :
              :                                                    if (!cfs_rq_is_decayed(cfs_rq) || cfs_rq->nr_running)
       (3)    :                                                        list_add_leaf_cfs_rq(cfs_rq);
            :                                                      :
            :                                                    :
            :                                                  :
            :                                                :
            :                                              :
       (4)  :                                              rcu_read_unlock();
      
      CPU 2 walks the task group list in parallel to sched_offline_group(),
      specifically, it'll read the soon to be unlinked task group entry at
      (1). Unlinking it on CPU 1 at (2) therefore won't prevent CPU 2 from
      still passing it on to tg_unthrottle_up(). CPU 1 now tries to unlink
      all cfs_rq's via list_del_leaf_cfs_rq() in
      unregister_fair_sched_group().  Meanwhile CPU 2 will re-add some of
      these at (3), which is the cause of the UAF later on.
      
      To prevent this additional race from happening, we need to wait until
      walk_tg_tree_from() has finished traversing the task groups, i.e.
      after the RCU read critical section ends in (4). Afterwards we're safe
      to call unregister_fair_sched_group(), as each new walk won't see the
      dying task group any more.
      
      On top of that, we need to wait yet another RCU grace period after
      unregister_fair_sched_group() to ensure print_cfs_stats(), which might
      run concurrently, always sees valid objects, i.e. not already free'd
      ones.
      
      This patch survives Michal's reproducer[2] for 8h+ now, which used to
      trigger within minutes before.
      
        [1] https://lore.kernel.org/lkml/20211011172236.11223-1-mkoutny@suse.com/
        [2] https://lore.kernel.org/lkml/20211102160228.GA57072@blackbody.suse.cz/
      
      Fixes: a7b359fc ("sched/fair: Correctly insert cfs_rq's to list on unthrottle")
      [peterz: shuffle code around a bit]
      Reported-by: default avatarKevin Tanguy <kevin.tanguy@corp.ovh.com>
      Signed-off-by: default avatarMathias Krause <minipli@grsecurity.net>
      Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
      b027789e
    • Vincent Donnefort's avatar
      sched/core: Mitigate race cpus_share_cache()/update_top_cache_domain() · 42dc938a
      Vincent Donnefort authored
      Nothing protects the access to the per_cpu variable sd_llc_id. When testing
      the same CPU (i.e. this_cpu == that_cpu), a race condition exists with
      update_top_cache_domain(). One scenario being:
      
                    CPU1                            CPU2
        ==================================================================
      
        per_cpu(sd_llc_id, CPUX) => 0
                                          partition_sched_domains_locked()
            				      detach_destroy_domains()
        cpus_share_cache(CPUX, CPUX)          update_top_cache_domain(CPUX)
          per_cpu(sd_llc_id, CPUX) => 0
                                                per_cpu(sd_llc_id, CPUX) = CPUX
          per_cpu(sd_llc_id, CPUX) => CPUX
          return false
      
      ttwu_queue_cond() wouldn't catch smp_processor_id() == cpu and the result
      is a warning triggered from ttwu_queue_wakelist().
      
      Avoid a such race in cpus_share_cache() by always returning true when
      this_cpu == that_cpu.
      
      Fixes: 518cd623 ("sched: Only queue remote wakeups when crossing cache boundaries")
      Reported-by: default avatarJing-Ting Wu <jing-ting.wu@mediatek.com>
      Signed-off-by: default avatarVincent Donnefort <vincent.donnefort@arm.com>
      Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
      Reviewed-by: default avatarValentin Schneider <valentin.schneider@arm.com>
      Reviewed-by: default avatarVincent Guittot <vincent.guittot@linaro.org>
      Link: https://lore.kernel.org/r/20211104175120.857087-1-vincent.donnefort@arm.com
      42dc938a
    • Boris Ostrovsky's avatar
      x86/smp: Factor out parts of native_smp_prepare_cpus() · ce2612b6
      Boris Ostrovsky authored
      Commit 66558b73 ("sched: Add cluster scheduler level for x86")
      introduced cpu_l2c_shared_map mask which is expected to be initialized
      by smp_op.smp_prepare_cpus(). That commit only updated
      native_smp_prepare_cpus() version but not xen_pv_smp_prepare_cpus().
      As result Xen PV guests crash in set_cpu_sibling_map().
      
      While the new mask can be allocated in xen_pv_smp_prepare_cpus() one can
      see that both versions of smp_prepare_cpus ops share a number of common
      operations that can be factored out. So do that instead.
      
      Fixes: 66558b73 ("sched: Add cluster scheduler level for x86")
      Signed-off-by: default avatarBoris Ostrovsky <boris.ostrovsky@oracle.com>
      Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
      Reviewed-by: default avatarJuergen Gross <jgross@suse.com>
      Link: https://lkml.kernel.org/r/1635896196-18961-1-git-send-email-boris.ostrovsky@oracle.com
      ce2612b6
    • Linus Torvalds's avatar
      Merge tag 'ext4_for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4 · debe436e
      Linus Torvalds authored
      Pull ext4 updates from Ted Ts'o:
       "Only bug fixes and cleanups for ext4 this merge window.
      
        Of note are fixes for the combination of the inline_data and
        fast_commit fixes, and more accurately calculating when to schedule
        additional lazy inode table init, especially when CONFIG_HZ is 100HZ"
      
      * tag 'ext4_for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4:
        ext4: fix error code saved on super block during file system abort
        ext4: inline data inode fast commit replay fixes
        ext4: commit inline data during fast commit
        ext4: scope ret locally in ext4_try_to_trim_range()
        ext4: remove an unused variable warning with CONFIG_QUOTA=n
        ext4: fix boolreturn.cocci warnings in fs/ext4/name.c
        ext4: prevent getting empty inode buffer
        ext4: move ext4_fill_raw_inode() related functions
        ext4: factor out ext4_fill_raw_inode()
        ext4: prevent partial update of the extent blocks
        ext4: check for inconsistent extents between index and leaf block
        ext4: check for out-of-order index extents in ext4_valid_extent_entries()
        ext4: convert from atomic_t to refcount_t on ext4_io_end->count
        ext4: refresh the ext4_ext_path struct after dropping i_data_sem.
        ext4: ensure enough credits in ext4_ext_shift_path_extents
        ext4: correct the left/middle/right debug message for binsearch
        ext4: fix lazy initialization next schedule time computation in more granular unit
        Revert "ext4: enforce buffer head state assertion in ext4_da_map_blocks"
      debe436e
    • Linus Torvalds's avatar
      Merge tag 'for-5.16-deadlock-fix-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux · 6070dcc8
      Linus Torvalds authored
      Pull btrfs fix from David Sterba:
       "Fix for a deadlock when direct/buffered IO is done on a mmaped file
        and a fault happens (details in the patch). There's a fstest
        generic/647 that triggers the problem and makes testing hard"
      
      * tag 'for-5.16-deadlock-fix-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux:
        btrfs: fix deadlock due to page faults during direct IO reads and writes
      6070dcc8
    • Linus Torvalds's avatar
      Merge tag 'nfsd-5.16' of git://linux-nfs.org/~bfields/linux · 38764c73
      Linus Torvalds authored
      Pull nfsd updates from Bruce Fields:
       "A slow cycle for nfsd: mainly cleanup, including Neil's patch dropping
        support for a filehandle format deprecated 20 years ago, and further
        xdr-related cleanup from Chuck"
      
      * tag 'nfsd-5.16' of git://linux-nfs.org/~bfields/linux: (26 commits)
        nfsd4: remove obselete comment
        nfsd: document server-to-server-copy parameters
        NFSD:fix boolreturn.cocci warning
        nfsd: update create verifier comment
        SUNRPC: Change return value type of .pc_encode
        SUNRPC: Replace the "__be32 *p" parameter to .pc_encode
        NFSD: Save location of NFSv4 COMPOUND status
        SUNRPC: Change return value type of .pc_decode
        SUNRPC: Replace the "__be32 *p" parameter to .pc_decode
        SUNRPC: De-duplicate .pc_release() call sites
        SUNRPC: Simplify the SVC dispatch code path
        SUNRPC: Capture value of xdr_buf::page_base
        SUNRPC: Add trace event when alloc_pages_bulk() makes no progress
        svcrdma: Split svcrmda_wc_{read,write} tracepoints
        svcrdma: Split the svcrdma_wc_send() tracepoint
        svcrdma: Split the svcrdma_wc_receive() tracepoint
        NFSD: Have legacy NFSD WRITE decoders use xdr_stream_subsegment()
        SUNRPC: xdr_stream_subsegment() must handle non-zero page_bases
        NFSD: Initialize pointer ni with NULL and not plain integer 0
        NFSD: simplify struct nfsfh
        ...
      38764c73
    • Linus Torvalds's avatar
      Merge tag 'nfs-for-5.16-1' of git://git.linux-nfs.org/projects/trondmy/linux-nfs · 2ec20f48
      Linus Torvalds authored
      Pull NFS client updates from Trond Myklebust:
       "Highlights include:
      
        Features:
         - NFSv4.1 can always retrieve and cache the ACCESS mode on OPEN
         - Optimisations for READDIR and the 'ls -l' style workload
         - Further replacements of dprintk() with tracepoints and other
           tracing improvements
         - Ensure we re-probe NFSv4 server capabilities when the user does a
           "mount -o remount"
      
        Bugfixes:
         - Fix an Oops in pnfs_mark_request_commit()
         - Fix up deadlocks in the commit code
         - Fix regressions in NFSv2/v3 attribute revalidation due to the
           change_attr_type optimisations
         - Fix some dentry verifier races
         - Fix some missing dentry verifier settings
         - Fix a performance regression in nfs_set_open_stateid_locked()
         - SUNRPC was sending multiple SYN calls when re-establishing a TCP
           connection.
         - Fix multiple NFSv4 issues due to missing sanity checking of server
           return values
         - Fix a potential Oops when FREE_STATEID races with an unmount
      
        Cleanups:
         - Clean up the labelled NFS code
         - Remove unused header <linux/pnfs_osd_xdr.h>"
      
      * tag 'nfs-for-5.16-1' of git://git.linux-nfs.org/projects/trondmy/linux-nfs: (84 commits)
        NFSv4: Sanity check the parameters in nfs41_update_target_slotid()
        NFS: Remove the nfs4_label argument from decode_getattr_*() functions
        NFS: Remove the nfs4_label argument from nfs_setsecurity
        NFS: Remove the nfs4_label argument from nfs_fhget()
        NFS: Remove the nfs4_label argument from nfs_add_or_obtain()
        NFS: Remove the nfs4_label argument from nfs_instantiate()
        NFS: Remove the nfs4_label from the nfs_setattrres
        NFS: Remove the nfs4_label from the nfs4_getattr_res
        NFS: Remove the f_label from the nfs4_opendata and nfs_openres
        NFS: Remove the nfs4_label from the nfs4_lookupp_res struct
        NFS: Remove the label from the nfs4_lookup_res struct
        NFS: Remove the nfs4_label from the nfs4_link_res struct
        NFS: Remove the nfs4_label from the nfs4_create_res struct
        NFS: Remove the nfs4_label from the nfs_entry struct
        NFS: Create a new nfs_alloc_fattr_with_label() function
        NFS: Always initialise fattr->label in nfs_fattr_alloc()
        NFSv4.2: alloc_file_pseudo() takes an open flag, not an f_mode
        NFS: Don't allocate nfs_fattr on the stack in __nfs42_ssc_open()
        NFSv4: Remove unnecessary 'minor version' check
        NFSv4: Fix potential Oops in decode_op_map()
        ...
      2ec20f48
    • Linus Torvalds's avatar
      Merge branch 'exit-cleanups-for-v5.16' of... · 5147da90
      Linus Torvalds authored
      Merge branch 'exit-cleanups-for-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/user-namespace
      
      Pull exit cleanups from Eric Biederman:
       "While looking at some issues related to the exit path in the kernel I
        found several instances where the code is not using the existing
        abstractions properly.
      
        This set of changes introduces force_fatal_sig a way of sending a
        signal and not allowing it to be caught, and corrects the misuse of
        the existing abstractions that I found.
      
        A lot of the misuse of the existing abstractions are silly things such
        as doing something after calling a no return function, rolling BUG by
        hand, doing more work than necessary to terminate a kernel thread, or
        calling do_exit(SIGKILL) instead of calling force_sig(SIGKILL).
      
        In the review a deficiency in force_fatal_sig and force_sig_seccomp
        where ptrace or sigaction could prevent the delivery of the signal was
        found. I have added a change that adds SA_IMMUTABLE to change that
        makes it impossible to interrupt the delivery of those signals, and
        allows backporting to fix force_sig_seccomp
      
        And Arnd found an issue where a function passed to kthread_run had the
        wrong prototype, and after my cleanup was failing to build."
      
      * 'exit-cleanups-for-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/user-namespace: (23 commits)
        soc: ti: fix wkup_m3_rproc_boot_thread return type
        signal: Add SA_IMMUTABLE to ensure forced siganls do not get changed
        signal: Replace force_sigsegv(SIGSEGV) with force_fatal_sig(SIGSEGV)
        exit/r8188eu: Replace the macro thread_exit with a simple return 0
        exit/rtl8712: Replace the macro thread_exit with a simple return 0
        exit/rtl8723bs: Replace the macro thread_exit with a simple return 0
        signal/x86: In emulate_vsyscall force a signal instead of calling do_exit
        signal/sparc32: In setup_rt_frame and setup_fram use force_fatal_sig
        signal/sparc32: Exit with a fatal signal when try_to_clear_window_buffer fails
        exit/syscall_user_dispatch: Send ordinary signals on failure
        signal: Implement force_fatal_sig
        exit/kthread: Have kernel threads return instead of calling do_exit
        signal/s390: Use force_sigsegv in default_trap_handler
        signal/vm86_32: Properly send SIGSEGV when the vm86 state cannot be saved.
        signal/vm86_32: Replace open coded BUG_ON with an actual BUG_ON
        signal/sparc: In setup_tsb_params convert open coded BUG into BUG
        signal/powerpc: On swapcontext failure force SIGSEGV
        signal/sh: Use force_sig(SIGKILL) instead of do_group_exit(SIGKILL)
        signal/mips: Update (_save|_restore)_fp_context to fail with -EFAULT
        signal/sparc32: Remove unreachable do_exit in do_sparc_fault
        ...
      5147da90
    • Linus Torvalds's avatar
      Merge tag 'kernel.sys.v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux · a41b7445
      Linus Torvalds authored
      Pull prctl updates from Christian Brauner:
       "This contains the missing prctl uapi pieces for PR_SCHED_CORE.
      
        In order to activate core scheduling the caller is expected to specify
        the scope of the new core scheduling domain.
      
        For example, passing 2 in the 4th argument of
      
           prctl(PR_SCHED_CORE, PR_SCHED_CORE_CREATE, <pid>,  2, 0);
      
        would indicate that the new core scheduling domain encompasses all
        tasks in the process group of <pid>. Specifying 0 would only create a
        core scheduling domain for the thread identified by <pid> and 2 would
        encompass the whole thread-group of <pid>.
      
        Note, the values 0, 1, and 2 correspond to PIDTYPE_PID, PIDTYPE_TGID,
        and PIDTYPE_PGID. A first version tried to expose those values
        directly to which I objected because:
      
         - PIDTYPE_* is an enum that is kernel internal which we should not
           expose to userspace directly.
      
         - PIDTYPE_* indicates what a given struct pid is used for it doesn't
           express a scope.
      
        But what the 4th argument of PR_SCHED_CORE prctl() expresses is the
        scope of the operation, i.e. the scope of the core scheduling domain
        at creation time. So Eugene's patch now simply introduces three new
        defines PR_SCHED_CORE_SCOPE_THREAD, PR_SCHED_CORE_SCOPE_THREAD_GROUP,
        and PR_SCHED_CORE_SCOPE_PROCESS_GROUP. They simply express what
        happens.
      
        This has been on the mailing list for quite a while with all relevant
        scheduler folks Cced. I announced multiple times that I'd pick this up
        if I don't see or her anyone else doing it. None of this touches
        proper scheduler code but only concerns uapi so I think this is fine.
      
        With core scheduling being quite common now for vm managers (e.g.
        moving individual vcpu threads into their own core scheduling domain)
        and container managers (e.g. moving the init process into its own core
        scheduling domain and letting all created children inherit it) having
        to rely on raw numbers passed as the 4th argument in prctl() is a bit
        annoying and everyone is starting to come up with their own defines"
      
      * tag 'kernel.sys.v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux:
        uapi/linux/prctl: provide macro definitions for the PR_SCHED_CORE type argument
      a41b7445
    • Linus Torvalds's avatar
      Merge tag 'pidfd.v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux · 6752de1a
      Linus Torvalds authored
      Pull pidfd updates from Christian Brauner:
       "Various places in the kernel have picked up pidfds.
      
        The two most recent additions have probably been the ability to use
        pidfds in bpf maps and the usage of pidfds in mm-based syscalls such
        as process_mrelease() and process_madvise().
      
        The same pattern to turn a pidfd into a struct task exists in two
        places. One of those places used PIDTYPE_TGID while the other one used
        PIDTYPE_PID even though it is clearly documented in all pidfd-helpers
        that pidfds __currently__ only refer to thread-group leaders (subject
        to change in the future if need be).
      
        This isn't a bug per se but has the potential to be one if we allow
        pidfds to refer to individual threads. If that happens we want to
        audit all codepaths that make use of them to ensure they can deal with
        pidfds refering to individual threads.
      
        This adds a simple helper to turn a pidfd into a struct task making it
        easy to grep for such places. Plus, it gets rid of code-duplication"
      
      * tag 'pidfd.v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux:
        mm: use pidfd_get_task()
        pid: add pidfd_get_task() helper
      6752de1a
  2. 10 Nov, 2021 18 commits
    • Linus Torvalds's avatar
      Merge tag 'thermal-5.16-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · 88100752
      Linus Torvalds authored
      Pull more thermal control updates from Rafael Wysocki:
       "These fix two issues in the thermal core and one in the int340x
        thermal driver.
      
        Specifics:
      
         - Replace pr_warn() with pr_warn_once() in user_space_bind() to
           reduce kernel log noise (Rafael Wysocki).
      
         - Extend the RFIM mailbox interface in the int340x thermal driver to
           return 64 bit values to allow all values returned by the hardware
           to be handled correctly (Srinivas Pandruvada).
      
         - Fix possible NULL pointer dereferences in the of_thermal_ family of
           functions (Subbaraman Narayanamurthy)"
      
      * tag 'thermal-5.16-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
        thermal: Replace pr_warn() with pr_warn_once() in user_space_bind()
        thermal: Fix NULL pointer dereferences in of_thermal_ functions
        thermal/drivers/int340x: processor_thermal: Suppot 64 bit RFIM responses
      88100752
    • Linus Torvalds's avatar
      Merge tag 'pm-5.16-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · d422555f
      Linus Torvalds authored
      Pull more power management updates from Rafael Wysocki:
       "These fix three intel_pstate driver regressions, fix locking in the
        core code suspending and resuming devices during system PM
        transitions, fix the handling of cpuidle drivers based on runtime PM
        during system-wide suspend, fix two issues in the operating
        performance points (OPP) framework and resource-managed helpers to it.
      
        Specifics:
      
         - Fix two intel_pstate driver regressions related to the HWP
           interrupt handling added recently (Srinivas Pandruvada).
      
         - Fix intel_pstate driver regression introduced during the 5.11 cycle
           and causing HWP desired performance to be mishandled in some cases
           when switching driver modes and during system suspend and shutdown
           (Rafael Wysocki).
      
         - Fix system-wide device suspend and resume locking to avoid
           deadlocks when device objects are deleted during a system-wide PM
           transition (Rafael Wysocki).
      
         - Modify system-wide suspend of devices to prevent cpuidle drivers
           based on runtime PM from misbehaving during the "no IRQ" phase of
           it (Ulf Hansson).
      
         - Fix return value of _opp_add_static_v2() helper (YueHaibing).
      
         - Fix required-opp handle count (Pavankumar Kondeti).
      
         - Add resource managed OPP helpers, update dev_pm_opp_attach_genpd(),
           update their devfreq users, and make minor DT binding change
           (Dmitry Osipenko)"
      
      * tag 'pm-5.16-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
        PM: sleep: Avoid calling put_device() under dpm_list_mtx
        cpufreq: intel_pstate: Clear HWP Status during HWP Interrupt enable
        cpufreq: intel_pstate: Fix unchecked MSR 0x773 access
        cpufreq: intel_pstate: Clear HWP desired on suspend/shutdown and offline
        PM: sleep: Fix runtime PM based cpuidle support
        dt-bindings: opp: Allow multi-worded OPP entry name
        opp: Fix return in _opp_add_static_v2()
        PM / devfreq: tegra30: Check whether clk_round_rate() returns zero rate
        PM / devfreq: tegra30: Use resource-managed helpers
        PM / devfreq: Add devm_devfreq_add_governor()
        opp: Add more resource-managed variants of dev_pm_opp_of_add_table()
        opp: Change type of dev_pm_opp_attach_genpd(names) argument
        opp: Fix required-opps phandle array count check
      d422555f
    • Linus Torvalds's avatar
      Merge tag 'acpi-5.16-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · 285fc3db
      Linus Torvalds authored
      Pull more ACPI updates from Rafael Wysocki:
       "These add support for a new ACPI device configuration object called
        _DSC, fix some issues including one recent regression, add two new
        items to quirk lists and clean up assorted pieces of code.
      
        Specifics:
      
         - Add support for new ACPI device configuration object called _DSC
           ("Deepest State for Configuration") to allow certain devices to be
           probed without changing their power states, document it and make
           two drivers use it (Sakari Ailus, Rajmohan Mani).
      
         - Fix device wakeup power reference counting broken recently by
           mistake (Rafael Wysocki).
      
         - Drop unused symbol and macros depending on it from acgcc.h (Rafael
           Wysocki).
      
         - Add HP ZHAN 66 Pro to the "no EC wakeup" quirk list (Binbin Zhou).
      
         - Add Xiaomi Mi Pad 2 to the backlight quirk list and drop an unused
           piece of data from all of the list entries (Hans de Goede).
      
         - Fix register read accesses handling in the Intel PMIC operation
           region driver (Hans de Goede).
      
         - Clean up static variables initialization in the EC driver
           (wangzhitong)"
      
      * tag 'acpi-5.16-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
        Documentation: ACPI: Fix non-D0 probe _DSC object example
        ACPI: Drop ACPI_USE_BUILTIN_STDARG ifdef from acgcc.h
        ACPI: PM: Fix device wakeup power reference counting error
        ACPI: video: use platform backlight driver on Xiaomi Mi Pad 2
        ACPI: video: Drop dmi_system_id.ident settings from video_detect_dmi_table[]
        ACPI: PMIC: Fix intel_pmic_regs_handler() read accesses
        ACPI: EC: Remove initialization of static variables to false
        ACPI: EC: Use ec_no_wakeup on HP ZHAN 66 Pro
        at24: Support probing while in non-zero ACPI D state
        media: i2c: imx319: Support device probe in non-zero ACPI D state
        ACPI: Add a convenience function to tell a device is in D0 state
        Documentation: ACPI: Document _DSC object usage for enum power state
        i2c: Allow an ACPI driver to manage the device's power state during probe
        ACPI: scan: Obtain device's desired enumeration power state
      285fc3db
    • Linus Torvalds's avatar
      Merge tag 'dmaengine-5.16-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/vkoul/dmaengine · e68a7d35
      Linus Torvalds authored
      Pull dmaengine updates from Vinod Koul:
       "A bunch of driver updates, no new driver or controller support this
        time though:
      
         - Another pile of idxd updates
      
         - pm routines cleanup for at_xdmac driver
      
         - Correct handling of callback_result for few drivers
      
         - zynqmp_dma driver updates and descriptor management refinement
      
         - Hardware handshaking support for dw-axi-dmac
      
         - Support for remotely powered controllers in Qcom bam dma
      
         - tegra driver updates"
      
      * tag 'dmaengine-5.16-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/vkoul/dmaengine: (69 commits)
        dmaengine: ti: k3-udma: Set r/tchan or rflow to NULL if request fail
        dmaengine: ti: k3-udma: Set bchan to NULL if a channel request fail
        dmaengine: stm32-dma: avoid 64-bit division in stm32_dma_get_max_width
        dmaengine: fsl-edma: support edma memcpy
        dmaengine: idxd: fix resource leak on dmaengine driver disable
        dmaengine: idxd: cleanup completion record allocation
        dmaengine: zynqmp_dma: Correctly handle descriptor callbacks
        dmaengine: xilinx_dma: Correctly handle cyclic descriptor callbacks
        dmaengine: altera-msgdma: Correctly handle descriptor callbacks
        dmaengine: at_xdmac: fix compilation warning
        dmaengine: dw-axi-dmac: Simplify assignment in dma_chan_pause()
        dmaengine: qcom: bam_dma: Add "powered remotely" mode
        dt-bindings: dmaengine: bam_dma: Add "powered remotely" mode
        dmaengine: sa11x0: Mark PM functions as __maybe_unused
        dmaengine: switch from 'pci_' to 'dma_' API
        dmaengine: ioat: switch from 'pci_' to 'dma_' API
        dmaengine: hsu: switch from 'pci_' to 'dma_' API
        dmaengine: hisi_dma: switch from 'pci_' to 'dma_' API
        dmaengine: dw: switch from 'pci_' to 'dma_' API
        dmaengine: dw-edma-pcie: switch from 'pci_' to 'dma_' API
        ...
      e68a7d35
    • Linus Torvalds's avatar
      Merge tag 'tag-chrome-platform-for-v5.16' of... · d4efc0de
      Linus Torvalds authored
      Merge tag 'tag-chrome-platform-for-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/chrome-platform/linux
      
      Pull chrome platform updates from Benson Leung:
       "cros_ec_typec:
      
         - Clean up use of cros_ec_check_features
      
        cros_ec_*:
      
         - Rename and move cros_ec_pd_command to cros_ec_command, and make
           changes to cros_ec_typec and cros_ec_proto to use the new common
           command, reducing duplication.
      
        sensorhub:
      
         - simplify getting .driver_data in cros_ec_sensors_core and
           cros_ec_sensorhub
      
        misc:
      
         - Maintainership change. Enric Balletbo i Serra has moved on from
           Collabora, so removing him from chrome/platform maintainers. Thanks
           for all of your hard work maintaining this, Enric, and best of luck
           to you in your new role!
      
         - Add Prashant Malani as driver maintainer for cros_ec_typec.c and
           cros_usbpd_notify. He was already principal contributor of these
           drivers"
      
      * tag 'tag-chrome-platform-for-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/chrome-platform/linux:
        platform/chrome: cros_ec_proto: Use ec_command for check_features
        platform/chrome: cros_ec_proto: Use EC struct for features
        MAINTAINERS: Chrome: Drop Enric Balletbo i Serra
        platform/chrome: cros_ec_typec: Use cros_ec_command()
        platform/chrome: cros_ec_proto: Add version for ec_command
        platform/chrome: cros_ec_proto: Make data pointers void
        platform/chrome: cros_usbpd_notify: Move ec_command()
        platform/chrome: cros_usbpd_notify: Rename cros_ec_pd_command()
        platform/chrome: cros_ec: Fix spelling mistake "responsed" -> "response"
        platform/chrome: cros_ec_sensorhub: simplify getting .driver_data
        iio: common: cros_ec_sensors: simplify getting .driver_data
        platform/chrome: cros-ec-typec: Cleanup use of check_features
        platform/chrome: cros_ec_proto: Fix check_features ret val
        MAINTAINERS: Add Prashant's maintainership of cros_ec drivers
      d4efc0de
    • Linus Torvalds's avatar
      Merge tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux · 89fa0be0
      Linus Torvalds authored
      Pull arm64 fixes from Will Deacon:
      
       - Fix double-evaluation of 'pte' macro argument when using 52-bit PAs
      
       - Fix signedness of some MTE prctl PR_* constants
      
       - Fix kmemleak memory usage by skipping early pgtable allocations
      
       - Fix printing of CPU feature register strings
      
       - Remove redundant -nostdlib linker flag for vDSO binaries
      
      * tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux:
        arm64: pgtable: make __pte_to_phys/__phys_to_pte_val inline functions
        arm64: Track no early_pgtable_alloc() for kmemleak
        arm64: mte: change PR_MTE_TCF_NONE back into an unsigned long
        arm64: vdso: remove -nostdlib compiler flag
        arm64: arm64_ftr_reg->name may not be a human-readable string
      89fa0be0
    • Linus Torvalds's avatar
      Merge tag 'arm-fixes-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc · 3f55f177
      Linus Torvalds authored
      Pull ARM SoC fixes from Arnd Bergmann:
       "This is one set of fixes for the NXP/FSL DPAA2 drivers, addressing a
        few minor issues. I received these just after sending out the last
        v5.15 fixes, and nothing in here seemed urgent enough for a quick
        follow-up"
      
      * tag 'arm-fixes-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc:
        soc: fsl: dpaa2-console: free buffer before returning from dpaa2_console_read
        soc: fsl: dpio: use the combined functions to protect critical zone
        soc: fsl: dpio: replace smp_processor_id with raw_smp_processor_id
      3f55f177
    • Linus Torvalds's avatar
      Merge tag 'asm-generic-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic · e8f023ca
      Linus Torvalds authored
      Pull asm-generic cleanup from Arnd Bergmann:
       "This is a single cleanup from Peter Collingbourne, removing some dead
        code"
      
      * tag 'asm-generic-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic:
        arch: remove unused function syscall_set_arguments()
      e8f023ca
    • Linus Torvalds's avatar
      Merge tag 'for-linus-5.16b-rc1-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip · bf98ecbb
      Linus Torvalds authored
      Pull xen updates from Juergen Gross:
      
       - a series to speed up the boot of Xen PV guests
      
       - some cleanups in Xen related code
      
       - replacement of license texts with the appropriate SPDX headers and
         fixing of wrong SPDX headers in Xen header files
      
       - a small series making paravirtualized interrupt masking much simpler
         and at the same time removing complaints of objtool
      
       - a fix for Xen ballooning hogging workqueues for too long
      
       - enablement of the Xen pciback driver for Arm
      
       - some further small fixes/enhancements
      
      * tag 'for-linus-5.16b-rc1-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip: (22 commits)
        xen/balloon: fix unused-variable warning
        xen/balloon: rename alloc/free_xenballooned_pages
        xen/balloon: add late_initcall_sync() for initial ballooning done
        x86/xen: remove 32-bit awareness from startup_xen
        xen: remove highmem remnants
        xen: allow pv-only hypercalls only with CONFIG_XEN_PV
        x86/xen: remove 32-bit pv leftovers
        xen-pciback: allow compiling on other archs than x86
        x86/xen: switch initial pvops IRQ functions to dummy ones
        x86/xen: remove xen_have_vcpu_info_placement flag
        x86/pvh: add prototype for xen_pvh_init()
        xen: Fix implicit type conversion
        xen: fix wrong SPDX headers of Xen related headers
        xen/pvcalls-back: Remove redundant 'flush_workqueue()' calls
        x86/xen: Remove redundant irq_enter/exit() invocations
        xen-pciback: Fix return in pm_ctrl_init()
        xen/x86: restrict PV Dom0 identity mapping
        xen/x86: there's no highmem anymore in PV mode
        xen/x86: adjust handling of the L3 user vsyscall special page table
        xen/x86: adjust xen_set_fixmap()
        ...
      bf98ecbb
    • Linus Torvalds's avatar
      Merge tag 'libnvdimm-for-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm · 4287af35
      Linus Torvalds authored
      Pull libnvdimm update from Dan Williams:
       "A single cleanup that precedes some deeper PMEM/DAX reworks that did
        not settle in time for v5.16:
      
         - Continue the cleanup of the dax api in preparation for a dax-device
           block-device divorce"
      
      * tag 'libnvdimm-for-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm:
        nvdimm/pmem: move dax_attribute_group from dax to pmem
      4287af35
    • Linus Torvalds's avatar
      Merge tag 'linux-watchdog-5.16-rc1' of git://www.linux-watchdog.org/linux-watchdog · 89d714ab
      Linus Torvalds authored
      Pull watchdog updates from Wim Van Sebroeck:
      
       - f71808e_wdt: convert to watchdog framework
      
       - db8500_wdt: Rename driver (was ux500_wdt.c)
      
       - sunxi: Add compatibles for R329 and D1
      
       - mtk: add disable_wdt_extrst support
      
       - several other small fixes and improvements
      
      * tag 'linux-watchdog-5.16-rc1' of git://www.linux-watchdog.org/linux-watchdog: (30 commits)
        watchdog: db8500_wdt: Rename symbols
        watchdog: db8500_wdt: Rename driver
        watchdog: ux500_wdt: Drop platform data
        watchdog: bcm63xx_wdt: fix fallthrough warning
        watchdog: iTCO_wdt: No need to stop the timer in probe
        watchdog: s3c2410: describe driver in KConfig
        watchdog: sp5100_tco: Add support for get_timeleft
        watchdog: mtk: add disable_wdt_extrst support
        dt-bindings: watchdog: mtk-wdt: add disable_wdt_extrst support
        watchdog: rza_wdt: Use semicolons instead of commas
        watchdog: mlx-wdt: Use regmap_write_bits()
        watchdog: rti-wdt: Make use of the helper function devm_platform_ioremap_resource()
        watchdog: iTCO_wdt: Make use of the helper function devm_platform_ioremap_resource()
        watchdog: ar7_wdt: Make use of the helper function devm_platform_ioremap_resource_byname()
        watchdog: sunxi_wdt: Add support for D1
        dt-bindings: watchdog: sunxi: Add compatibles for D1
        ar7: fix kernel builds for compiler test
        dt-bindings: watchdog: sunxi: Add compatibles for R329
        watchdog: meson_gxbb_wdt: add timeout parameter
        watchdog: meson_gxbb_wdt: add nowayout parameter
        ...
      89d714ab
    • Linus Torvalds's avatar
      Merge tag 'rproc-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/remoteproc/linux · bd485d27
      Linus Torvalds authored
      Pull remoteproc updates from Bjorn Andersson:
       "The remoteproc repo is moved to a new path on git.kernel.org, to allow
        Mathieu push access to the branches.
      
        Support for the Mediatek MT8195 SCP was added, the related DeviceTree
        binding was converted to YAML and MT8192 SCP was documented as well.
      
        Amlogic Meson6, Meson8, Meson8b and Meson8m2 has an ARC core to aid in
        resuming the system after suspend, a new remoteproc driver for booting
        this core is introduced.
      
        A new driver to support the DSP processor found on NXP i.MX8QM,
        i.MX8QXP, i.MX8MP and i.MX8ULP is added.
      
        The Qualcomm modem and TrustZone based remoteproc drivers gains
        support for the modem in SC7280 and MSM8996 gains support for a
        missing power-domain.
      
        Throughout the Qualcomm drivers, the support for informing the
        always-on power coprocessor about the state of each remoteproc is
        reworked to avoid complications related to our use of genpd and the
        system suspend state.
      
        Lastly a number of small fixes are found throughout the drivers and
        framework"
      
      * tag 'rproc-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/remoteproc/linux: (39 commits)
        remoteproc: Remove vdev_to_rvdev and vdev_to_rproc from remoteproc API
        remoteproc: omap_remoteproc: simplify getting .driver_data
        remoteproc: qcom_q6v5_mss: Use devm_platform_ioremap_resource_byname() to simplify code
        remoteproc: Fix a memory leak in an error handling path in 'rproc_handle_vdev()'
        remoteproc: Fix spelling mistake "atleast" -> "at least"
        remoteproc: imx_dsp_rproc: mark PM functions as __maybe_unused
        remoteproc: imx_dsp_rproc: Correct the comment style of copyright
        dt-bindings: dsp: fsl: Update binding document for remote proc driver
        remoteproc: imx_dsp_rproc: Add remoteproc driver for DSP on i.MX
        remoteproc: imx_rproc: Add IMX_RPROC_SCU_API method
        remoteproc: imx_rproc: Move common structure to header file
        rpmsg: char: Remove useless include
        remoteproc: meson-mx-ao-arc: fix a bit test
        remoteproc: mss: q6v5-mss: Add modem support on SC7280
        dt-bindings: remoteproc: qcom: Update Q6V5 Modem PIL binding
        remoteproc: qcom: pas: Add SC7280 Modem support
        dt-bindings: remoteproc: qcom: pas: Add SC7280 MPSS support
        remoteproc: qcom: pas: Use the same init resources for MSM8996 and MSM8998
        MAINTAINERS: Update remoteproc repo url
        dt-bindings: remoteproc: k3-dsp: Cleanup SoC compatible from DT example
        ...
      bd485d27
    • Linus Torvalds's avatar
      Merge tag 'rpmsg-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/remoteproc/linux · becc1fb4
      Linus Torvalds authored
      Pull rpmsg updates from Bjorn Andersson:
       "For the GLINK implementation this adds support for splitting outgoing
        messages that are too large to fit in the fifo, it introduces the use
        of "read notifications", to avoid polling in the case where the
        outgoing fifo is full and a few bugs are squashed.
      
        The return value of rpmsg_create_ept() for when RPMSG is disabled is
        corrected to return a valid error, the Mediatek rpmsg driver is
        updated to match the DT binding and a couple of cleanups are done in
        the virtio rpmsg driver"
      
      * tag 'rpmsg-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/remoteproc/linux:
        rpmsg: glink: Send READ_NOTIFY command in FIFO full case
        rpmsg: glink: Remove channel decouple from rpdev release
        rpmsg: glink: Remove the rpmsg dev in close_ack
        rpmsg: glink: Add TX_DATA_CONT command while sending
        rpmsg: virtio_rpmsg_bus: use dev_warn_ratelimited for msg with no recipient
        rpmsg: virtio: Remove unused including <linux/of_device.h>
        rpmsg: Change naming of mediatek rpmsg property
        rpmsg: Fix rpmsg_create_ept return when RPMSG config is not defined
        rpmsg: glink: Replace strncpy() with strscpy_pad()
      becc1fb4
    • Rafael J. Wysocki's avatar
      Merge branch 'thermal-int340x' · 61988e0a
      Rafael J. Wysocki authored
      Merge int340x thermal driver fix for 5.16-rc1.
      
      * thermal-int340x:
        thermal/drivers/int340x: processor_thermal: Suppot 64 bit RFIM responses
      61988e0a
    • Rafael J. Wysocki's avatar
      Merge branches 'pm-opp' and 'pm-cpufreq' · dcc0b6f2
      Rafael J. Wysocki authored
      Merge operating performance points (OPP) framework updates for and
      intel_pstate driver fixes for 5.16-rc1.
      
      * pm-opp:
        dt-bindings: opp: Allow multi-worded OPP entry name
        opp: Fix return in _opp_add_static_v2()
        PM / devfreq: tegra30: Check whether clk_round_rate() returns zero rate
        PM / devfreq: tegra30: Use resource-managed helpers
        PM / devfreq: Add devm_devfreq_add_governor()
        opp: Add more resource-managed variants of dev_pm_opp_of_add_table()
        opp: Change type of dev_pm_opp_attach_genpd(names) argument
        opp: Fix required-opps phandle array count check
      
      * pm-cpufreq:
        cpufreq: intel_pstate: Clear HWP Status during HWP Interrupt enable
        cpufreq: intel_pstate: Fix unchecked MSR 0x773 access
        cpufreq: intel_pstate: Clear HWP desired on suspend/shutdown and offline
      dcc0b6f2
    • Rafael J. Wysocki's avatar
      Merge branches 'acpica', 'acpi-ec', 'acpi-pmic' and 'acpi-video' · 314c6e2b
      Rafael J. Wysocki authored
      Merge assorted fixes and cleanups and one new backlight quirk list
      item for 5.16-rc1.
      
      * acpica:
        ACPI: Drop ACPI_USE_BUILTIN_STDARG ifdef from acgcc.h
      
      * acpi-ec:
        ACPI: EC: Remove initialization of static variables to false
        ACPI: EC: Use ec_no_wakeup on HP ZHAN 66 Pro
      
      * acpi-pmic:
        ACPI: PMIC: Fix intel_pmic_regs_handler() read accesses
      
      * acpi-video:
        ACPI: video: use platform backlight driver on Xiaomi Mi Pad 2
        ACPI: video: Drop dmi_system_id.ident settings from video_detect_dmi_table[]
      314c6e2b
    • Rafael J. Wysocki's avatar
      Merge branch 'acpi-dsc' · 2c49daba
      Rafael J. Wysocki authored
      Merge new ACPI device configuration object _DSC support for 5.16-rc1.
      
      * acpi-dsc:
        Documentation: ACPI: Fix non-D0 probe _DSC object example
        at24: Support probing while in non-zero ACPI D state
        media: i2c: imx319: Support device probe in non-zero ACPI D state
        ACPI: Add a convenience function to tell a device is in D0 state
        Documentation: ACPI: Document _DSC object usage for enum power state
        i2c: Allow an ACPI driver to manage the device's power state during probe
        ACPI: scan: Obtain device's desired enumeration power state
      2c49daba
    • Sakari Ailus's avatar
      Documentation: ACPI: Fix non-D0 probe _DSC object example · dff5acfd
      Sakari Ailus authored
      The original patch adding the example used _DSC Name when Method was
      intended. Fix this.
      
      Also replace spaces used for indentation with tabs in the example.
      
      Fixes: ed66f12b ("Documentation: ACPI: Document _DSC object usage for enum power state")
      Reported-by: default avatarBingbu Cao <bingbu.cao@intel.com>
      Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
      Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
      dff5acfd
  3. 09 Nov, 2021 10 commits
    • Linus Torvalds's avatar
      Merge tag 'for-5.16/drivers-2021-11-09' of git://git.kernel.dk/linux-block · cb690f52
      Linus Torvalds authored
      Pull more block driver updates from Jens Axboe:
      
       - Last series adding error handling support for add_disk() in drivers.
         After this one, and once the SCSI side has been merged, we can
         finally annotate add_disk() as must_check. (Luis)
      
       - bcache fixes (Coly)
      
       - zram fixes (Ming)
      
       - ataflop locking fix (Tetsuo)
      
       - nbd fixes (Ye, Yu)
      
       - MD merge via Song
            - Cleanup (Yang)
            - sysfs fix (Guoqing)
      
       - Misc fixes (Geert, Wu, luo)
      
      * tag 'for-5.16/drivers-2021-11-09' of git://git.kernel.dk/linux-block: (34 commits)
        bcache: Revert "bcache: use bvec_virt"
        ataflop: Add missing semicolon to return statement
        floppy: address add_disk() error handling on probe
        ataflop: address add_disk() error handling on probe
        block: update __register_blkdev() probe documentation
        ataflop: remove ataflop_probe_lock mutex
        mtd/ubi/block: add error handling support for add_disk()
        block/sunvdc: add error handling support for add_disk()
        z2ram: add error handling support for add_disk()
        nvdimm/pmem: use add_disk() error handling
        nvdimm/pmem: cleanup the disk if pmem_release_disk() is yet assigned
        nvdimm/blk: add error handling support for add_disk()
        nvdimm/blk: avoid calling del_gendisk() on early failures
        nvdimm/btt: add error handling support for add_disk()
        nvdimm/btt: use goto error labels on btt_blk_init()
        loop: Remove duplicate assignments
        drbd: Fix double free problem in drbd_create_device
        nvdimm/btt: do not call del_gendisk() if not needed
        bcache: fix use-after-free problem in bcache_device_free()
        zram: replace fsync_bdev with sync_blockdev
        ...
      cb690f52
    • Linus Torvalds's avatar
      Merge tag 'for-5.16/block-2021-11-09' of git://git.kernel.dk/linux-block · 3e28850c
      Linus Torvalds authored
      Pull block fixes from Jens Axboe:
      
       - Set of fixes for the batched tag allocation (Ming, me)
      
       - add_disk() error handling fix (Luis)
      
       - Nested queue quiesce fixes (Ming)
      
       - Shared tags init error handling fix (Ye)
      
       - Misc cleanups (Jean, Ming, me)
      
      * tag 'for-5.16/block-2021-11-09' of git://git.kernel.dk/linux-block:
        nvme: wait until quiesce is done
        scsi: make sure that request queue queiesce and unquiesce balanced
        scsi: avoid to quiesce sdev->request_queue two times
        blk-mq: add one API for waiting until quiesce is done
        blk-mq: don't free tags if the tag_set is used by other device in queue initialztion
        block: fix device_add_disk() kobject_create_and_add() error handling
        block: ensure cached plug request matches the current queue
        block: move queue enter logic into blk_mq_submit_bio()
        block: make bio_queue_enter() fast-path available inline
        block: split request allocation components into helpers
        block: have plug stored requests hold references to the queue
        blk-mq: update hctx->nr_active in blk_mq_end_request_batch()
        blk-mq: add RQF_ELV debug entry
        blk-mq: only try to run plug merge if request has same queue with incoming bio
        block: move RQF_ELV setting into allocators
        dm: don't stop request queue after the dm device is suspended
        block: replace always false argument with 'false'
        block: assign correct tag before doing prefetch of request
        blk-mq: fix redundant check of !e expression
      3e28850c
    • Linus Torvalds's avatar
      Merge tag 'for-5.16/bdev-size-2021-11-09' of git://git.kernel.dk/linux-block · 1dc1f92e
      Linus Torvalds authored
      Pull more bdev size updates from Jens Axboe:
       "Two followup changes for the bdev-size series from this merge window:
      
         - Add loff_t cast to bdev_nr_bytes() (Christoph)
      
         - Use bdev_nr_bytes() consistently for the block parts at least (me)"
      
      * tag 'for-5.16/bdev-size-2021-11-09' of git://git.kernel.dk/linux-block:
        block: use new bdev_nr_bytes() helper for blkdev_{read,write}_iter()
        block: add a loff_t cast to bdev_nr_bytes
      1dc1f92e
    • Linus Torvalds's avatar
      Merge tag 'io_uring-5.16-2021-11-09' of git://git.kernel.dk/linux-block · 007301c4
      Linus Torvalds authored
      Pull io_uring fixes from Jens Axboe:
       "Minor fixes that should go into the 5.16 release:
      
         - Fix max worker setting not working correctly on NUMA (Beld)
      
         - Correctly return current setting for max workers if zeroes are
           passed in (Pavel)
      
         - io_queue_sqe_arm_apoll() cleanup, as identified during the initial
           merge (Pavel)
      
         - Misc fixes (Nghia, me)"
      
      * tag 'io_uring-5.16-2021-11-09' of git://git.kernel.dk/linux-block:
        io_uring: honour zeroes as io-wq worker limits
        io_uring: remove dead 'sqe' store
        io_uring: remove redundant assignment to ret in io_register_iowq_max_workers()
        io-wq: fix max-workers not correctly set on multi-node system
        io_uring: clean up io_queue_sqe_arm_apoll
      007301c4
    • Linus Torvalds's avatar
      Merge tag 'for-5.16/dm-changes' of... · c183e170
      Linus Torvalds authored
      Merge tag 'for-5.16/dm-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm
      
      Pull device mapper updates from Mike Snitzer:
      
       - Add DM core support for emitting audit events through the audit
         subsystem. Also enhance both the integrity and crypt targets to emit
         events to via dm-audit.
      
       - Various other simple code improvements and cleanups.
      
      * tag 'for-5.16/dm-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm:
        dm table: log table creation error code
        dm: make workqueue names device-specific
        dm writecache: Make use of the helper macro kthread_run()
        dm crypt: Make use of the helper macro kthread_run()
        dm verity: use bvec_kmap_local in verity_for_bv_block
        dm log writes: use memcpy_from_bvec in log_writes_map
        dm integrity: use bvec_kmap_local in __journal_read_write
        dm integrity: use bvec_kmap_local in integrity_metadata
        dm: add add_disk() error handling
        dm: Remove redundant flush_workqueue() calls
        dm crypt: log aead integrity violations to audit subsystem
        dm integrity: log audit events for dm-integrity target
        dm: introduce audit event module for device mapper
      c183e170
    • Linus Torvalds's avatar
      Merge tag 'dma-mapping-5.16' of git://git.infradead.org/users/hch/dma-mapping · 37259498
      Linus Torvalds authored
      Pull dma-mapping updates from Christoph Hellwig:
       "Just a small set of changes this time. The request dma_direct_alloc
        cleanups are still under review and haven't made the cut.
      
        Summary:
      
         - convert sparc32 to the generic dma-direct code
      
         - use bitmap_zalloc (Christophe JAILLET)"
      
      * tag 'dma-mapping-5.16' of git://git.infradead.org/users/hch/dma-mapping:
        dma-mapping: use 'bitmap_zalloc()' when applicable
        sparc32: use DMA_DIRECT_REMAP
        sparc32: remove dma_make_coherent
        sparc32: remove the call to dma_make_coherent in arch_dma_free
      37259498
    • Linus Torvalds's avatar
      Merge tag 'ovl-update-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/mszeredi/vfs · 1bdd629e
      Linus Torvalds authored
      Pull overlayfs updates from Miklos Szeredi:
      
       - Fix a regression introduced in the last cycle
      
       - Fix a use-after-free in the AIO path
      
       - Fix a bogus warning reported by syzbot
      
      * tag 'ovl-update-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/mszeredi/vfs:
        ovl: fix filattr copy-up failure
        ovl: fix warning in ovl_create_real()
        ovl: fix use after free in struct ovl_aio_req
      1bdd629e
    • Linus Torvalds's avatar
      Merge tag 'fuse-update-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/mszeredi/fuse · cdd39b05
      Linus Torvalds authored
      Pull fuse updates from Miklos Szeredi:
      
       - Fix a possible of deadlock in case inode writeback is in progress
         during dentry reclaim
      
       - Fix a crash in case of page stealing
      
       - Selectively invalidate cached attributes, possibly improving
         performance
      
       - Allow filesystems to disable data flushing from ->flush()
      
       - Misc fixes and cleanups
      
      * tag 'fuse-update-5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/mszeredi/fuse: (23 commits)
        fuse: fix page stealing
        virtiofs: use strscpy for copying the queue name
        fuse: add FOPEN_NOFLUSH
        fuse: only update necessary attributes
        fuse: take cache_mask into account in getattr
        fuse: add cache_mask
        fuse: move reverting attributes to fuse_change_attributes()
        fuse: simplify local variables holding writeback cache state
        fuse: cleanup code conditional on fc->writeback_cache
        fuse: fix attr version comparison in fuse_read_update_size()
        fuse: always invalidate attributes after writes
        fuse: rename fuse_write_update_size()
        fuse: don't bump attr_version in cached write
        fuse: selective attribute invalidation
        fuse: don't increment nlink in link()
        fuse: decrement nlink on overwriting rename
        fuse: simplify __fuse_write_file_get()
        fuse: move fuse_invalidate_attr() into fuse_update_ctime()
        fuse: delete redundant code
        fuse: use kmap_local_page()
        ...
      cdd39b05
    • Linus Torvalds's avatar
      Merge tag 'for-linus-5.16-ofs1' of git://git.kernel.org/pub/scm/linux/kernel/git/hubcap/linux · a0c7d4a0
      Linus Torvalds authored
      Pull orangefs fixes from Mike Marshall:
      
       - fix sb refcount leak when allocate sb info failed (Chenyuan Mi)
      
       - fix error return code of orangefs_revalidate_lookup() (Jia-Ju Bai)
      
       - remove redundant initialization of variable ret (Colin Ian King)
      
      * tag 'for-linus-5.16-ofs1' of git://git.kernel.org/pub/scm/linux/kernel/git/hubcap/linux:
        orangefs: Fix sb refcount leak when allocate sb info failed.
        fs: orangefs: fix error return code of orangefs_revalidate_lookup()
        orangefs: Remove redundant initialization of variable ret
      a0c7d4a0
    • Linus Torvalds's avatar
      Merge tag '9p-for-5.16-rc1' of git://github.com/martinetd/linux · f89ce84b
      Linus Torvalds authored
      Pull 9p updates from Dominique Martinet:
       "Fixes, netfs read support and checkpatch rewrite:
      
         - fix syzcaller uninitialized value usage after missing error check
      
         - add module autoloading based on transport name
      
         - convert cached reads to use netfs helpers
      
         - adjust readahead based on transport msize
      
         - and many, many checkpatch.pl warning fixes..."
      
      * tag '9p-for-5.16-rc1' of git://github.com/martinetd/linux:
        9p: fix a bunch of checkpatch warnings
        9p: set readahead and io size according to maxsize
        9p p9mode2perm: remove useless strlcpy and check sscanf return code
        9p v9fs_parse_options: replace simple_strtoul with kstrtouint
        9p: fix file headers
        fs/9p: fix indentation and Add missing a blank line after declaration
        fs/9p: fix warnings found by checkpatch.pl
        9p: fix minor indentation and codestyle
        fs/9p: cleanup: opening brace at the beginning of the next line
        9p: Convert to using the netfs helper lib to do reads and caching
        fscache_cookie_enabled: check cookie is valid before accessing it
        net/9p: autoload transport modules
        9p/net: fix missing error check in p9_check_errors
      f89ce84b