1. 12 9月, 2013 1 次提交
    • D
      ipc,shm: introduce lockless functions to obtain the ipc object · 8b8d52ac
      Davidlohr Bueso 提交于
      This is the third and final patchset that deals with reducing the amount
      of contention we impose on the ipc lock (kern_ipc_perm.lock).  These
      changes mostly deal with shared memory, previous work has already been
      done for semaphores and message queues:
      
        http://lkml.org/lkml/2013/3/20/546 (sems)
        http://lkml.org/lkml/2013/5/15/584 (mqueues)
      
      With these patches applied, a custom shm microbenchmark stressing shmctl
      doing IPC_STAT with 4 threads a million times, reduces the execution
      time by 50%.  A similar run, this time with IPC_SET, reduces the
      execution time from 3 mins and 35 secs to 27 seconds.
      
      Patches 1-8: replaces blindly taking the ipc lock for a smarter
      combination of rcu and ipc_obtain_object, only acquiring the spinlock
      when updating.
      
      Patch 9: renames the ids rw_mutex to rwsem, which is what it already was.
      
      Patch 10: is a trivial mqueue leftover cleanup
      
      Patch 11: adds a brief lock scheme description, requested by Andrew.
      
      This patch:
      
      Add shm_obtain_object() and shm_obtain_object_check(), which will allow us
      to get the ipc object without acquiring the lock.  Just as with other
      forms of ipc, these functions are basically wrappers around
      ipc_obtain_object*().
      Signed-off-by: NDavidlohr Bueso <davidlohr.bueso@hp.com>
      Tested-by: NSedat Dilek <sedat.dilek@gmail.com>
      Cc: Rik van Riel <riel@redhat.com>
      Cc: Manfred Spraul <manfred@colorfullife.com>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      8b8d52ac
  2. 04 9月, 2013 1 次提交
    • M
      ipc/msg.c: Fix lost wakeup in msgsnd(). · bebcb928
      Manfred Spraul 提交于
      The check if the queue is full and adding current to the wait queue of
      pending msgsnd() operations (ss_add()) must be atomic.
      
      Otherwise:
       - the thread that performs msgsnd() finds a full queue and decides to
         sleep.
       - the thread that performs msgrcv() first reads all messages from the
         queue and then sleeps, because the queue is empty.
       - the msgrcv() calls do not perform any wakeups, because the msgsnd()
         task has not yet called ss_add().
       - then the msgsnd()-thread first calls ss_add() and then sleeps.
      
      Net result: msgsnd() and msgrcv() both sleep forever.
      
      Observed with msgctl08 from ltp with a preemptible kernel.
      
      Fix: Call ipc_lock_object() before performing the check.
      
      The patch also moves security_msg_queue_msgsnd() under ipc_lock_object:
       - msgctl(IPC_SET) explicitely mentions that it tries to expunge any
         pending operations that are not allowed anymore with the new
         permissions.  If security_msg_queue_msgsnd() is called without locks,
         then there might be races.
       - it makes the patch much simpler.
      Reported-and-tested-by: NVineet Gupta <Vineet.Gupta1@synopsys.com>
      Acked-by: NRik van Riel <riel@redhat.com>
      Cc: stable@vger.kernel.org  # for 3.11
      Signed-off-by: NManfred Spraul <manfred@colorfullife.com>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      bebcb928
  3. 31 8月, 2013 1 次提交
  4. 29 8月, 2013 1 次提交
  5. 10 7月, 2013 19 次提交
  6. 27 5月, 2013 1 次提交
    • M
      ipc/sem.c: Fix missing wakeups in do_smart_update_queue() · ab465df9
      Manfred Spraul 提交于
      do_smart_update_queue() is called when an operation (semop,
      semctl(SETVAL), semctl(SETALL), ...) modified the array.  It must check
      which of the sleeping tasks can proceed.
      
      do_smart_update_queue() missed a few wakeups:
       - if a sleeping complex op was completed, then all per-semaphore queues
         must be scanned - not only those that were modified by *sops
       - if a sleeping simple op proceeded, then the global queue must be
         scanned again
      
      And:
       - the test for "|sops == NULL) before scanning the global queue is not
         required: If the global queue is empty, then it doesn't need to be
         scanned - regardless of the reason for calling do_smart_update_queue()
      
      The patch is not optimized, i.e.  even completing a wait-for-zero
      operation causes a rescan.  This is done to keep the patch as simple as
      possible.
      Signed-off-by: NManfred Spraul <manfred@colorfullife.com>
      Acked-by: NDavidlohr Bueso <davidlohr.bueso@hp.com>
      Cc: Rik van Riel <riel@redhat.com>
      Cc: Andrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      ab465df9
  7. 10 5月, 2013 3 次提交
  8. 08 5月, 2013 1 次提交
  9. 05 5月, 2013 7 次提交
  10. 03 5月, 2013 1 次提交
  11. 02 5月, 2013 2 次提交
  12. 01 5月, 2013 2 次提交