lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite for Android: free password hash cracker in your pocket
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Date:   Wed, 18 Oct 2017 12:59:44 -0700
From:   "Paul E. McKenney" <paulmck@...ux.vnet.ibm.com>
To:     torvalds@...ux-foundation.org
Cc:     mingo@...nel.org, mathieu.desnoyers@...icios.com,
        peterz@...radead.org, boqun.feng@...il.com, ahh@...gle.com,
        maged.michael@...il.com, gromer@...gle.com, avi@...lladb.com,
        benh@...nel.crashing.org, paulus@...ba.org, mpe@...erman.id.au,
        davejwatson@...com, stern@...land.harvard.edu, will.deacon@....com,
        luto@...nel.org, viro@...iv.linux.org.uk, npiggin@...il.com,
        linux-arch@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: [GIT PULL urgent-membarrier] membarrier commits for 4.14

Hello, Linus,

This urgent pull request contains five commits that fix a problem
that arose when designing requested extensions to sys_membarrier()
to allow JITs to efficiently flush old code from instruction caches.
Several potential algorithms are much less painful if the user register
intent to use this functionality early on, for example, before the process
spawns the second thread.  Registering at this time removes the need to
interrupt each and every thread in that process at the first expedited
sys_membarrier() system call.

However, if we let the current function out, then user programs might be
written without registration, which would make it more difficult to add
required registration after the fact.  Hence the late-in-merge-window
pull request.

The last two commits remove unused code from architectures not supporting
sys_membarrier() and fix a problem that arises when tasks are created
with CLONE_VM but !CLONE_THREAD on powerpc.

These have been subject to 0day test robot and -next testing and
are available in the git repository at:

  git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu.git membarrier.2017.10.09a

for you to fetch changes up to f7399e01ccd0850786bdedbee2fd351651ce99f8:

  Fix: membarrier: Handle CLONE_VM + !CLONE_THREAD correctly on powerpc (2017-10-09 14:24:49 -0700)

----------------------------------------------------------------
Mathieu Desnoyers (5):
      membarrier: Provide register expedited private command
      membarrier: selftest: Test private expedited cmd
      membarrier: Document scheduler barrier requirements
      membarrier: Remove unused code for architectures without membarrier hooks
      Fix: membarrier: Handle CLONE_VM + !CLONE_THREAD correctly on powerpc

 MAINTAINERS                                        |   2 +
 arch/powerpc/Kconfig                               |   1 +
 arch/powerpc/include/asm/membarrier.h              |  26 +++++
 arch/powerpc/kernel/Makefile                       |   2 +
 arch/powerpc/kernel/membarrier.c                   |  36 +++++++
 arch/powerpc/mm/mmu_context.c                      |   7 ++
 arch/x86/mm/tlb.c                                  |   5 +
 fs/exec.c                                          |   1 +
 include/linux/mm_types.h                           |   3 +
 include/linux/sched/mm.h                           |  37 +++++++
 include/uapi/linux/membarrier.h                    |  23 +++--
 init/Kconfig                                       |   3 +
 kernel/sched/core.c                                |  47 +++++----
 kernel/sched/membarrier.c                          |  35 ++++++-
 .../testing/selftests/membarrier/membarrier_test.c | 109 ++++++++++++++++++---
 15 files changed, 290 insertions(+), 47 deletions(-)
 create mode 100644 arch/powerpc/include/asm/membarrier.h
 create mode 100644 arch/powerpc/kernel/membarrier.c

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ