From: Dimitri Sivanich Date: Fri, 29 Jun 2012 21:17:29 +0000 (-0700) Subject: rcu: Segregate rcu_state fields to improve cache locality X-Git-Tag: v3.7-rc1~199^2~1^2~17 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=b402b73b3afe3614bc0e921ebe18013ea103115a;p=thirdparty%2Fkernel%2Fstable.git rcu: Segregate rcu_state fields to improve cache locality The fields in the rcu_state structure that are protected by the root rcu_node structure's ->lock can share a cache line with the fields protected by ->onofflock. This can result in excessive memory contention on large systems, so this commit applies ____cacheline_internodealigned_in_smp to the ->onofflock field in order to segregate them. Signed-off-by: Dimitri Sivanich Signed-off-by: Paul E. McKenney Tested-by: Dimitri Sivanich Reviewed-by: Josh Triplett --- diff --git a/kernel/rcutree.h b/kernel/rcutree.h index effb2733b7fc1..5d92b80a0a281 100644 --- a/kernel/rcutree.h +++ b/kernel/rcutree.h @@ -394,7 +394,8 @@ struct rcu_state { /* End of fields guarded by root rcu_node's lock. */ - raw_spinlock_t onofflock; /* exclude on/offline and */ + raw_spinlock_t onofflock ____cacheline_internodealigned_in_smp; + /* exclude on/offline and */ /* starting new GP. */ struct rcu_head *orphan_nxtlist; /* Orphaned callbacks that */ /* need a grace period. */