1. 23 Feb, 2021 18 commits
    • Rob Herring's avatar
      scripts/dtc: Add missing fdtoverlay to gitignore · c3476d2f
      Rob Herring authored
      Commit 0da6bcd9 ("scripts: dtc: Build fdtoverlay tool") enabled
      building fdtoverlay, but failed to add it to .gitignore.
      
      Also add a note to keep hostprogs in sync with .gitignore.
      
      Fixes: 0da6bcd9 ("scripts: dtc: Build fdtoverlay tool")
      Reported-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      Cc: Viresh Kumar <viresh.kumar@linaro.org>
      Signed-off-by: default avatarRob Herring <robh@kernel.org>
      c3476d2f
    • Linus Torvalds's avatar
      Merge tag 'gfs2-for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/gfs2/linux-gfs2 · f6e1e1d1
      Linus Torvalds authored
      Pull gfs2 updates from Andreas Gruenbacher:
      
       - Log space and revoke accounting rework to fix some failed asserts.
      
       - Local resource group glock sharing for better local performance.
      
       - Add support for version 1802 filesystems: trusted xattr support and
         '-o rgrplvb' mounts by default.
      
       - Actually synchronize on the inode glock's FREEING bit during withdraw
         ("gfs2: fix glock confusion in function signal_our_withdraw").
      
       - Fix parallel recovery of multiple journals ("gfs2: keep bios separate
         for each journal").
      
       - Various other bug fixes.
      
      * tag 'gfs2-for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/gfs2/linux-gfs2: (49 commits)
        gfs2: Don't get stuck with I/O plugged in gfs2_ail1_flush
        gfs2: Per-revoke accounting in transactions
        gfs2: Rework the log space allocation logic
        gfs2: Minor calc_reserved cleanup
        gfs2: Use resource group glock sharing
        gfs2: Allow node-wide exclusive glock sharing
        gfs2: Add local resource group locking
        gfs2: Add per-reservation reserved block accounting
        gfs2: Rename rs_{free -> requested} and rd_{reserved -> requested}
        gfs2: Check for active reservation in gfs2_release
        gfs2: Don't search for unreserved space twice
        gfs2: Only pass reservation down to gfs2_rbm_find
        gfs2: Also reflect single-block allocations in rgd->rd_extfail_pt
        gfs2: Recursive gfs2_quota_hold in gfs2_iomap_end
        gfs2: Add trusted xattr support
        gfs2: Enable rgrplvb for sb_fs_format 1802
        gfs2: Don't skip dlm unlock if glock has an lvb
        gfs2: Lock imbalance on error path in gfs2_recover_one
        gfs2: Move function gfs2_ail_empty_tr
        gfs2: Get rid of current_tail()
        ...
      f6e1e1d1
    • Linus Torvalds's avatar
      Merge tag 'idmapped-mounts-v5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux · 7d6beb71
      Linus Torvalds authored
      Pull idmapped mounts from Christian Brauner:
       "This introduces idmapped mounts which has been in the making for some
        time. Simply put, different mounts can expose the same file or
        directory with different ownership. This initial implementation comes
        with ports for fat, ext4 and with Christoph's port for xfs with more
        filesystems being actively worked on by independent people and
        maintainers.
      
        Idmapping mounts handle a wide range of long standing use-cases. Here
        are just a few:
      
         - Idmapped mounts make it possible to easily share files between
           multiple users or multiple machines especially in complex
           scenarios. For example, idmapped mounts will be used in the
           implementation of portable home directories in
           systemd-homed.service(8) where they allow users to move their home
           directory to an external storage device and use it on multiple
           computers where they are assigned different uids and gids. This
           effectively makes it possible to assign random uids and gids at
           login time.
      
         - It is possible to share files from the host with unprivileged
           containers without having to change ownership permanently through
           chown(2).
      
         - It is possible to idmap a container's rootfs and without having to
           mangle every file. For example, Chromebooks use it to share the
           user's Download folder with their unprivileged containers in their
           Linux subsystem.
      
         - It is possible to share files between containers with
           non-overlapping idmappings.
      
         - Filesystem that lack a proper concept of ownership such as fat can
           use idmapped mounts to implement discretionary access (DAC)
           permission checking.
      
         - They allow users to efficiently changing ownership on a per-mount
           basis without having to (recursively) chown(2) all files. In
           contrast to chown (2) changing ownership of large sets of files is
           instantenous with idmapped mounts. This is especially useful when
           ownership of a whole root filesystem of a virtual machine or
           container is changed. With idmapped mounts a single syscall
           mount_setattr syscall will be sufficient to change the ownership of
           all files.
      
         - Idmapped mounts always take the current ownership into account as
           idmappings specify what a given uid or gid is supposed to be mapped
           to. This contrasts with the chown(2) syscall which cannot by itself
           take the current ownership of the files it changes into account. It
           simply changes the ownership to the specified uid and gid. This is
           especially problematic when recursively chown(2)ing a large set of
           files which is commong with the aforementioned portable home
           directory and container and vm scenario.
      
         - Idmapped mounts allow to change ownership locally, restricting it
           to specific mounts, and temporarily as the ownership changes only
           apply as long as the mount exists.
      
        Several userspace projects have either already put up patches and
        pull-requests for this feature or will do so should you decide to pull
        this:
      
         - systemd: In a wide variety of scenarios but especially right away
           in their implementation of portable home directories.
      
               https://systemd.io/HOME_DIRECTORY/
      
         - container runtimes: containerd, runC, LXD:To share data between
           host and unprivileged containers, unprivileged and privileged
           containers, etc. The pull request for idmapped mounts support in
           containerd, the default Kubernetes runtime is already up for quite
           a while now: https://github.com/containerd/containerd/pull/4734
      
         - The virtio-fs developers and several users have expressed interest
           in using this feature with virtual machines once virtio-fs is
           ported.
      
         - ChromeOS: Sharing host-directories with unprivileged containers.
      
        I've tightly synced with all those projects and all of those listed
        here have also expressed their need/desire for this feature on the
        mailing list. For more info on how people use this there's a bunch of
        talks about this too. Here's just two recent ones:
      
            https://www.cncf.io/wp-content/uploads/2020/12/Rootless-Containers-in-Gitpod.pdf
            https://fosdem.org/2021/schedule/event/containers_idmap/
      
        This comes with an extensive xfstests suite covering both ext4 and
        xfs:
      
            https://git.kernel.org/brauner/xfstests-dev/h/idmapped_mounts
      
        It covers truncation, creation, opening, xattrs, vfscaps, setid
        execution, setgid inheritance and more both with idmapped and
        non-idmapped mounts. It already helped to discover an unrelated xfs
        setgid inheritance bug which has since been fixed in mainline. It will
        be sent for inclusion with the xfstests project should you decide to
        merge this.
      
        In order to support per-mount idmappings vfsmounts are marked with
        user namespaces. The idmapping of the user namespace will be used to
        map the ids of vfs objects when they are accessed through that mount.
        By default all vfsmounts are marked with the initial user namespace.
        The initial user namespace is used to indicate that a mount is not
        idmapped. All operations behave as before and this is verified in the
        testsuite.
      
        Based on prior discussions we want to attach the whole user namespace
        and not just a dedicated idmapping struct. This allows us to reuse all
        the helpers that already exist for dealing with idmappings instead of
        introducing a whole new range of helpers. In addition, if we decide in
        the future that we are confident enough to enable unprivileged users
        to setup idmapped mounts the permission checking can take into account
        whether the caller is privileged in the user namespace the mount is
        currently marked with.
      
        The user namespace the mount will be marked with can be specified by
        passing a file descriptor refering to the user namespace as an
        argument to the new mount_setattr() syscall together with the new
        MOUNT_ATTR_IDMAP flag. The system call follows the openat2() pattern
        of extensibility.
      
        The following conditions must be met in order to create an idmapped
        mount:
      
         - The caller must currently have the CAP_SYS_ADMIN capability in the
           user namespace the underlying filesystem has been mounted in.
      
         - The underlying filesystem must support idmapped mounts.
      
         - The mount must not already be idmapped. This also implies that the
           idmapping of a mount cannot be altered once it has been idmapped.
      
         - The mount must be a detached/anonymous mount, i.e. it must have
           been created by calling open_tree() with the OPEN_TREE_CLONE flag
           and it must not already have been visible in the filesystem.
      
        The last two points guarantee easier semantics for userspace and the
        kernel and make the implementation significantly simpler.
      
        By default vfsmounts are marked with the initial user namespace and no
        behavioral or performance changes are observed.
      
        The manpage with a detailed description can be found here:
      
            https://git.kernel.org/brauner/man-pages/c/1d7b902e2875a1ff342e036a9f866a995640aea8
      
        In order to support idmapped mounts, filesystems need to be changed
        and mark themselves with the FS_ALLOW_IDMAP flag in fs_flags. The
        patches to convert individual filesystem are not very large or
        complicated overall as can be seen from the included fat, ext4, and
        xfs ports. Patches for other filesystems are actively worked on and
        will be sent out separately. The xfstestsuite can be used to verify
        that port has been done correctly.
      
        The mount_setattr() syscall is motivated independent of the idmapped
        mounts patches and it's been around since July 2019. One of the most
        valuable features of the new mount api is the ability to perform
        mounts based on file descriptors only.
      
        Together with the lookup restrictions available in the openat2()
        RESOLVE_* flag namespace which we added in v5.6 this is the first time
        we are close to hardened and race-free (e.g. symlinks) mounting and
        path resolution.
      
        While userspace has started porting to the new mount api to mount
        proper filesystems and create new bind-mounts it is currently not
        possible to change mount options of an already existing bind mount in
        the new mount api since the mount_setattr() syscall is missing.
      
        With the addition of the mount_setattr() syscall we remove this last
        restriction and userspace can now fully port to the new mount api,
        covering every use-case the old mount api could. We also add the
        crucial ability to recursively change mount options for a whole mount
        tree, both removing and adding mount options at the same time. This
        syscall has been requested multiple times by various people and
        projects.
      
        There is a simple tool available at
      
            https://github.com/brauner/mount-idmapped
      
        that allows to create idmapped mounts so people can play with this
        patch series. I'll add support for the regular mount binary should you
        decide to pull this in the following weeks:
      
        Here's an example to a simple idmapped mount of another user's home
        directory:
      
      	u1001@f2-vm:/$ sudo ./mount --idmap both:1000:1001:1 /home/ubuntu/ /mnt
      
      	u1001@f2-vm:/$ ls -al /home/ubuntu/
      	total 28
      	drwxr-xr-x 2 ubuntu ubuntu 4096 Oct 28 22:07 .
      	drwxr-xr-x 4 root   root   4096 Oct 28 04:00 ..
      	-rw------- 1 ubuntu ubuntu 3154 Oct 28 22:12 .bash_history
      	-rw-r--r-- 1 ubuntu ubuntu  220 Feb 25  2020 .bash_logout
      	-rw-r--r-- 1 ubuntu ubuntu 3771 Feb 25  2020 .bashrc
      	-rw-r--r-- 1 ubuntu ubuntu  807 Feb 25  2020 .profile
      	-rw-r--r-- 1 ubuntu ubuntu    0 Oct 16 16:11 .sudo_as_admin_successful
      	-rw------- 1 ubuntu ubuntu 1144 Oct 28 00:43 .viminfo
      
      	u1001@f2-vm:/$ ls -al /mnt/
      	total 28
      	drwxr-xr-x  2 u1001 u1001 4096 Oct 28 22:07 .
      	drwxr-xr-x 29 root  root  4096 Oct 28 22:01 ..
      	-rw-------  1 u1001 u1001 3154 Oct 28 22:12 .bash_history
      	-rw-r--r--  1 u1001 u1001  220 Feb 25  2020 .bash_logout
      	-rw-r--r--  1 u1001 u1001 3771 Feb 25  2020 .bashrc
      	-rw-r--r--  1 u1001 u1001  807 Feb 25  2020 .profile
      	-rw-r--r--  1 u1001 u1001    0 Oct 16 16:11 .sudo_as_admin_successful
      	-rw-------  1 u1001 u1001 1144 Oct 28 00:43 .viminfo
      
      	u1001@f2-vm:/$ touch /mnt/my-file
      
      	u1001@f2-vm:/$ setfacl -m u:1001:rwx /mnt/my-file
      
      	u1001@f2-vm:/$ sudo setcap -n 1001 cap_net_raw+ep /mnt/my-file
      
      	u1001@f2-vm:/$ ls -al /mnt/my-file
      	-rw-rwxr--+ 1 u1001 u1001 0 Oct 28 22:14 /mnt/my-file
      
      	u1001@f2-vm:/$ ls -al /home/ubuntu/my-file
      	-rw-rwxr--+ 1 ubuntu ubuntu 0 Oct 28 22:14 /home/ubuntu/my-file
      
      	u1001@f2-vm:/$ getfacl /mnt/my-file
      	getfacl: Removing leading '/' from absolute path names
      	# file: mnt/my-file
      	# owner: u1001
      	# group: u1001
      	user::rw-
      	user:u1001:rwx
      	group::rw-
      	mask::rwx
      	other::r--
      
      	u1001@f2-vm:/$ getfacl /home/ubuntu/my-file
      	getfacl: Removing leading '/' from absolute path names
      	# file: home/ubuntu/my-file
      	# owner: ubuntu
      	# group: ubuntu
      	user::rw-
      	user:ubuntu:rwx
      	group::rw-
      	mask::rwx
      	other::r--"
      
      * tag 'idmapped-mounts-v5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux: (41 commits)
        xfs: remove the possibly unused mp variable in xfs_file_compat_ioctl
        xfs: support idmapped mounts
        ext4: support idmapped mounts
        fat: handle idmapped mounts
        tests: add mount_setattr() selftests
        fs: introduce MOUNT_ATTR_IDMAP
        fs: add mount_setattr()
        fs: add attr_flags_to_mnt_flags helper
        fs: split out functions to hold writers
        namespace: only take read lock in do_reconfigure_mnt()
        mount: make {lock,unlock}_mount_hash() static
        namespace: take lock_mount_hash() directly when changing flags
        nfs: do not export idmapped mounts
        overlayfs: do not mount on top of idmapped mounts
        ecryptfs: do not mount on top of idmapped mounts
        ima: handle idmapped mounts
        apparmor: handle idmapped mounts
        fs: make helpers idmap mount aware
        exec: handle idmapped mounts
        would_dump: handle idmapped mounts
        ...
      7d6beb71
    • Linus Torvalds's avatar
      Merge branch 'for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/dennis/percpu · aa8e3291
      Linus Torvalds authored
      Pull percpu updates from Dennis Zhou:
       "Percpu had a cleanup come in that makes use of the cpu bitmask helpers
        instead of the current iterative approach.
      
        This clean up then had an adverse interaction when clang's inlining
        sensitivity is changed such that not all sites are inlined resulting
        in modpost being upset with section mismatch due to percpu setup being
        marked __init.
      
        That was fixed by introducing __flatten to compiler_attributes.h"
      
      * 'for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/dennis/percpu:
        percpu: fix clang modpost section mismatch
        percpu: reduce the number of cpu distance comparisons
      aa8e3291
    • Linus Torvalds's avatar
      Kbuild: disable TRIM_UNUSED_KSYMS option · 5cf0fd59
      Linus Torvalds authored
      The removal of EXPORT_UNUSED_SYMBOL() in commit 36794822 looks like
      (and was sold as) a no-op, but it actually had a rather serious and
      subtle side effect: the UNUSED_SYMBOLS option not only enabled the
      removed (unused) functionality, it also _disabled_ the TRIM_UNUSED_KSYMS
      functionality.
      
      And it turns out that TRIM_UNUSED_KSYMS is a huge time waste, and takes
      up a third of the kernel build time for me.  For no actual upside, since
      no distro is likely to ever be able to enable it (because they all
      support external kernel modules).
      
      Rather than re-enable EXPORT_UNUSED_SYMBOL, this just disables the
      TRIM_UNUSED_KSYMS option by marking it broken.  I'm tempted to just
      remove the support entirely, but maybe somebody has a use-case and can
      fix the behavior of it.
      
      I could have just disabled it for COMPILE_TEST, but it really smells
      like the TRIM_UNUSED_KSYMS option is badly done and not really useful,
      so this takes the more direct approach - let's see if anybody ever
      actually notices or complains.
      
      Cc: Miroslav Benes <mbenes@suse.cz>
      Cc: Emil Velikov <emil.l.velikov@gmail.com>
      Cc: Christoph Hellwig <hch@lst.de>
      Cc: Jessica Yu <jeyu@kernel.org>
      Fixes: 36794822 ("module: remove EXPORT_UNUSED_SYMBOL*")
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      5cf0fd59
    • Linus Torvalds's avatar
      Merge tag 'modules-for-v5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/jeyu/linux · 21a6ab21
      Linus Torvalds authored
      Pull module updates from Jessica Yu:
      
       - Retire EXPORT_UNUSED_SYMBOL() and EXPORT_SYMBOL_GPL_FUTURE(). These
         export types were introduced between 2006 - 2008. All the of the
         unused symbols have been long removed and gpl future symbols were
         converted to gpl quite a long time ago, and I don't believe these
         export types have been used ever since. So, I think it should be safe
         to retire those export types now (Christoph Hellwig)
      
       - Refactor and clean up some aged code cruft in the module loader
         (Christoph Hellwig)
      
       - Build {,module_}kallsyms_on_each_symbol only when livepatching is
         enabled, as it is the only caller (Christoph Hellwig)
      
       - Unexport find_module() and module_mutex and fix the last module
         callers to not rely on these anymore. Make module_mutex internal to
         the module loader (Christoph Hellwig)
      
       - Harden ELF checks on module load and validate ELF structures before
         checking the module signature (Frank van der Linden)
      
       - Fix undefined symbol warning for clang (Fangrui Song)
      
       - Fix smatch warning (Dan Carpenter)
      
      * tag 'modules-for-v5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/jeyu/linux:
        module: potential uninitialized return in module_kallsyms_on_each_symbol()
        module: remove EXPORT_UNUSED_SYMBOL*
        module: remove EXPORT_SYMBOL_GPL_FUTURE
        module: move struct symsearch to module.c
        module: pass struct find_symbol_args to find_symbol
        module: merge each_symbol_section into find_symbol
        module: remove each_symbol_in_section
        module: mark module_mutex static
        kallsyms: only build {,module_}kallsyms_on_each_symbol when required
        kallsyms: refactor {,module_}kallsyms_on_each_symbol
        module: use RCU to synchronize find_module
        module: unexport find_module and module_mutex
        drm: remove drm_fb_helper_modinit
        powerpc/powernv: remove get_cxl_module
        module: harden ELF info handling
        module: Ignore _GLOBAL_OFFSET_TABLE_ when warning for undefined symbols
      21a6ab21
    • Linus Torvalds's avatar
      Merge tag 'microblaze-v5.12' of git://git.monstr.eu/linux-2.6-microblaze · 74268693
      Linus Torvalds authored
      Pull microblaze updates from Michal Simek:
      
       - Fix DTB alignment
      
       - Remove code for very old GCC versions
      
       - Remove TRACING_SUPPORT selection
      
      * tag 'microblaze-v5.12' of git://git.monstr.eu/linux-2.6-microblaze:
        microblaze: Fix built-in DTB alignment to be 8-byte aligned
        microblaze: Remove support for gcc < 4
        microblaze: do not select TRACING_SUPPORT directly
      74268693
    • Bob Peterson's avatar
      gfs2: Don't get stuck with I/O plugged in gfs2_ail1_flush · 17d77684
      Bob Peterson authored
      In gfs2_ail1_flush, we're using I/O plugging to give the block layer a
      better chance of merging I/O requests.  If we're too aggressive here, we
      can end up waiting on I/O to complete while still plugged.  Fix that in
      a way similar to writeback_sb_inodes, except that we can't use
      blk_flush_plug because blk_flush_plug_list is not exported.
      Signed-off-by: default avatarBob Peterson <rpeterso@redhat.com>
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      17d77684
    • Linus Torvalds's avatar
      Merge tag 'objtool-core-2021-02-23' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · a56ff24e
      Linus Torvalds authored
      Pull objtool updates from Thomas Gleixner:
      
       - Make objtool work for big-endian cross compiles
      
       - Make stack tracking via stack pointer memory operations match
         push/pop semantics to prepare for architectures w/o PUSH/POP
         instructions.
      
       - Add support for analyzing alternatives
      
       - Improve retpoline detection and handling
      
       - Improve assembly code coverage on x86
      
       - Provide support for inlined stack switching
      
      * tag 'objtool-core-2021-02-23' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (33 commits)
        objtool: Support stack-swizzle
        objtool,x86: Additionally decode: mov %rsp, (%reg)
        x86/unwind/orc: Change REG_SP_INDIRECT
        x86/power: Support objtool validation in hibernate_asm_64.S
        x86/power: Move restore_registers() to top of the file
        x86/power: Annotate indirect branches as safe
        x86/acpi: Support objtool validation in wakeup_64.S
        x86/acpi: Annotate indirect branch as safe
        x86/ftrace: Support objtool vmlinux.o validation in ftrace_64.S
        x86/xen/pvh: Annotate indirect branch as safe
        x86/xen: Support objtool vmlinux.o validation in xen-head.S
        x86/xen: Support objtool validation in xen-asm.S
        objtool: Add xen_start_kernel() to noreturn list
        objtool: Combine UNWIND_HINT_RET_OFFSET and UNWIND_HINT_FUNC
        objtool: Add asm version of STACK_FRAME_NON_STANDARD
        objtool: Assume only ELF functions do sibling calls
        x86/ftrace: Add UNWIND_HINT_FUNC annotation for ftrace_stub
        objtool: Support retpoline jump detection for vmlinux.o
        objtool: Fix ".cold" section suffix check for newer versions of GCC
        objtool: Fix retpoline detection in asm code
        ...
      a56ff24e
    • Andreas Gruenbacher's avatar
      Merge branches 'rgrp-glock-sharing' and 'gfs2-revoke' from... · 803074ad
      Andreas Gruenbacher authored
      Merge branches 'rgrp-glock-sharing' and 'gfs2-revoke' from https://git.kernel.org/pub/scm/linux/kernel/git/gfs2/linux-gfs2.git
      
      Merge the resource group glock sharing feature and the revoke accounting rework.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      803074ad
    • Linus Torvalds's avatar
      Merge tag 'clang-lto-v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux · 79db4d22
      Linus Torvalds authored
      Pull clang LTO updates from Kees Cook:
       "Clang Link Time Optimization.
      
        This is built on the work done preparing for LTO by arm64 folks,
        tracing folks, etc. This includes the core changes as well as the
        remaining pieces for arm64 (LTO has been the default build method on
        Android for about 3 years now, as it is the prerequisite for the
        Control Flow Integrity protections).
      
        While x86 LTO enablement is done, it depends on some pending objtool
        clean-ups. It's possible that I'll send a "part 2" pull request for
        LTO that includes x86 support.
      
        For merge log posterity, and as detailed in commit dc5723b0
        ("kbuild: add support for Clang LTO"), here is the lt;dr to do an LTO
        build:
      
              make LLVM=1 LLVM_IAS=1 defconfig
              scripts/config -e LTO_CLANG_THIN
              make LLVM=1 LLVM_IAS=1
      
        (To do a cross-compile of arm64, add "CROSS_COMPILE=aarch64-linux-gnu-"
        and "ARCH=arm64" to the "make" command lines.)
      
        Summary:
      
         - Clang LTO build infrastructure and arm64-specific enablement (Sami
           Tolvanen)
      
         - Recursive build CC_FLAGS_LTO fix (Alexander Lobakin)"
      
      * tag 'clang-lto-v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
        kbuild: prevent CC_FLAGS_LTO self-bloating on recursive rebuilds
        arm64: allow LTO to be selected
        arm64: disable recordmcount with DYNAMIC_FTRACE_WITH_REGS
        arm64: vdso: disable LTO
        drivers/misc/lkdtm: disable LTO for rodata.o
        efi/libstub: disable LTO
        scripts/mod: disable LTO for empty.c
        modpost: lto: strip .lto from module names
        PCI: Fix PREL32 relocations for LTO
        init: lto: fix PREL32 relocations
        init: lto: ensure initcall ordering
        kbuild: lto: add a default list of used symbols
        kbuild: lto: merge module sections
        kbuild: lto: limit inlining
        kbuild: lto: fix module versioning
        kbuild: add support for Clang LTO
        tracing: move function tracer options to Kconfig
      79db4d22
    • Linus Torvalds's avatar
      Merge tag 'pinctrl-v5.12-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl · 3b9cdafb
      Linus Torvalds authored
      Pull pin control updates from Linus Walleij:
       "This is the bulk of pin control changes for the v5.12 kernel.
      
        This time a calm set with no core changes.
      
        New drivers/subdrivers:
      
         - Renesas R8A7790A0 pin controller.
      
         - Allwinner H616 and H616-R pin controllers.
      
         - Qualcomm SM8350 and SC8180x pin controllers.
      
        Improvements:
      
         - Redo the DT bindings for Ralink RT2880.
      
         - A common Qualcomm TLMM DT binding in YAML.
      
         - Delete the unused drivers for U300, COH901, Sirf Atlas, and ZTE ZX"
      
      * tag 'pinctrl-v5.12-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl: (71 commits)
        pinctrl: mediatek: Fix trigger type setting follow for unexpected interrupt
        dt-bindings: pinctrl: Group tuples in pin control properties
        pinctrl: nuvoton: npcm7xx: Fix alignment of table header comment
        pinctrl: at91-pio4: fix "Prefer 'unsigned int' to bare use of 'unsigned'"
        pinctrl: at91-pio4: add support for slew-rate
        dt-bindings: pinctrl: at91-pio4: add slew-rate
        pinctrl: actions: Add depends on || COMPILE_TEST
        pinctrl: single: set function name when adding function
        pinctrl: qcom: Add sc8180x TLMM driver
        dt-bindings: pinctrl: qcom: Add sc8180x binding
        dt-bindings: pinctrl: qcom: Define common TLMM binding
        pinctrl: qcom: Add SM8350 pinctrl driver
        dt-bindings: pinctrl: qcom: Add SM8350 pinctrl bindings
        pinctrl: samsung: use raw_spinlock for s3c64xx
        dt-bindings: mediatek: mt8192: Fix dt_binding_check warning
        pinctrl: qcom: spmi-mpp: Add PM8019 compatible
        pinctrl: pinmux: add function selector to pinmux-functions
        pinctrl: samsung: use raw_spinlock for locking
        pinctrl: clarify #pinctrl-cells for pinctrl-single,pins
        pinctrl: actions: Add the platform dependency to drivers
        ...
      3b9cdafb
    • Linus Torvalds's avatar
      Merge tag 'for-linus-5.12-1' of git://github.com/cminyard/linux-ipmi · f81f2138
      Linus Torvalds authored
      Pull IPMI update from Corey Minyard:
       "Only one change, but it's required for other things, so it needs to go
        in"
      
      * tag 'for-linus-5.12-1' of git://github.com/cminyard/linux-ipmi:
        ipmi: remove open coded version of SMBus block write
      f81f2138
    • Linus Torvalds's avatar
      Merge tag 'topic/iomem-mmap-vs-gup-2021-02-22' of git://anongit.freedesktop.org/drm/drm · e913a8cd
      Linus Torvalds authored
      Pull follow_pfn() updates from Daniel Vetter:
       "Fixes around VM_FPNMAP and follow_pfn:
      
         - replace mm/frame_vector.c by get_user_pages in misc/habana and
           drm/exynos drivers, then move that into media as it's sole user
      
         - close race in generic_access_phys
      
         - s390 pci ioctl fix of this series landed in 5.11 already
      
         - properly revoke iomem mappings (/dev/mem, pci files)"
      
      * tag 'topic/iomem-mmap-vs-gup-2021-02-22' of git://anongit.freedesktop.org/drm/drm:
        PCI: Revoke mappings like devmem
        PCI: Also set up legacy files only after sysfs init
        sysfs: Support zapping of binary attr mmaps
        resource: Move devmem revoke code to resource framework
        /dev/mem: Only set filp->f_mapping
        PCI: Obey iomem restrictions for procfs mmap
        mm: Close race in generic_access_phys
        media: videobuf2: Move frame_vector into media subsystem
        mm/frame-vector: Use FOLL_LONGTERM
        misc/habana: Use FOLL_LONGTERM for userptr
        misc/habana: Stop using frame_vector helpers
        drm/exynos: Use FOLL_LONGTERM for g2d cmdlists
        drm/exynos: Stop using frame_vector helpers
      e913a8cd
    • Linus Torvalds's avatar
      Merge tag 'topic/kcmp-kconfig-2021-02-22' of git://anongit.freedesktop.org/drm/drm · 4b5f9254
      Linus Torvalds authored
      Pull kcmp kconfig update from Daniel Vetter:
       "Make the kcmp syscall available independently of checkpoint/restore.
      
        drm userspaces uses this, systemd uses this, so makes sense to pull it
        out from the checkpoint-restore bundle.
      
        Kees reviewed this from security pov and is happy with the final
        version"
      
      Link: https://lwn.net/Articles/845448/
      
      * tag 'topic/kcmp-kconfig-2021-02-22' of git://anongit.freedesktop.org/drm/drm:
        kcmp: Support selection of SYS_kcmp without CHECKPOINT_RESTORE
      4b5f9254
    • Linus Torvalds's avatar
      Merge branch 'userns-for-v5.12' of... · 7b0b78df
      Linus Torvalds authored
      Merge branch 'userns-for-v5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/user-namespace
      
      Pull user namespace update from Eric Biederman:
       "There are several pieces of active development, but only a single
        change made it through the gauntlet to be ready for v5.12. That change
        is tightening up the semantics of the v3 capabilities xattr. It is
        just short of being a bug-fix/security issue as no user space is known
        to even generate the problem case"
      
      * 'userns-for-v5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/user-namespace:
        capabilities: Don't allow writing ambiguous v3 file capabilities
      7b0b78df
    • Linus Torvalds's avatar
      Merge branch 'for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq · ac9e806c
      Linus Torvalds authored
      Pull qorkqueue updates from Tejun Heo:
       "Tracepoint and comment updates only"
      
      * 'for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq:
        workqueue: Use %s instead of function name
        workqueue: tracing the name of the workqueue instead of it's address
        workqueue: fix annotation for WQ_SYSFS
      ac9e806c
    • Linus Torvalds's avatar
      Merge branch 'for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup · 4b3bd22b
      Linus Torvalds authored
      Pull cgroup updates from Tejun Heo:
       "Nothing interesting. Just two minor patches"
      
      * 'for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup:
        cpuset: fix typos in comments
        cgroup: cgroup.{procs,threads} factor out common parts
      4b3bd22b
  2. 22 Feb, 2021 22 commits
    • Linus Torvalds's avatar
      Merge tag 'powerpc-5.12-1' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux · b12b4724
      Linus Torvalds authored
      Pull powerpc updates from Michael Ellerman:
      
       - A large series adding wrappers for our interrupt handlers, so that
         irq/nmi/user tracking can be isolated in the wrappers rather than
         spread in each handler.
      
       - Conversion of the 32-bit syscall handling into C.
      
       - A series from Nick to streamline our TLB flushing when using the
         Radix MMU.
      
       - Switch to using queued spinlocks by default for 64-bit server CPUs.
      
       - A rework of our PCI probing so that it happens later in boot, when
         more generic infrastructure is available.
      
       - Two small fixes to allow 32-bit little-endian processes to run on
         64-bit kernels.
      
       - Other smaller features, fixes & cleanups.
      
      Thanks to: Alexey Kardashevskiy, Ananth N Mavinakayanahalli, Aneesh
      Kumar K.V, Athira Rajeev, Bhaskar Chowdhury, Cédric Le Goater, Chengyang
      Fan, Christophe Leroy, Christopher M. Riedl, Fabiano Rosas, Florian
      Fainelli, Frederic Barrat, Ganesh Goudar, Hari Bathini, Jiapeng Chong,
      Joseph J Allen, Kajol Jain, Markus Elfring, Michal Suchanek, Nathan
      Lynch, Naveen N. Rao, Nicholas Piggin, Oliver O'Halloran, Pingfan Liu,
      Po-Hsu Lin, Qian Cai, Ram Pai, Randy Dunlap, Sandipan Das, Stephen
      Rothwell, Tyrel Datwyler, Will Springer, Yury Norov, and Zheng Yongjun.
      
      * tag 'powerpc-5.12-1' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux: (188 commits)
        powerpc/perf: Adds support for programming of Thresholding in P10
        powerpc/pci: Remove unimplemented prototypes
        powerpc/uaccess: Merge raw_copy_to_user_allowed() into raw_copy_to_user()
        powerpc/uaccess: Merge __put_user_size_allowed() into __put_user_size()
        powerpc/uaccess: get rid of small constant size cases in raw_copy_{to,from}_user()
        powerpc/64: Fix stack trace not displaying final frame
        powerpc/time: Remove get_tbl()
        powerpc/time: Avoid using get_tbl()
        spi: mpc52xx: Avoid using get_tbl()
        powerpc/syscall: Avoid storing 'current' in another pointer
        powerpc/32: Handle bookE debugging in C in syscall entry/exit
        powerpc/syscall: Do not check unsupported scv vector on PPC32
        powerpc/32: Remove the counter in global_dbcr0
        powerpc/32: Remove verification of MSR_PR on syscall in the ASM entry
        powerpc/syscall: implement system call entry/exit logic in C for PPC32
        powerpc/32: Always save non volatile GPRs at syscall entry
        powerpc/syscall: Change condition to check MSR_RI
        powerpc/syscall: Save r3 in regs->orig_r3
        powerpc/syscall: Use is_compat_task()
        powerpc/syscall: Make interrupt.c buildable on PPC32
        ...
      b12b4724
    • Linus Torvalds's avatar
      Merge tag 'for-linus' of git://git.armlinux.org.uk/~rmk/linux-arm · 6ff6f86b
      Linus Torvalds authored
      Pull ARM updates from Russell King:
      
       - Generalise byte swapping assembly
      
       - Update debug addresses for STI
      
       - Validate start of physical memory with DTB
      
       - Do not clear SCTLR.nTLSMD in decompressor
      
       - amba/locomo/sa1111 devices remove method return type is void
      
       - address markers for KASAN in page table dump
      
      * tag 'for-linus' of git://git.armlinux.org.uk/~rmk/linux-arm:
        ARM: 9065/1: OABI compat: fix build when EPOLL is not enabled
        ARM: 9055/1: mailbox: arm_mhuv2: make remove callback return void
        amba: Make use of bus_type functions
        amba: Make the remove callback return void
        vfio: platform: simplify device removal
        amba: reorder functions
        amba: Fix resource leak for drivers without .remove
        ARM: 9054/1: arch/arm/mm/mmu.c: Remove duplicate header
        ARM: 9053/1: arm/mm/ptdump:Add address markers for KASAN regions
        ARM: 9051/1: vdso: remove unneded extra-y addition
        ARM: 9050/1: Kconfig: Select ARCH_HAVE_NMI_SAFE_CMPXCHG where possible
        ARM: 9049/1: locomo: make locomo bus's remove callback return void
        ARM: 9048/1: sa1111: make sa1111 bus's remove callback return void
        ARM: 9047/1: smp: remove unused variable
        ARM: 9046/1: decompressor: Do not clear SCTLR.nTLSMD for ARMv7+ cores
        ARM: 9045/1: uncompress: Validate start of physical memory against passed DTB
        ARM: 9042/1: debug: no uncompress debugging while semihosting
        ARM: 9041/1: sti LL_UART: add STiH418 SBC UART0 support
        ARM: 9040/1: use DEBUG_UART_PHYS and DEBUG_UART_VIRT for sti LL_UART
        ARM: 9039/1: assembler: generalize byte swapping macro into rev_l
      6ff6f86b
    • Linus Torvalds's avatar
      Merge tag 'timers-urgent-2021-02-22' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 4aa36444
      Linus Torvalds authored
      Pull timer fixes from Thomas Gleixner:
       "A small set of clockevent fixes which fell through the cracks before
        the 5.11 release:
      
         - Ensure a clock is enabled on sh_cmt
      
         - Trivial compile fail and compile warning fixes"
      
      * tag 'timers-urgent-2021-02-22' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        clocksource/drivers/mxs_timer: Add missing semicolon when DEBUG is defined
        clocksource/drivers/sh_cmt: Make sure channel clock supply is enabled
        clocksource/drivers/ixp4xx: Select TIMER_OF when needed
      4aa36444
    • Linus Torvalds's avatar
      Merge tag 'trace-v5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace · c9584234
      Linus Torvalds authored
      Pull tracing updates from Steven Rostedt:
      
       - Update to the way irqs and preemption is tracked via the trace event
         PC field
      
       - Fix handling of unregistering event failing due to allocate memory.
         This is only triggered by failure injection, as it is pretty much
         guaranteed to have less than a page allocation succeed.
      
       - Do not show the useless "filter" or "enable" files for the "ftrace"
         trace system, as they have no effect on doing anything.
      
       - Add a warning if kprobes are registered more than once.
      
       - Synthetic events now have their fields parsed by semicolons. Old
         formats without semicolons will still work, but new features will
         require them.
      
       - New option to allow trace events to show %p without hashing in trace
         file. The trace file can only be read by root, and reading the raw
         event buffer did not have any pointers hashed, so this does not
         expose anything new.
      
       - New directory in tools called tools/tracing, where a new tool that
         reads sequential latency reports from the ftrace latency tracers.
      
       - Other minor fixes and cleanups.
      
      * tag 'trace-v5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace: (33 commits)
        kprobes: Fix to delay the kprobes jump optimization
        tracing/tools: Add the latency-collector to tools directory
        tracing: Make hash-ptr option default
        tracing: Add ptr-hash option to show the hashed pointer value
        tracing: Update the stage 3 of trace event macro comment
        tracing: Show real address for trace event arguments
        selftests/ftrace: Add '!event' synthetic event syntax check
        selftests/ftrace: Update synthetic event syntax errors
        tracing: Add a backward-compatibility check for synthetic event creation
        tracing: Update synth command errors
        tracing: Rework synthetic event command parsing
        tracing/dynevent: Delegate parsing to create function
        kprobes: Warn if the kprobe is reregistered
        ftrace: Remove unused ftrace_force_update()
        tracepoints: Code clean up
        tracepoints: Do not punish non static call users
        tracepoints: Remove unnecessary "data_args" macro parameter
        tracing: Do not create "enable" or "filter" files for ftrace event subsystem
        kernel: trace: preemptirq_delay_test: add cpu affinity
        tracepoint: Do not fail unregistering a probe due to memory failure
        ...
      c9584234
    • Linus Torvalds's avatar
      Merge tag 'perf-tools-for-v5.12-2020-02-19' of... · 3a36281a
      Linus Torvalds authored
      Merge tag 'perf-tools-for-v5.12-2020-02-19' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux
      
      Pull perf tool updates from Arnaldo Carvalho de Melo:
       "New features:
      
         - Support instruction latency in 'perf report', with both memory
           latency (weight) and instruction latency information, users can
           locate expensive load instructions and understand time spent in
           different stages.
      
         - Extend 'perf c2c' to display the number of loads which were blocked
           by data or address conflict.
      
         - Add 'perf stat' support for L2 topdown events in systems such as
           Intel's Sapphire rapids server.
      
         - Add support for PERF_SAMPLE_CODE_PAGE_SIZE in various tools, as a
           sort key, for instance:
      
              perf report --stdio --sort=comm,symbol,code_page_size
      
         - New 'perf daemon' command to run long running sessions while
           providing a way to control the enablement of events without
           restarting a traditional 'perf record' session.
      
         - Enable counting events for BPF programs in 'perf stat' just like
           for other targets (tid, cgroup, cpu, etc), e.g.:
      
              # perf stat -e ref-cycles,cycles -b 254 -I 1000
                 1.487903822            115,200      ref-cycles
                 1.487903822             86,012      cycles
                 2.489147029             80,560      ref-cycles
                 2.489147029             73,784      cycles
              ^C
      
           The example above counts 'cycles' and 'ref-cycles' of BPF program
           of id 254. It is similar to bpftool-prog-profile command, but more
           flexible.
      
         - Support the new layout for PERF_RECORD_MMAP2 to carry the DSO
           build-id using infrastructure generalised from the eBPF subsystem,
           removing the need for traversing the perf.data file to collect
           build-ids at the end of 'perf record' sessions and helping with
           long running sessions where binaries can get replaced in updates,
           leading to possible mis-resolution of symbols.
      
         - Support filtering by hex address in 'perf script'.
      
         - Support DSO filter in 'perf script', like in other perf tools.
      
         - Add namespaces support to 'perf inject'
      
         - Add support for SDT (Dtrace Style Markers) events on ARM64.
      
        perf record:
      
         - Fix handling of eventfd() when draining a buffer in 'perf record'.
      
         - Improvements to the generation of metadata events for pre-existing
           threads (mmaps, comm, etc), speeding up the work done at the start
           of system wide or per CPU 'perf record' sessions.
      
        Hardware tracing:
      
         - Initial support for tracing KVM with Intel PT.
      
         - Intel PT fixes for IPC
      
         - Support Intel PT PSB (synchronization packets) events.
      
         - Automatically group aux-output events to overcome --filter syntax.
      
         - Enable PERF_SAMPLE_DATA_SRC on ARMs SPE.
      
         - Update ARM's CoreSight hardware tracing OpenCSD library to v1.0.0.
      
        perf annotate TUI:
      
         - Fix handling of 'k' ("show line number") hotkey
      
         - Fix jump parsing for C++ code.
      
        perf probe:
      
         - Add protection to avoid endless loop.
      
        cgroups:
      
         - Avoid reading cgroup mountpoint multiple times, caching it.
      
         - Fix handling of cgroup v1/v2 in mixed hierarchy.
      
        Symbol resolving:
      
         - Add OCaml symbol demangling.
      
         - Further fixes for handling PE executables when using perf with Wine
           and .exe/.dll files.
      
         - Fix 'perf unwind' DSO handling.
      
         - Resolve symbols against debug file first, to deal with artifacts
           related to LTO.
      
         - Fix gap between kernel end and module start on powerpc.
      
        Reporting tools:
      
         - The DSO filter shouldn't show samples in unresolved maps.
      
         - Improve debuginfod support in various tools.
      
        build ids:
      
         - Fix 16-byte build ids in 'perf buildid-cache', add a 'perf test'
           entry for that case.
      
        perf test:
      
         - Support for PERF_SAMPLE_WEIGHT_STRUCT.
      
         - Add test case for PERF_SAMPLE_CODE_PAGE_SIZE.
      
         - Shell based tests for 'perf daemon's commands ('start', 'stop,
           'reconfig', 'list', etc).
      
         - ARM cs-etm 'perf test' fixes.
      
         - Add parse-metric memory bandwidth testcase.
      
        Compiler related:
      
         - Fix 'perf probe' kretprobe issue caused by gcc 11 bug when used
           with -fpatchable-function-entry.
      
         - Fix ARM64 build with gcc 11's -Wformat-overflow.
      
         - Fix unaligned access in sample parsing test.
      
         - Fix printf conversion specifier for IP addresses on arm64, s390 and
           powerpc.
      
        Arch specific:
      
         - Support exposing Performance Monitor Counter SPRs as part of
           extended regs on powerpc.
      
         - Add JSON 'perf stat' metrics for ARM64's imx8mp, imx8mq and imx8mn
           DDR, fix imx8mm ones.
      
         - Fix common and uarch events for ARM64's A76 and Ampere eMag"
      
      * tag 'perf-tools-for-v5.12-2020-02-19' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux: (148 commits)
        perf buildid-cache: Don't skip 16-byte build-ids
        perf buildid-cache: Add test for 16-byte build-id
        perf symbol: Remove redundant libbfd checks
        perf test: Output the sub testing result in cs-etm
        perf test: Suppress logs in cs-etm testing
        perf tools: Fix arm64 build error with gcc-11
        perf intel-pt: Add documentation for tracing virtual machines
        perf intel-pt: Split VM-Entry and VM-Exit branches
        perf intel-pt: Adjust sample flags for VM-Exit
        perf intel-pt: Allow for a guest kernel address filter
        perf intel-pt: Support decoding of guest kernel
        perf machine: Factor out machine__idle_thread()
        perf machine: Factor out machines__find_guest()
        perf intel-pt: Amend decoder to track the NR flag
        perf intel-pt: Retain the last PIP packet payload as is
        perf intel_pt: Add vmlaunch and vmresume as branches
        perf script: Add branch types for VM-Entry and VM-Exit
        perf auxtrace: Automatically group aux-output events
        perf test: Fix unaligned access in sample parsing test
        perf tools: Support arch specific PERF_SAMPLE_WEIGHT_STRUCT processing
        ...
      3a36281a
    • Linus Torvalds's avatar
      Merge tag 'nfsd-5.12-1' of git://git.kernel.org/pub/scm/linux/kernel/git/cel/linux · 7c70f3a7
      Linus Torvalds authored
      Pull more nfsd updates from Chuck Lever:
       "Here are a few additional NFSD commits for the merge window:
      
       Optimization:
         - Cork the socket while there are queued replies
      
        Fixes:
         - DRC shutdown ordering
         - svc_rdma_accept() lockdep splat"
      
      * tag 'nfsd-5.12-1' of git://git.kernel.org/pub/scm/linux/kernel/git/cel/linux:
        SUNRPC: Further clean up svc_tcp_sendmsg()
        SUNRPC: Remove redundant socket flags from svc_tcp_sendmsg()
        SUNRPC: Use TCP_CORK to optimise send performance on the server
        svcrdma: Hold private mutex while invoking rdma_accept()
        nfsd: register pernet ops last, unregister first
      7c70f3a7
    • Linus Torvalds's avatar
      Merge tag 'ceph-for-5.12-rc1' of git://github.com/ceph/ceph-client · 20bf195e
      Linus Torvalds authored
      Pull ceph updates from Ilya Dryomov:
       "With netfs helper library and fscache rework delayed, just a few cap
        handling improvements to avoid grabbing mmap_lock in some code paths
        and deal with capsnaps better and a mount option cleanup"
      
      * tag 'ceph-for-5.12-rc1' of git://github.com/ceph/ceph-client:
        ceph: defer flushing the capsnap if the Fb is used
        libceph: remove osdtimeout option entirely
        libceph: deprecate [no]cephx_require_signatures options
        ceph: allow queueing cap/snap handling after putting cap references
        ceph: clean up inode work queueing
        ceph: fix flush_snap logic after putting caps
      20bf195e
    • Linus Torvalds's avatar
      Merge tag 'fs_for_v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs · 9fe19046
      Linus Torvalds authored
      Pull isofs, udf, and quota updates from Jan Kara:
       "Several udf, isofs, and quota fixes"
      
      * tag 'fs_for_v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs:
        parser: Fix kernel-doc markups
        udf: handle large user and group ID
        isofs: handle large user and group ID
        parser: add unsigned int parser
        udf: fix silent AED tagLocation corruption
        isofs: release buffer head before return
        quota: Fix memory leak when handling corrupted quota file
      9fe19046
    • Linus Torvalds's avatar
      Merge tag 'fsnotify_for_v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs · db990385
      Linus Torvalds authored
      Pull fsnotify update from Jan Kara:
       "Make inotify groups be charged against appropriate memcgs"
      
      * tag 'fsnotify_for_v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs:
        inotify, memcg: account inotify instances to kmemcg
      db990385
    • Linus Torvalds's avatar
      Merge tag 'lazytime_for_v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs · d61c6a58
      Linus Torvalds authored
      Pull lazytime updates from Jan Kara:
       "Cleanups of the lazytime handling in the writeback code making rules
        for calling ->dirty_inode() filesystem handlers saner"
      
      * tag 'lazytime_for_v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs:
        ext4: simplify i_state checks in __ext4_update_other_inode_time()
        gfs2: don't worry about I_DIRTY_TIME in gfs2_fsync()
        fs: improve comments for writeback_single_inode()
        fs: drop redundant check from __writeback_single_inode()
        fs: clean up __mark_inode_dirty() a bit
        fs: pass only I_DIRTY_INODE flags to ->dirty_inode
        fs: don't call ->dirty_inode for lazytime timestamp updates
        fat: only specify I_DIRTY_TIME when needed in fat_update_time()
        fs: only specify I_DIRTY_TIME when needed in generic_update_time()
        fs: correctly document the inode dirty flags
      d61c6a58
    • Linus Torvalds's avatar
      Merge tag 'exfat-for-5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/linkinjeon/exfat · c63dca9e
      Linus Torvalds authored
      Pull exfat updates from Namjae Jeon:
      
       - improve file deletion performance with dirsync mount option
      
       - fix shift-out-of-bounds in exfat_fill_super() reported by syzkaller
      
      * tag 'exfat-for-5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/linkinjeon/exfat:
        exfat: improve performance of exfat_free_cluster when using dirsync mount option
        exfat: fix shift-out-of-bounds in exfat_fill_super()
      c63dca9e
    • Linus Torvalds's avatar
      Merge tag 'zonefs-5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/dlemoal/zonefs · 0f3d950d
      Linus Torvalds authored
      Pull zonefs updates from Damien Le Moal:
       "Two changes:
      
         - A fix that did not make it in time for 5.11, to correct the file
           size initialization of full sequential zone, from Shin'ichiro
      
         - Add file operation tracepoints to help with debugging, from
           Johannes"
      
      * tag 'zonefs-5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/dlemoal/zonefs:
        zonefs: Fix file size of zones in full condition
        zonefs: add tracepoints for file operations
      0f3d950d
    • Linus Torvalds's avatar
      Merge branch 'work.audit' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs · 250a25e7
      Linus Torvalds authored
      Pull RCU-safe common_lsm_audit() from Al Viro:
       "Make common_lsm_audit() non-blocking and usable from RCU pathwalk
        context.
      
        We don't really need to grab/drop dentry in there - rcu_read_lock() is
        enough. There's a couple of followups using that to simplify the
        logics in selinux, but those hadn't soaked in -next yet, so they'll
        have to go in next window"
      
      * 'work.audit' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs:
        make dump_common_audit_data() safe to be called from RCU pathwalk
        new helper: d_find_alias_rcu()
      250a25e7
    • Linus Torvalds's avatar
      Merge branch 'work.d_name' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs · 205f92d7
      Linus Torvalds authored
      Pull d_name whack-a-mole from Al Viro:
       "A bunch of places that play with ->d_name in printks instead of using
        proper formats..."
      
      * 'work.d_name' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs:
        orangefs_file_mmap(): use %pD
        cifs_debug: use %pd instead of messing with ->d_name
        erofs: use %pd instead of messing with ->d_name
        cramfs: use %pD instead of messing with file_dentry()->d_name
      205f92d7
    • Linus Torvalds's avatar
      Merge tag 'memblock-v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rppt/memblock · 7b7028ed
      Linus Torvalds authored
      Pull memblock update from Mike Rapoport:
       "Remove return value of memblock_free_all()
      
        memblock_free_all() returns the total count of freed pages and its
        callers used this value to update totalram_pages. This update is now
        anyway a part of memblock_free_all() and its callers no longer check
        the return value, so make memblock_free_all() void"
      
      * tag 'memblock-v5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rppt/memblock:
        mm: memblock: remove return value of memblock_free_all()
      7b7028ed
    • Andreas Gruenbacher's avatar
      gfs2: Per-revoke accounting in transactions · 2129b428
      Andreas Gruenbacher authored
      In the log, revokes are stored as a revoke descriptor (struct
      gfs2_log_descriptor), followed by zero or more additional revoke blocks
      (struct gfs2_meta_header).  On filesystems with a blocksize of 4k, the
      revoke descriptor contains up to 503 revokes, and the metadata blocks
      contain up to 509 revokes each.  We've so far been reserving space for
      revokes in transactions in block granularity, so a lot more space than
      necessary was being allocated and then released again.
      
      This patch switches to assigning revokes to transactions individually
      instead.  Initially, space for the revoke descriptor is reserved and
      handed out to transactions.  When more revokes than that are reserved,
      additional revoke blocks are added.  When the log is flushed, the space
      for the additional revoke blocks is released, but we keep the space for
      the revoke descriptor block allocated.
      
      Transactions may still reserve more revokes than they will actually need
      in the end, but now we won't overshoot the target as much, and by only
      returning the space for excess revokes at log flush time, we further
      reduce the amount of contention between processes.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      2129b428
    • Andreas Gruenbacher's avatar
      gfs2: Rework the log space allocation logic · fe3e3976
      Andreas Gruenbacher authored
      The current log space allocation logic is hard to understand or extend.
      The principle it that when the log is flushed, we may or may not have a
      transaction active that has space allocated in the log.  To deal with
      that, we set aside a magical number of blocks to be used in case we
      don't have an active transaction.  It isn't clear that the pool will
      always be big enough.  In addition, we can't return unused log space at
      the end of a transaction, so the number of blocks allocated must exactly
      match the number of blocks used.
      
      Simplify this as follows:
       * When transactions are allocated or merged, always reserve enough
         blocks to flush the transaction (err on the safe side).
       * In gfs2_log_flush, return any allocated blocks that haven't been used.
       * Maintain a pool of spare blocks big enough to do one log flush, as
         before.
       * In gfs2_log_flush, when we have no active transaction, allocate a
         suitable number of blocks.  For that, use the spare pool when
         called from logd, and leave the pool alone otherwise.  This means
         that when the log is almost full, logd will still be able to do one
         more log flush, which will result in more log space becoming
         available.
      
      This will make the log space allocator code easier to work with in
      the future.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      fe3e3976
    • Andreas Gruenbacher's avatar
      gfs2: Minor calc_reserved cleanup · 71b219f4
      Andreas Gruenbacher authored
      No functional change.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      71b219f4
    • Linus Torvalds's avatar
      Merge tag 'kgdb-5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/danielt/linux · 899cbb0e
      Linus Torvalds authored
      Pull kgdb updates from Daniel Thompson:
       "Another fairly small set of changes of changes this cycle. The most
        significant functional change is a fix to better manage the flags when
        allocating memory.
      
        Additionally there is the removal of some unused code (which is
        slightly more dramatic than it sounds given it means there are now no
        tasklets in kgdb) together with a tidy up of the debug prints and some
        spelling corrections for the documentation"
      
      * tag 'kgdb-5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/danielt/linux:
        kgdb: Remove kgdb_schedule_breakpoint()
        kdb: Make memory allocations more robust
        kdb: kdb_support: Fix debugging information problem
        kernel: debug: fix typo issue
        kgdb: rectify kernel-doc for kgdb_unregister_io_module()
      899cbb0e
    • Linus Torvalds's avatar
      Merge tag 'livepatching-for-5.12' of... · 54ab35d6
      Linus Torvalds authored
      Merge tag 'livepatching-for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/livepatching/livepatching
      
      Pull livepatching updates from Petr Mladek:
      
       - Practical information how to implement reliable stacktraces needed by
         the livepatching consistency model by Mark Rutland and Mark Brown.
      
       - Automatically generated documentation contents by Mark Brown.
      
      * tag 'livepatching-for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/livepatching/livepatching:
        Documentation: livepatch: document reliable stacktrace
        Documentation: livepatch: Convert to automatically generated contents
      54ab35d6
    • Linus Torvalds's avatar
      Merge tag 'printk-for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/printk/linux · b2bec7d8
      Linus Torvalds authored
      Pull printk updates from Petr Mladek:
      
       - New "no_hash_pointers" kernel parameter causes that %p shows raw
         pointer values instead of hashed ones. It is intended only for
         debugging purposes. Misuse is prevented by a fat warning message that
         is inspired by trace_printk().
      
       - Prevent a possible deadlock when flushing printk_safe buffers during
         panic().
      
       - Fix performance regression caused by the lockless printk ringbuffer.
         It was visible with huge log buffer and long messages.
      
       - Documentation fix-up.
      
      * tag 'printk-for-5.12' of git://git.kernel.org/pub/scm/linux/kernel/git/printk/linux:
        lib/vsprintf: no_hash_pointers prints all addresses as unhashed
        kselftest: add support for skipped tests
        lib: use KSTM_MODULE_GLOBALS macro in kselftest drivers
        printk: avoid prb_first_valid_seq() where possible
        printk: fix deadlock when kernel panic
        printk: rectify kernel-doc for prb_rec_init_wr()
      b2bec7d8
    • Linus Torvalds's avatar
      Merge tag 'linux-kselftest-kunit-5.12-rc1' of... · 783955f0
      Linus Torvalds authored
      Merge tag 'linux-kselftest-kunit-5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull KUnit updates from Shuah Khan
      
       - support for filtering test suites using glob from Daniel Latypov.
      
           "kunit_filter.glob" command line option is passed to the UML
           kernel, which currently only supports filtering by suite name.
           This support allows running different subsets of tests, e.g.
      
            $ ./tools/testing/kunit/kunit.py build
            $ ./tools/testing/kunit/kunit.py exec 'list*'
            $ ./tools/testing/kunit/kunit.py exec 'kunit*'
      
       - several fixes and cleanups also from Daniel Latypov.
      
      * tag 'linux-kselftest-kunit-5.12-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest:
        kunit: tool: fix unintentional statefulness in run_kernel()
        kunit: tool: add support for filtering suites by glob
        kunit: add kunit.filter_glob cmdline option to filter suites
        kunit: don't show `1 == 1` in failed assertion messages
        kunit: make kunit_tool accept optional path to .kunitconfig fragment
        Documentation: kunit: add tips.rst for small examples
        KUnit: Docs: make start.rst example Kconfig follow style.rst
        kunit: tool: simplify kconfig is_subset_of() logic
        minor: kunit: tool: fix unit test so it can run from non-root dir
        kunit: tool: use `with open()` in unit test
        kunit: tool: stop using bare asserts in unit test
        kunit: tool: fix unit test cleanup handling
      783955f0