• Linus Torvalds's avatar
    Merge tag 'locking-urgent-2020-08-10' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 97d052ea
    Linus Torvalds authored
    Pull locking updates from Thomas Gleixner:
     "A set of locking fixes and updates:
    
       - Untangle the header spaghetti which causes build failures in
         various situations caused by the lockdep additions to seqcount to
         validate that the write side critical sections are non-preemptible.
    
       - The seqcount associated lock debug addons which were blocked by the
         above fallout.
    
         seqcount writers contrary to seqlock writers must be externally
         serialized, which usually happens via locking - except for strict
         per CPU seqcounts. As the lock is not part of the seqcount, lockdep
         cannot validate that the lock is held.
    
         This new debug mechanism adds the concept of associated locks.
         sequence count has now lock type variants and corresponding
         initializers which take a pointer to the associated lock used for
         writer serialization. If lockdep is enabled the pointer is stored
         and write_seqcount_begin() has a lockdep assertion to validate that
         the lock is held.
    
         Aside of the type and the initializer no other code changes are
         required at the seqcount usage sites. The rest of the seqcount API
         is unchanged and determines the type at compile time with the help
         of _Generic which is possible now that the minimal GCC version has
         been moved up.
    
         Adding this lockdep coverage unearthed a handful of seqcount bugs
         which have been addressed already independent of this.
    
         While generally useful this comes with a Trojan Horse twist: On RT
         kernels the write side critical section can become preemtible if
         the writers are serialized by an associated lock, which leads to
         the well known reader preempts writer livelock. RT prevents this by
         storing the associated lock pointer independent of lockdep in the
         seqcount and changing the reader side to block on the lock when a
         reader detects that a writer is in the write side critical section.
    
       - Conversion of seqcount usage sites to associated types and
         initializers"
    
    * tag 'locking-urgent-2020-08-10' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (25 commits)
      locking/seqlock, headers: Untangle the spaghetti monster
      locking, arch/ia64: Reduce <asm/smp.h> header dependencies by moving XTP bits into the new <asm/xtp.h> header
      x86/headers: Remove APIC headers from <asm/smp.h>
      seqcount: More consistent seqprop names
      seqcount: Compress SEQCNT_LOCKNAME_ZERO()
      seqlock: Fold seqcount_LOCKNAME_init() definition
      seqlock: Fold seqcount_LOCKNAME_t definition
      seqlock: s/__SEQ_LOCKDEP/__SEQ_LOCK/g
      hrtimer: Use sequence counter with associated raw spinlock
      kvm/eventfd: Use sequence counter with associated spinlock
      userfaultfd: Use sequence counter with associated spinlock
      NFSv4: Use sequence counter with associated spinlock
      iocost: Use sequence counter with associated spinlock
      raid5: Use sequence counter with associated spinlock
      vfs: Use sequence counter with associated spinlock
      timekeeping: Use sequence counter with associated raw spinlock
      xfrm: policy: Use sequence counters with associated lock
      netfilter: nft_set_rbtree: Use sequence counter with associated rwlock
      netfilter: conntrack: Use sequence counter with associated spinlock
      sched: tasks: Use sequence counter with associated spinlock
      ...
    97d052ea
userfaultfd.c 51.7 KB