1. 21 12月, 2020 1 次提交
  2. 19 12月, 2020 1 次提交
  3. 18 12月, 2020 2 次提交
    • P
      io_uring: close a small race gap for files cancel · dfea9fce
      Pavel Begunkov 提交于
      The purpose of io_uring_cancel_files() is to wait for all requests
      matching ->files to go/be cancelled. We should first drop files of a
      request in io_req_drop_files() and only then make it undiscoverable for
      io_uring_cancel_files.
      
      First drop, then delete from list. It's ok to leave req->id->files
      dangling, because it's not dereferenced by cancellation code, only
      compared against. It would potentially go to sleep and be awaken by
      following in io_req_drop_files() wake_up().
      
      Fixes: 0f212204 ("io_uring: don't rely on weak ->files references")
      Cc: <stable@vger.kernel.org> # 5.5+
      Signed-off-by: NPavel Begunkov <asml.silence@gmail.com>
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      dfea9fce
    • X
      io_uring: fix io_wqe->work_list corruption · 0020ef04
      Xiaoguang Wang 提交于
      For the first time a req punted to io-wq, we'll initialize io_wq_work's
      list to be NULL, then insert req to io_wqe->work_list. If this req is not
      inserted into tail of io_wqe->work_list, this req's io_wq_work list will
      point to another req's io_wq_work. For splitted bio case, this req maybe
      inserted to io_wqe->work_list repeatedly, once we insert it to tail of
      io_wqe->work_list for the second time, now io_wq_work->list->next will be
      invalid pointer, which then result in many strang error, panic, kernel
      soft-lockup, rcu stall, etc.
      
      In my vm, kernel doest not have commit cc29e1bf ("block: disable
      iopoll for split bio"), below fio job can reproduce this bug steadily:
      [global]
      name=iouring-sqpoll-iopoll-1
      ioengine=io_uring
      iodepth=128
      numjobs=1
      thread
      rw=randread
      direct=1
      registerfiles=1
      hipri=1
      bs=4m
      size=100M
      runtime=120
      time_based
      group_reporting
      randrepeat=0
      
      [device]
      directory=/home/feiman.wxg/mntpoint/  # an ext4 mount point
      
      If we have commit cc29e1bf ("block: disable iopoll for split bio"),
      there will no splitted bio case for polled io, but I think we still to need
      to fix this list corruption, it also should maybe go to stable branchs.
      
      To fix this corruption, if a req is inserted into tail of io_wqe->work_list,
      initialize req->io_wq_work->list->next to bu NULL.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NXiaoguang Wang <xiaoguang.wang@linux.alibaba.com>
      Reviewed-by: NPavel Begunkov <asml.silence@gmail.com>
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      0020ef04
  4. 17 12月, 2020 26 次提交
    • P
      io_uring: limit {io|sq}poll submit locking scope · 89448c47
      Pavel Begunkov 提交于
      We don't need to take uring_lock for SQPOLL|IOPOLL to do
      io_cqring_overflow_flush() when cq_overflow_list is empty, remove it
      from the hot path.
      Signed-off-by: NPavel Begunkov <asml.silence@gmail.com>
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      89448c47
    • P
      io_uring: inline io_cqring_mark_overflow() · 09e88404
      Pavel Begunkov 提交于
      There is only one user of it and the name is misleading, get rid of it
      by inlining. By the way make overflow_flush's return value deduction
      simpler.
      Signed-off-by: NPavel Begunkov <asml.silence@gmail.com>
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      09e88404
    • P
      io_uring: consolidate CQ nr events calculation · e23de15f
      Pavel Begunkov 提交于
      Add a helper which calculates number of events in CQ. Handcoded version
      of it in io_cqring_overflow_flush() is not the clearest thing, so it
      makes it slightly more readable.
      Signed-off-by: NPavel Begunkov <asml.silence@gmail.com>
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      e23de15f
    • P
      io_uring: remove racy overflow list fast checks · 9cd2be51
      Pavel Begunkov 提交于
      list_empty_careful() is not racy only if some conditions are met, i.e.
      no re-adds after del_init. io_cqring_overflow_flush() does list_move(),
      so it's actually racy.
      
      Remove those checks, we have ->cq_check_overflow for the fast path.
      Signed-off-by: NPavel Begunkov <asml.silence@gmail.com>
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      9cd2be51
    • P
      io_uring: cancel reqs shouldn't kill overflow list · cda286f0
      Pavel Begunkov 提交于
      io_uring_cancel_task_requests() doesn't imply that the ring is going
      away, it may continue to work well after that. The problem is that it
      sets ->cq_overflow_flushed effectively disabling the CQ overflow feature
      
      Split setting cq_overflow_flushed from flush, and do the first one only
      on exit. It's ok in terms of cancellations because there is a
      io_uring->in_idle check in __io_cqring_fill_event().
      
      It also fixes a race with setting ->cq_overflow_flushed in
      io_uring_cancel_task_requests, whuch's is not atomic and a part of a
      bitmask with other flags. Though, the only other flag that's not set
      during init is drain_next, so it's not as bad for sane architectures.
      Signed-off-by: NPavel Begunkov <asml.silence@gmail.com>
      Fixes: 0f212204 ("io_uring: don't rely on weak ->files references")
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      cda286f0
    • J
      io_uring: hold mmap_sem for mm->locked_vm manipulation · 4bc4a912
      Jens Axboe 提交于
      The kernel doesn't seem to have clear rules around this, but various
      spots are using the mmap_sem to serialize access to modifying the
      locked_vm count. Play it safe and lock the mm for write when accounting
      or unaccounting locked memory.
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      4bc4a912
    • J
      io_uring: break links on shutdown failure · a146468d
      Jens Axboe 提交于
      Ensure that the return value of __sys_shutdown_sock() is used to
      potentially break links to the request, if we fail.
      
      Fixes: 36f4fa68 ("io_uring: add support for shutdown(2)")
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      a146468d
    • L
      Merge tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/rdma/rdma · 009bd55d
      Linus Torvalds 提交于
      Pull rdma updates from Jason Gunthorpe:
       "A smaller set of patches, nothing stands out as being particularly
        major this cycle. The biggest item would be the new HIP09 HW support
        from HNS, otherwise it was pretty quiet for new work here:
      
         - Driver bug fixes and updates: bnxt_re, cxgb4, rxe, hns, i40iw,
           cxgb4, mlx4 and mlx5
      
         - Bug fixes and polishing for the new rts ULP
      
         - Cleanup of uverbs checking for allowed driver operations
      
         - Use sysfs_emit all over the place
      
         - Lots of bug fixes and clarity improvements for hns
      
         - hip09 support for hns
      
         - NDR and 50/100Gb signaling rates
      
         - Remove dma_virt_ops and go back to using the IB DMA wrappers
      
         - mlx5 optimizations for contiguous DMA regions"
      
      * tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/rdma/rdma: (147 commits)
        RDMA/cma: Don't overwrite sgid_attr after device is released
        RDMA/mlx5: Fix MR cache memory leak
        RDMA/rxe: Use acquire/release for memory ordering
        RDMA/hns: Simplify AEQE process for different types of queue
        RDMA/hns: Fix inaccurate prints
        RDMA/hns: Fix incorrect symbol types
        RDMA/hns: Clear redundant variable initialization
        RDMA/hns: Fix coding style issues
        RDMA/hns: Remove unnecessary access right set during INIT2INIT
        RDMA/hns: WARN_ON if get a reserved sl from users
        RDMA/hns: Avoid filling sl in high 3 bits of vlan_id
        RDMA/hns: Do shift on traffic class when using RoCEv2
        RDMA/hns: Normalization the judgment of some features
        RDMA/hns: Limit the length of data copied between kernel and userspace
        RDMA/mlx4: Remove bogus dev_base_lock usage
        RDMA/uverbs: Fix incorrect variable type
        RDMA/core: Do not indicate device ready when device enablement fails
        RDMA/core: Clean up cq pool mechanism
        RDMA/core: Update kernel documentation for ib_create_named_qp()
        MAINTAINERS: SOFT-ROCE: Change Zhu Yanjun's email address
        ...
      009bd55d
    • L
      Merge tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi · 60f7c503
      Linus Torvalds 提交于
      Pull SCSI updates from James Bottomley:
       "This consists of the usual driver updates (ufs, qla2xxx, smartpqi,
        target, zfcp, fnic, mpt3sas, ibmvfc) plus a load of cleanups, a major
        power management rework and a load of assorted minor updates.
      
        There are a few core updates (formatting fixes being the big one) but
        nothing major this cycle"
      
      * tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi: (279 commits)
        scsi: mpt3sas: Update driver version to 36.100.00.00
        scsi: mpt3sas: Handle trigger page after firmware update
        scsi: mpt3sas: Add persistent MPI trigger page
        scsi: mpt3sas: Add persistent SCSI sense trigger page
        scsi: mpt3sas: Add persistent Event trigger page
        scsi: mpt3sas: Add persistent Master trigger page
        scsi: mpt3sas: Add persistent trigger pages support
        scsi: mpt3sas: Sync time periodically between driver and firmware
        scsi: qla2xxx: Update version to 10.02.00.104-k
        scsi: qla2xxx: Fix device loss on 4G and older HBAs
        scsi: qla2xxx: If fcport is undergoing deletion complete I/O with retry
        scsi: qla2xxx: Fix the call trace for flush workqueue
        scsi: qla2xxx: Fix flash update in 28XX adapters on big endian machines
        scsi: qla2xxx: Handle aborts correctly for port undergoing deletion
        scsi: qla2xxx: Fix N2N and NVMe connect retry failure
        scsi: qla2xxx: Fix FW initialization error on big endian machines
        scsi: qla2xxx: Fix crash during driver load on big endian machines
        scsi: qla2xxx: Fix compilation issue in PPC systems
        scsi: qla2xxx: Don't check for fw_started while posting NVMe command
        scsi: qla2xxx: Tear down session if FW say it is down
        ...
      60f7c503
    • L
      Merge tag 'for-5.11/drivers-2020-12-14' of git://git.kernel.dk/linux-block · 69f637c3
      Linus Torvalds 提交于
      Pull block driver updates from Jens Axboe:
       "Nothing major in here:
      
         - NVMe pull request from Christoph:
              - nvmet passthrough improvements (Chaitanya Kulkarni)
              - fcloop error injection support (James Smart)
              - read-only support for zoned namespaces without Zone Append
                (Javier González)
              - improve some error message (Minwoo Im)
              - reject I/O to offline fabrics namespaces (Victor Gladkov)
              - PCI queue allocation cleanups (Niklas Schnelle)
              - remove an unused allocation in nvmet (Amit Engel)
              - a Kconfig spelling fix (Colin Ian King)
              - nvme_req_qid simplication (Baolin Wang)
      
         - MD pull request from Song:
              - Fix race condition in md_ioctl() (Dae R. Jeong)
              - Initialize read_slot properly for raid10 (Kevin Vigor)
              - Code cleanup (Pankaj Gupta)
              - md-cluster resync/reshape fix (Zhao Heming)
      
         - Move null_blk into its own directory (Damien Le Moal)
      
         - null_blk zone and discard improvements (Damien Le Moal)
      
         - bcache race fix (Dongsheng Yang)
      
         - Set of rnbd fixes/improvements (Gioh Kim, Guoqing Jiang, Jack Wang,
           Lutz Pogrell, Md Haris Iqbal)
      
         - lightnvm NULL pointer deref fix (tangzhenhao)
      
         - sr in_interrupt() removal (Sebastian Andrzej Siewior)
      
         - FC endpoint security support for s390/dasd (Jan Höppner, Sebastian
           Ott, Vineeth Vijayan). From the s390 arch guys, arch bits included
           as it made it easier for them to funnel the feature through the
           block driver tree.
      
         - Follow up fixes (Colin Ian King)"
      
      * tag 'for-5.11/drivers-2020-12-14' of git://git.kernel.dk/linux-block: (64 commits)
        block: drop dead assignments in loop_init()
        sr: Remove in_interrupt() usage in sr_init_command().
        sr: Switch the sector size back to 2048 if sr_read_sector() changed it.
        cdrom: Reset sector_size back it is not 2048.
        drivers/lightnvm: fix a null-ptr-deref bug in pblk-core.c
        null_blk: Move driver into its own directory
        null_blk: Allow controlling max_hw_sectors limit
        null_blk: discard zones on reset
        null_blk: cleanup discard handling
        null_blk: Improve implicit zone close
        null_blk: improve zone locking
        block: Align max_hw_sectors to logical blocksize
        null_blk: Fail zone append to conventional zones
        null_blk: Fix zone size initialization
        bcache: fix race between setting bdev state to none and new write request direct to backing
        block/rnbd: fix a null pointer dereference on dev->blk_symlink_name
        block/rnbd-clt: Dynamically alloc buffer for pathname & blk_symlink_name
        block/rnbd: call kobject_put in the failure path
        Documentation/ABI/rnbd-srv: add document for force_close
        block/rnbd-srv: close a mapped device from server side.
        ...
      69f637c3
    • L
      Merge tag 'for-5.11/block-2020-12-14' of git://git.kernel.dk/linux-block · ac7ac461
      Linus Torvalds 提交于
      Pull block updates from Jens Axboe:
       "Another series of killing more code than what is being added, again
        thanks to Christoph's relentless cleanups and tech debt tackling.
      
        This contains:
      
         - blk-iocost improvements (Baolin Wang)
      
         - part0 iostat fix (Jeffle Xu)
      
         - Disable iopoll for split bios (Jeffle Xu)
      
         - block tracepoint cleanups (Christoph Hellwig)
      
         - Merging of struct block_device and hd_struct (Christoph Hellwig)
      
         - Rework/cleanup of how block device sizes are updated (Christoph
           Hellwig)
      
         - Simplification of gendisk lookup and removal of block device
           aliasing (Christoph Hellwig)
      
         - Block device ioctl cleanups (Christoph Hellwig)
      
         - Removal of bdget()/blkdev_get() as exported API (Christoph Hellwig)
      
         - Disk change rework, avoid ->revalidate_disk() (Christoph Hellwig)
      
         - sbitmap improvements (Pavel Begunkov)
      
         - Hybrid polling fix (Pavel Begunkov)
      
         - bvec iteration improvements (Pavel Begunkov)
      
         - Zone revalidation fixes (Damien Le Moal)
      
         - blk-throttle limit fix (Yu Kuai)
      
         - Various little fixes"
      
      * tag 'for-5.11/block-2020-12-14' of git://git.kernel.dk/linux-block: (126 commits)
        blk-mq: fix msec comment from micro to milli seconds
        blk-mq: update arg in comment of blk_mq_map_queue
        blk-mq: add helper allocating tagset->tags
        Revert "block: Fix a lockdep complaint triggered by request queue flushing"
        nvme-loop: use blk_mq_hctx_set_fq_lock_class to set loop's lock class
        blk-mq: add new API of blk_mq_hctx_set_fq_lock_class
        block: disable iopoll for split bio
        block: Improve blk_revalidate_disk_zones() checks
        sbitmap: simplify wrap check
        sbitmap: replace CAS with atomic and
        sbitmap: remove swap_lock
        sbitmap: optimise sbitmap_deferred_clear()
        blk-mq: skip hybrid polling if iopoll doesn't spin
        blk-iocost: Factor out the base vrate change into a separate function
        blk-iocost: Factor out the active iocgs' state check into a separate function
        blk-iocost: Move the usage ratio calculation to the correct place
        blk-iocost: Remove unnecessary advance declaration
        blk-iocost: Fix some typos in comments
        blktrace: fix up a kerneldoc comment
        block: remove the request_queue to argument request based tracepoints
        ...
      ac7ac461
    • L
      Merge tag 'for-5.11/io_uring-2020-12-14' of git://git.kernel.dk/linux-block · 48aba79b
      Linus Torvalds 提交于
      Pull io_uring updates from Jens Axboe:
       "Fairly light set of changes this time around, and mostly some bits
        that were pushed out to 5.11 instead of 5.10, fixes/cleanups, and a
        few features. In particular:
      
         - Cleanups around iovec import (David Laight, Pavel)
      
         - Add timeout support for io_uring_enter(2), which enables us to
           clean up liburing and avoid a timeout sqe submission in the
           completion path.
      
           The big win here is that it allows setups that split SQ and CQ
           handling into separate threads to avoid locking, as the CQ side
           will no longer submit when timeouts are needed when waiting for
           events (Hao Xu)
      
         - Add support for socket shutdown, and renameat/unlinkat.
      
         - SQPOLL cleanups and improvements (Xiaoguang Wang)
      
         - Allow SQPOLL setups for CAP_SYS_NICE, and enable regular
           (non-fixed) files to be used.
      
         - Cancelation improvements (Pavel)
      
         - Fixed file reference improvements (Pavel)
      
         - IOPOLL related race fixes (Pavel)
      
         - Lots of other little fixes and cleanups (mostly Pavel)"
      
      * tag 'for-5.11/io_uring-2020-12-14' of git://git.kernel.dk/linux-block: (43 commits)
        io_uring: fix io_cqring_events()'s noflush
        io_uring: fix racy IOPOLL flush overflow
        io_uring: fix racy IOPOLL completions
        io_uring: always let io_iopoll_complete() complete polled io
        io_uring: add timeout update
        io_uring: restructure io_timeout_cancel()
        io_uring: fix files cancellation
        io_uring: use bottom half safe lock for fixed file data
        io_uring: fix miscounting ios_left
        io_uring: change submit file state invariant
        io_uring: check kthread stopped flag when sq thread is unparked
        io_uring: share fixed_file_refs b/w multiple rsrcs
        io_uring: replace inflight_wait with tctx->wait
        io_uring: don't take fs for recvmsg/sendmsg
        io_uring: only wake up sq thread while current task is in io worker context
        io_uring: don't acquire uring_lock twice
        io_uring: initialize 'timeout' properly in io_sq_thread()
        io_uring: refactor io_sq_thread() handling
        io_uring: always batch cancel in *cancel_files()
        io_uring: pass files into kill timeouts/poll
        ...
      48aba79b
    • L
      Merge tag 'tif-task_work.arch-2020-12-14' of git://git.kernel.dk/linux-block · 005b2a9d
      Linus Torvalds 提交于
      Pull TIF_NOTIFY_SIGNAL updates from Jens Axboe:
       "This sits on top of of the core entry/exit and x86 entry branch from
        the tip tree, which contains the generic and x86 parts of this work.
      
        Here we convert the rest of the archs to support TIF_NOTIFY_SIGNAL.
      
        With that done, we can get rid of JOBCTL_TASK_WORK from task_work and
        signal.c, and also remove a deadlock work-around in io_uring around
        knowing that signal based task_work waking is invoked with the sighand
        wait queue head lock.
      
        The motivation for this work is to decouple signal notify based
        task_work, of which io_uring is a heavy user of, from sighand. The
        sighand lock becomes a huge contention point, particularly for
        threaded workloads where it's shared between threads. Even outside of
        threaded applications it's slower than it needs to be.
      
        Roman Gershman <romger@amazon.com> reported that his networked
        workload dropped from 1.6M QPS at 80% CPU to 1.0M QPS at 100% CPU
        after io_uring was changed to use TIF_NOTIFY_SIGNAL. The time was all
        spent hammering on the sighand lock, showing 57% of the CPU time there
        [1].
      
        There are further cleanups possible on top of this. One example is
        TIF_PATCH_PENDING, where a patch already exists to use
        TIF_NOTIFY_SIGNAL instead. Hopefully this will also lead to more
        consolidation, but the work stands on its own as well"
      
      [1] https://github.com/axboe/liburing/issues/215
      
      * tag 'tif-task_work.arch-2020-12-14' of git://git.kernel.dk/linux-block: (28 commits)
        io_uring: remove 'twa_signal_ok' deadlock work-around
        kernel: remove checking for TIF_NOTIFY_SIGNAL
        signal: kill JOBCTL_TASK_WORK
        io_uring: JOBCTL_TASK_WORK is no longer used by task_work
        task_work: remove legacy TWA_SIGNAL path
        sparc: add support for TIF_NOTIFY_SIGNAL
        riscv: add support for TIF_NOTIFY_SIGNAL
        nds32: add support for TIF_NOTIFY_SIGNAL
        ia64: add support for TIF_NOTIFY_SIGNAL
        h8300: add support for TIF_NOTIFY_SIGNAL
        c6x: add support for TIF_NOTIFY_SIGNAL
        alpha: add support for TIF_NOTIFY_SIGNAL
        xtensa: add support for TIF_NOTIFY_SIGNAL
        arm: add support for TIF_NOTIFY_SIGNAL
        microblaze: add support for TIF_NOTIFY_SIGNAL
        hexagon: add support for TIF_NOTIFY_SIGNAL
        csky: add support for TIF_NOTIFY_SIGNAL
        openrisc: add support for TIF_NOTIFY_SIGNAL
        sh: add support for TIF_NOTIFY_SIGNAL
        um: add support for TIF_NOTIFY_SIGNAL
        ...
      005b2a9d
    • L
      Merge branch 'parisc-5.11-1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/parisc-linux · 5ee863be
      Linus Torvalds 提交于
      Pull parisc updates from Helge Deller:
       "A change to increase the default maximum stack size on parisc to 100MB
        and the ability to further increase the stack hard limit size at
        runtime with ulimit for newly started processes.
      
        The other patches fix compile warnings, utilize the Kbuild logic and
        cleanups the parisc arch code"
      
      * 'parisc-5.11-1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/parisc-linux:
        parisc: pci-dma: fix warning unused-function
        parisc/uapi: Use Kbuild logic to provide <asm/types.h>
        parisc: Make user stack size configurable
        parisc: Use _TIF_USER_WORK_MASK in entry.S
        parisc: Drop loops_per_jiffy from per_cpu struct
      5ee863be
    • L
      Merge tag 'mips_5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/mips/linux · 8312f41f
      Linus Torvalds 提交于
      Pull MIPS updates from Thomas Bogendoerfer:
      
       - enable GCOV
      
       - rework setup of protection map
      
       - add support for more MSCC platforms
      
       - add sysfs boardinfo for Loongson64
      
       - enable KASLR for Loogson64
      
       - add reset controller for BCM63xx
      
       - cleanups and fixes
      
      * tag 'mips_5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/mips/linux: (70 commits)
        mips: fix Section mismatch in reference
        MAINTAINERS: Add linux-mips mailing list to JZ47xx entries
        MAINTAINERS: Remove JZ4780 DMA driver entry
        MAINTAINERS: chenhc@lemote.com -> chenhuacai@kernel.org
        MIPS: Octeon: irq: Alloc desc before configuring IRQ
        MIPS: mm: Add back define for PAGE_SHARED
        MIPS: Select ARCH_KEEP_MEMBLOCK if DEBUG_KERNEL to enable sysfs memblock debug
        mips: lib: uncached: fix non-standard usage of variable 'sp'
        MIPS: DTS: img: Fix schema warnings for pwm-leds
        MIPS: KASLR: Avoid endless loop in sync_icache if synci_step is zero
        MIPS: Move memblock_dump_all() to the end of setup_arch()
        MIPS: SMP-CPS: Add support for irq migration when CPU offline
        MIPS: OCTEON: Don't add kernel sections into memblock allocator
        MIPS: Don't round up kernel sections size for memblock_add()
        MIPS: Enable GCOV
        MIPS: configs: drop unused BACKLIGHT_GENERIC option
        MIPS: Loongson64: Fix up reserving kernel memory range
        MIPS: mm: Remove unused is_aligned_hugepage_range
        MIPS: No need to check CPU 0 in {loongson3,bmips,octeon}_cpu_disable()
        mips: cdmm: fix use-after-free in mips_cdmm_bus_discover
        ...
      8312f41f
    • L
      Merge tag 'microblaze-v5.11' of git://git.monstr.eu/linux-2.6-microblaze · 66fc6a62
      Linus Torvalds 提交于
      Pull microblaze updates from Michal Simek:
       "The biggest change is to remove support for noMMU configuration.
      
        FPGAs are bigger so people use Microblaze with MMU for a lot of years
        and there is likely no user of this code anymore. No one is updating
        libraries for this configuration either.
      
         - Remove noMMU support
      
         - Add support for TIF_NOTIFY_SIGNAL
      
         - Small header fix"
      
      * tag 'microblaze-v5.11' of git://git.monstr.eu/linux-2.6-microblaze:
        microblaze: Remove noMMU code
        microblaze: add support for TIF_NOTIFY_SIGNAL
        microblaze: Replace <linux/clk-provider.h> by <linux/of_clk.h>
      66fc6a62
    • L
      Merge tag 'for-linus-5.11-rc1-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip · 7acfd427
      Linus Torvalds 提交于
      Pull xen updates from Juergen Gross:
       "Fixes for security issues just having been disclosed:
      
         - a five patch series for fixing of XSA-349 (DoS via resource
           depletion in Xen dom0)
      
         - a patch fixing XSA-350 (access of stale pointer in a Xen dom0)"
      
      * tag 'for-linus-5.11-rc1-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip:
        xen-blkback: set ring->xenblkd to NULL after kthread_stop()
        xenbus/xenbus_backend: Disallow pending watch messages
        xen/xenbus: Count pending messages for each watch
        xen/xenbus/xen_bus_type: Support will_handle watch callback
        xen/xenbus: Add 'will_handle' callback support in xenbus_watch_path()
        xen/xenbus: Allow watches discard events before queueing
      7acfd427
    • L
      Merge tag 'hyperv-next-signed-20201214' of... · 571b12dd
      Linus Torvalds 提交于
      Merge tag 'hyperv-next-signed-20201214' of git://git.kernel.org/pub/scm/linux/kernel/git/hyperv/linux
      
      Pull Hyper-V updates from Wei Liu:
      
       - harden VMBus (Andres Beltran)
      
       - clean up VMBus driver (Matheus Castello)
      
       - fix hv_balloon reporting (Vitaly Kuznetsov)
      
       - fix a potential OOB issue (Andrea Parri)
      
       - remove an obsolete TODO item (Stefan Eschenbacher)
      
      * tag 'hyperv-next-signed-20201214' of git://git.kernel.org/pub/scm/linux/kernel/git/hyperv/linux:
        hv_balloon: do adjust_managed_page_count() when ballooning/un-ballooning
        hv_balloon: simplify math in alloc_balloon_pages()
        drivers/hv: remove obsolete TODO and fix misleading typo in comment
        drivers: hv: vmbus: Fix checkpatch SPLIT_STRING
        hv_netvsc: Validate number of allocated sub-channels
        drivers: hv: vmbus: Fix call msleep using < 20ms
        drivers: hv: vmbus: Fix checkpatch LINE_SPACING
        drivers: hv: vmbus: Replace symbolic permissions by octal permissions
        drivers: hv: Fix hyperv_record_panic_msg path on comment
        hv_netvsc: Use vmbus_requestor to generate transaction IDs for VMBus hardening
        scsi: storvsc: Use vmbus_requestor to generate transaction IDs for VMBus hardening
        Drivers: hv: vmbus: Add vmbus_requestor data structure for VMBus hardening
      571b12dd
    • L
      Merge tag 'seccomp-v5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux · e994cc24
      Linus Torvalds 提交于
      Pull seccomp updates from Kees Cook:
       "The major change here is finally gaining seccomp constant-action
        bitmaps, which internally reduces the seccomp overhead for many
        real-world syscall filters to O(1), as discussed at Plumbers this
        year.
      
         - Improve seccomp performance via constant-action bitmaps (YiFei Zhu
           & Kees Cook)
      
         - Fix bogus __user annotations (Jann Horn)
      
         - Add missed CONFIG for improved selftest coverage (Mickaël Salaün)"
      
      * tag 'seccomp-v5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
        selftests/seccomp: Update kernel config
        seccomp: Remove bogus __user annotations
        seccomp/cache: Report cache data through /proc/pid/seccomp_cache
        xtensa: Enable seccomp architecture tracking
        sh: Enable seccomp architecture tracking
        s390: Enable seccomp architecture tracking
        riscv: Enable seccomp architecture tracking
        powerpc: Enable seccomp architecture tracking
        parisc: Enable seccomp architecture tracking
        csky: Enable seccomp architecture tracking
        arm: Enable seccomp architecture tracking
        arm64: Enable seccomp architecture tracking
        selftests/seccomp: Compare bitmap vs filter overhead
        x86: Enable seccomp architecture tracking
        seccomp/cache: Add "emulator" to check if filter is constant allow
        seccomp/cache: Lookup syscall allowlist bitmap for fast path
      e994cc24
    • L
      Merge tag 'pstore-v5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux · ba1d41a5
      Linus Torvalds 提交于
      Pull pstore updates from Kees Cook:
      
       - Clean up unused but exposed API (Christoph Hellwig)
      
       - Provide KCONFIG for default size of kmsg buffer (Vasile-Laurentiu
         Stanimir)
      
      * tag 'pstore-v5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
        pstore: Move kmsg_bytes default into Kconfig
        pstore/blk: remove {un,}register_pstore_blk
        pstore/blk: update the command line example
        pstore/zone: cap the maximum device size
      ba1d41a5
    • L
      Merge tag 'gcc-plugins-v5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux · 6df0f285
      Linus Torvalds 提交于
      Pull gcc-plugins updates from Kees Cook:
      
       - Clean up gcc plugin builds now that GCC must be 4.9+ (Masahiro
         Yamada)
      
       - Update MAINTAINERS (Kees Cook)
      
      * tag 'gcc-plugins-v5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
        MAINTAINERS: Drop inactive gcc-plugins maintainer
        gcc-plugins: simplify GCC plugin-dev capability test
        gcc-plugins: remove code for GCC versions older than 4.9
      6df0f285
    • L
      Merge tag 'Smack-for-5.11' of git://github.com/cschaufler/smack-next · 8bda68d6
      Linus Torvalds 提交于
      Pull smack updates from Casey Schaufler:
       "There are no functional changes. Just one minor code clean-up and a
        set of corrections in function header comments"
      
      * tag 'Smack-for-5.11' of git://github.com/cschaufler/smack-next:
        security/smack: remove unused varible 'rc'
        Smack: fix kernel-doc interface on functions
      8bda68d6
    • L
      Merge tag 'integrity-v5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/zohar/linux-integrity · e20a9b92
      Linus Torvalds 提交于
      Pull integrity subsystem updates from Mimi Zohar:
       "Just three patches here. Other integrity changes are being upstreamed
        via EFI (defines a common EFI secure and trusted boot IMA policy) and
        BPF LSM (exporting the IMA file cache hash info based on inode).
      
        The three patches included here:
      
         - bug fix: fail calculating the file hash, when a file not opened for
           read and the attempt to re-open it for read fails.
      
         - defer processing the "ima_appraise" boot command line option to
           avoid enabling different modes (e.g. fix, log) to when the secure
           boot flag is available on arm.
      
         - defines "ima-buf" as the default IMA buffer measurement template in
           preparation for the builtin integrity "critical data" policy"
      
      * tag 'integrity-v5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/zohar/linux-integrity:
        ima: Don't modify file descriptor mode on the fly
        ima: select ima-buf template for buffer measurement
        ima: defer arch_ima_get_secureboot() call to IMA init time
      e20a9b92
    • L
      Merge tag 'selinux-pr-20201214' of git://git.kernel.org/pub/scm/linux/kernel/git/pcmoore/selinux · ca5b877b
      Linus Torvalds 提交于
      Pull selinux updates from Paul Moore:
       "While we have a small number of SELinux patches for v5.11, there are a
        few changes worth highlighting:
      
         - Change the LSM network hooks to pass flowi_common structs instead
           of the parent flowi struct as the LSMs do not currently need the
           full flowi struct and they do not have enough information to use it
           safely (missing information on the address family).
      
           This patch was discussed both with Herbert Xu (representing team
           netdev) and James Morris (representing team
           LSMs-other-than-SELinux).
      
         - Fix how we handle errors in inode_doinit_with_dentry() so that we
           attempt to properly label the inode on following lookups instead of
           continuing to treat it as unlabeled.
      
         - Tweak the kernel logic around allowx, auditallowx, and dontauditx
           SELinux policy statements such that the auditx/dontauditx are
           effective even without the allowx statement.
      
        Everything passes our test suite"
      
      * tag 'selinux-pr-20201214' of git://git.kernel.org/pub/scm/linux/kernel/git/pcmoore/selinux:
        lsm,selinux: pass flowi_common instead of flowi to the LSM hooks
        selinux: Fix fall-through warnings for Clang
        selinux: drop super_block backpointer from superblock_security_struct
        selinux: fix inode_doinit_with_dentry() LABEL_INVALID error handling
        selinux: allow dontauditx and auditallowx rules to take effect without allowx
        selinux: fix error initialization in inode_doinit_with_dentry()
      ca5b877b
    • L
      Merge tag 'audit-pr-20201214' of git://git.kernel.org/pub/scm/linux/kernel/git/pcmoore/audit · 3d5de2dd
      Linus Torvalds 提交于
      Pull audit updates from Paul Moore:
       "A small set of audit patches for v5.11 with four patches in total and
        only one of any real significance.
      
        Richard's patch to trigger accompanying records causes the kernel to
        emit additional related records when an audit event occurs; helping
        provide some much needed context to events in the audit log. It is
        also worth mentioning that this is a revised patch based on an earlier
        attempt that had to be reverted in the v5.8 time frame.
      
        Everything passes our test suite, and with no problems reported please
        merge this for v5.11"
      
      * tag 'audit-pr-20201214' of git://git.kernel.org/pub/scm/linux/kernel/git/pcmoore/audit:
        audit: replace atomic_add_return()
        audit: fix macros warnings
        audit: trigger accompanying records when no rules present
        audit: fix a kernel-doc markup
      3d5de2dd
    • L
      Merge tag 'printk-for-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/printk/linux · d3eb5211
      Linus Torvalds 提交于
      Pull printk updates from Petr Mladek:
      
       - Finally allow parallel writes and reads into/from the lockless
         ringbuffer. But it is not a complete solution. Readers are still
         serialized against each other. And nested writes are still prevented
         by printk_safe per-CPU buffers.
      
       - Use ttynull as the ultimate fallback for /dev/console.
      
       - Officially allow disabling console output by using console="" or
         console=null
      
       - A few code cleanups
      
      * tag 'printk-for-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/printk/linux:
        printk: remove logbuf_lock writer-protection of ringbuffer
        printk: inline log_output(),log_store() in vprintk_store()
        printk: remove obsolete dead assignment
        printk/console: Allow to disable console output by using console="" or console=null
        init/console: Use ttynull as a fallback when there is no console
        printk: ringbuffer: Reference text_data_ring directly in callees.
      d3eb5211
  5. 16 12月, 2020 10 次提交
    • L
      Merge tag 'fallthrough-fixes-clang-5.11-rc1' of... · 5e60366d
      Linus Torvalds 提交于
      Merge tag 'fallthrough-fixes-clang-5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gustavoars/linux
      
      Pull fallthrough fixes from Gustavo A. R. Silva:
       "Fix many fall-through warnings when building with Clang 12.0.0
        using -Wimplicit-fallthrough.
      
         - powerpc: boot: include compiler_attributes.h (Nick Desaulniers)
      
         - Revert "lib: Revert use of fallthrough pseudo-keyword in lib/"
           (Nick Desaulniers)
      
         - powerpc: fix -Wimplicit-fallthrough (Nick Desaulniers)
      
         - lib: Fix fall-through warnings for Clang (Gustavo A. R. Silva)"
      
      * tag 'fallthrough-fixes-clang-5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gustavoars/linux:
        lib: Fix fall-through warnings for Clang
        powerpc: fix -Wimplicit-fallthrough
        Revert "lib: Revert use of fallthrough pseudo-keyword in lib/"
        powerpc: boot: include compiler_attributes.h
      5e60366d
    • L
      Merge tag 'linux-kselftest-kunit-5.11-rc1' of... · 706451d4
      Linus Torvalds 提交于
      Merge tag 'linux-kselftest-kunit-5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull Kunit updates from Shuah Khan:
      
       - documentation update and fix to kunit_tool to parse diagnostic
         messages correctly from David Gow
      
       - Support for Parameterized Testing and fs/ext4 test updates to use
         KUnit parameterized testing feature from Arpitha Raghunandan
      
       - Helper to derive file names depending on --build_dir argument from
         Andy Shevchenko
      
      * tag 'linux-kselftest-kunit-5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest:
        fs: ext4: Modify inode-test.c to use KUnit parameterized testing feature
        kunit: Support for Parameterized Testing
        kunit: kunit_tool: Correctly parse diagnostic messages
        Documentation: kunit: provide guidance for testing many inputs
        kunit: Introduce get_file_path() helper
      706451d4
    • L
      Merge tag 'linux-kselftest-next-5.11-rc1' of... · 7194850e
      Linus Torvalds 提交于
      Merge tag 'linux-kselftest-next-5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull Kselftest updates from Shuah Khan:
      
       - Much needed gpio test Makefile cleanup to various problems with test
         dependencies and build errors from Michael Ellerman
      
       - Enabling vDSO test on non x86 platforms from Vincenzo Frascino
      
       - Fix intel_pstate to replace deprecated ftime() usages with
         clock_gettime() from Tommi Rantala
      
       - cgroup test build fix on older releases from Sachin Sant
      
       - A couple of spelling mistake fixes
      
      * tag 'linux-kselftest-next-5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest:
        selftests/cgroup: Fix build on older distros
        selftests/run_kselftest.sh: fix dry-run typo
        tool: selftests: fix spelling typo of 'writting'
        selftests/memfd: Fix implicit declaration warnings
        selftests: intel_pstate: ftime() is deprecated
        selftests/gpio: Add to CLEAN rule rather than overriding
        selftests/gpio: Fix build when source tree is read only
        selftests/gpio: Move include of lib.mk up
        selftests/gpio: Use TEST_GEN_PROGS_EXTENDED
        kselftest: Extend vdso correctness test to clock_gettime64
        kselftest: Move test_vdso to the vDSO test suite
        kselftest: Extend vDSO selftest to clock_getres
        kselftest: Extend vDSO selftest
        kselftest: Enable vDSO test on non x86 platforms
      7194850e
    • L
      Merge tag 'linux-kselftest-fixes-5.11-rc1' of... · b80affe3
      Linus Torvalds 提交于
      Merge tag 'linux-kselftest-fixes-5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull Kselftest fixes from Shuah Khan:
       "Build fixes for clone3 and rseq tests"
      
      * tag 'linux-kselftest-fixes-5.11-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest:
        selftests/clone3: Fix build error
        rseq/selftests: Fix MEMBARRIER_CMD_PRIVATE_EXPEDITED_RSEQ build error under other arch.
      b80affe3
    • L
      Merge tag 'asm-generic-timers-5.11' of... · 7a932e57
      Linus Torvalds 提交于
      Merge tag 'asm-generic-timers-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic
      
      Pull asm-generic cross-architecture timer cleanup from Arnd Bergmann:
       "This cleans up two ancient timer features that were never completed in
        the past, CONFIG_GENERIC_CLOCKEVENTS and CONFIG_ARCH_USES_GETTIMEOFFSET.
      
        There was only one user left for the ARCH_USES_GETTIMEOFFSET variant
        of clocksource implementations, the ARM EBSA110 platform. Rather than
        changing to use modern timekeeping, we remove the platform entirely as
        Russell no longer uses his machine and nobody else seems to have one
        any more.
      
        The conditional code for using arch_gettimeoffset() is removed as a
        result.
      
        For CONFIG_GENERIC_CLOCKEVENTS, there are still a couple of platforms
        not using clockevent drivers: parisc, ia64, most of m68k, and one Arm
        platform. These all do timer ticks slighly differently, and this gets
        cleaned up to the point they at least all call the same helper
        function.
      
        Instead of most platforms using 'select GENERIC_CLOCKEVENTS' in
        Kconfig, the polarity is now reversed, with the few remaining ones
        selecting LEGACY_TIMER_TICK instead"
      
      * tag 'asm-generic-timers-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic:
        timekeeping: default GENERIC_CLOCKEVENTS to enabled
        timekeeping: remove xtime_update
        m68k: remove timer_interrupt() function
        m68k: change remaining timers to legacy_timer_tick
        m68k: m68328: use legacy_timer_tick()
        m68k: sun3/sun3c: use legacy_timer_tick
        m68k: split heartbeat out of timer function
        m68k: coldfire: use legacy_timer_tick()
        parisc: use legacy_timer_tick
        ARM: rpc: use legacy_timer_tick
        ia64: convert to legacy_timer_tick
        timekeeping: add CONFIG_LEGACY_TIMER_TICK
        timekeeping: remove arch_gettimeoffset
        net: remove am79c961a driver
        ARM: remove ebsa110 platform
      7a932e57
    • L
      Merge tag 'asm-generic-mmu-context-5.11' of... · 15780712
      Linus Torvalds 提交于
      Merge tag 'asm-generic-mmu-context-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic
      
      Pull asm-generic mmu-context cleanup from Arnd Bergmann:
       "This is a cleanup series from Nicholas Piggin, preparing for later
        changes. The asm/mmu_context.h header are generalized and common code
        moved to asm-gneneric/mmu_context.h.
      
        This saves a bit of code and makes it easier to change in the future"
      
      * tag 'asm-generic-mmu-context-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic: (25 commits)
        h8300: Fix generic mmu_context build
        m68k: mmu_context: Fix Sun-3 build
        xtensa: use asm-generic/mmu_context.h for no-op implementations
        x86: use asm-generic/mmu_context.h for no-op implementations
        um: use asm-generic/mmu_context.h for no-op implementations
        sparc: use asm-generic/mmu_context.h for no-op implementations
        sh: use asm-generic/mmu_context.h for no-op implementations
        s390: use asm-generic/mmu_context.h for no-op implementations
        riscv: use asm-generic/mmu_context.h for no-op implementations
        powerpc: use asm-generic/mmu_context.h for no-op implementations
        parisc: use asm-generic/mmu_context.h for no-op implementations
        openrisc: use asm-generic/mmu_context.h for no-op implementations
        nios2: use asm-generic/mmu_context.h for no-op implementations
        nds32: use asm-generic/mmu_context.h for no-op implementations
        mips: use asm-generic/mmu_context.h for no-op implementations
        microblaze: use asm-generic/mmu_context.h for no-op implementations
        m68k: use asm-generic/mmu_context.h for no-op implementations
        ia64: use asm-generic/mmu_context.h for no-op implementations
        hexagon: use asm-generic/mmu_context.h for no-op implementations
        csky: use asm-generic/mmu_context.h for no-op implementations
        ...
      15780712
    • L
      Merge tag 'asm-generic-cleanup-5.11' of... · e2dc4957
      Linus Torvalds 提交于
      Merge tag 'asm-generic-cleanup-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic
      
      Pull asm-generic cleanups from Arnd Bergmann:
       "These are a couple of compiler warning fixes to make 'make W=2' less
        noisy, as well as some fixes to code comments in asm-generic"
      
      * tag 'asm-generic-cleanup-5.11' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic:
        syscalls: Fix file comments for syscalls implemented in kernel/sys.c
        ctype.h: remove duplicate isdigit() helper
        qspinlock: use signed temporaries for cmpxchg
        asm-generic: fix ffs -Wshadow warning
        asm-generic: percpu: avoid Wshadow warning
        asm-generic/sembuf: Update architecture related information in comment
      e2dc4957
    • L
      Merge branch 'akpm' (patches from Andrew) · f986e350
      Linus Torvalds 提交于
      Merge yet more updates from Andrew Morton:
      
       - lots of little subsystems
      
       - a few post-linux-next MM material. Most of the rest awaits more
         merging of other trees.
      
      Subsystems affected by this series: alpha, procfs, misc, core-kernel,
      bitmap, lib, lz4, checkpatch, nilfs, kdump, rapidio, gcov, bfs, relay,
      resource, ubsan, reboot, fault-injection, lzo, apparmor, and mm (swap,
      memory-hotplug, pagemap, cleanups, and gup).
      
      * emailed patches from Andrew Morton <akpm@linux-foundation.org>: (86 commits)
        mm: fix some spelling mistakes in comments
        mm: simplify follow_pte{,pmd}
        mm: unexport follow_pte_pmd
        apparmor: remove duplicate macro list_entry_is_head()
        lib/lzo/lzo1x_compress.c: make lzogeneric1x_1_compress() static
        fault-injection: handle EI_ETYPE_TRUE
        reboot: hide from sysfs not applicable settings
        reboot: allow to override reboot type if quirks are found
        reboot: remove cf9_safe from allowed types and rename cf9_force
        reboot: allow to specify reboot mode via sysfs
        reboot: refactor and comment the cpu selection code
        lib/ubsan.c: mark type_check_kinds with static keyword
        kcov: don't instrument with UBSAN
        ubsan: expand tests and reporting
        ubsan: remove UBSAN_MISC in favor of individual options
        ubsan: enable for all*config builds
        ubsan: disable UBSAN_TRAP for all*config
        ubsan: disable object-size sanitizer under GCC
        ubsan: move cc-option tests into Kconfig
        ubsan: remove redundant -Wno-maybe-uninitialized
        ...
      f986e350
    • H
      mm: fix some spelling mistakes in comments · 8958b249
      Haitao Shi 提交于
      Fix some spelling mistakes in comments:
      	udpate ==> update
      	succesful ==> successful
      	exmaple ==> example
      	unneccessary ==> unnecessary
      	stoping ==> stopping
      	uknown ==> unknown
      
      Link: https://lkml.kernel.org/r/20201127011747.86005-1-shihaitao1@huawei.comSigned-off-by: NHaitao Shi <shihaitao1@huawei.com>
      Reviewed-by: NMike Rapoport <rppt@linux.ibm.com>
      Reviewed-by: NSouptick Joarder <jrdr.linux@gmail.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      8958b249
    • C
      mm: simplify follow_pte{,pmd} · ff5c19ed
      Christoph Hellwig 提交于
      Merge __follow_pte_pmd, follow_pte_pmd and follow_pte into a single
      follow_pte function and just pass two additional NULL arguments for the
      two previous follow_pte callers.
      
      [sfr@canb.auug.org.au: merge fix for "s390/pci: remove races against pte updates"]
        Link: https://lkml.kernel.org/r/20201111221254.7f6a3658@canb.auug.org.au
      
      Link: https://lkml.kernel.org/r/20201029101432.47011-3-hch@lst.deSigned-off-by: NChristoph Hellwig <hch@lst.de>
      Reviewed-by: NMatthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Daniel Vetter <daniel@ffwll.ch>
      Cc: Dan Williams <dan.j.williams@intel.com>
      Cc: Nick Desaulniers <ndesaulniers@google.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      ff5c19ed