1. 25 7月, 2018 2 次提交
    • M
      locking/atomics: Simplify cmpxchg() instrumentation · df79ed2c
      Mark Rutland 提交于
      Currently we define some fairly verbose wrappers for the cmpxchg()
      family so that we can pass a pointer and size into kasan_check_write().
      
      The wrappers duplicate the size-switching logic necessary in arch code,
      and only work for scalar types. On some architectures, (cmp)xchg are
      used on non-scalar types, and thus the instrumented wrappers need to be
      able to handle this.
      
      We could take the type-punning logic from {READ,WRITE}_ONCE(), but this
      makes the wrappers even more verbose, and requires several local
      variables in the macros.
      
      Instead, let's simplify the wrappers into simple macros which:
      
      * snapshot the pointer into a single local variable, called __ai_ptr to
        avoid conflicts with variables in the scope of the caller.
      
      * call kasan_check_write() on __ai_ptr.
      
      * invoke the relevant arch_*() function, passing the original arguments,
        bar __ai_ptr being substituted for ptr.
      
      There should be no functional change as a result of this patch.
      Signed-off-by: NMark Rutland <mark.rutland@arm.com>
      Acked-by: NPeter Zijlstra (Intel) <peterz@infradead.org>
      Acked-by: NWill Deacon <will.deacon@arm.com>
      Cc: Boqun Feng <boqun.feng@gmail.com>
      Cc: Dmitry Vyukov <dvyukov@google.com>
      Cc: Linus Torvalds <torvalds@linux-foundation.org>
      Cc: Peter Zijlstra <peterz@infradead.org>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: andy.shevchenko@gmail.com
      Cc: arnd@arndb.de
      Cc: aryabinin@virtuozzo.com
      Cc: catalin.marinas@arm.com
      Cc: glider@google.com
      Cc: linux-arm-kernel@lists.infradead.org
      Cc: parri.andrea@gmail.com
      Cc: peter@hurleysoftware.com
      Link: http://lkml.kernel.org/r/20180716113017.3909-4-mark.rutland@arm.comSigned-off-by: NIngo Molnar <mingo@kernel.org>
      df79ed2c
    • M
      locking/atomics/x86: Reduce arch_cmpxchg64*() instrumentation · 00d5551c
      Mark Rutland 提交于
      Currently x86's arch_cmpxchg64() and arch_cmpxchg64_local() are
      instrumented twice, as they call into instrumented atomics rather than
      their arch_ equivalents.
      
      A call to cmpxchg64() results in:
      
        cmpxchg64()
          kasan_check_write()
          arch_cmpxchg64()
            cmpxchg()
              kasan_check_write()
              arch_cmpxchg()
      
      Let's fix this up and call the arch_ equivalents, resulting in:
      
        cmpxchg64()
          kasan_check_write()
          arch_cmpxchg64()
            arch_cmpxchg()
      Signed-off-by: NMark Rutland <mark.rutland@arm.com>
      Acked-by: NThomas Gleixner <tglx@linutronix.de>
      Acked-by: NPeter Zijlstra (Intel) <peterz@infradead.org>
      Acked-by: NWill Deacon <will.deacon@arm.com>
      Cc: Boqun Feng <boqun.feng@gmail.com>
      Cc: Dmitry Vyukov <dvyukov@google.com>
      Cc: Linus Torvalds <torvalds@linux-foundation.org>
      Cc: Peter Zijlstra <peterz@infradead.org>
      Cc: andy.shevchenko@gmail.com
      Cc: arnd@arndb.de
      Cc: aryabinin@virtuozzo.com
      Cc: catalin.marinas@arm.com
      Cc: glider@google.com
      Cc: linux-arm-kernel@lists.infradead.org
      Cc: parri.andrea@gmail.com
      Cc: peter@hurleysoftware.com
      Link: http://lkml.kernel.org/r/20180716113017.3909-3-mark.rutland@arm.comSigned-off-by: NIngo Molnar <mingo@kernel.org>
      00d5551c
  2. 17 7月, 2018 15 次提交
  3. 16 7月, 2018 2 次提交
  4. 15 7月, 2018 19 次提交
  5. 14 7月, 2018 2 次提交