[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20060919111950.GD21713@skybase>
Date: Tue, 19 Sep 2006 13:19:50 +0200
From: Martin Schwidefsky <schwidefsky@...ibm.com>
To: linux-arch@...r.kernel.org, linux-kernel@...r.kernel.org,
akpm@...l.org
Cc: mingo@...e.hu, paulus@...ba.org
Subject: [patch 2/3] Directed yield: direct yield of spinlocks for powerpc.
From: Martin Schwidefsky <schwidefsky@...ibm.com>
[patch 2/3] Directed yield: direct yield of spinlocks for powerpc.
Powerpc already has a directed yield for CONFIG_PREEMPT="n". To make
it work with CONFIG_PREEMPT="y" as well the _raw_{spin,read,write}_relax
primitives need to be defined to call __spin_yield() for spinlocks and
__rw_yield() for rw-locks.
Cc: Paul Mackerras <paulus@...ba.org>
Signed-off-by: Martin Schwidefsky <schwidefsky@...ibm.com>
---
include/asm-powerpc/spinlock.h | 6 +++---
1 files changed, 3 insertions(+), 3 deletions(-)
diff -urpN linux-2.6/include/asm-powerpc/spinlock.h linux-2.6-patched/include/asm-powerpc/spinlock.h
--- linux-2.6/include/asm-powerpc/spinlock.h 2006-09-19 12:59:35.000000000 +0200
+++ linux-2.6-patched/include/asm-powerpc/spinlock.h 2006-09-19 12:59:35.000000000 +0200
@@ -285,9 +285,9 @@ static __inline__ void __raw_write_unloc
rw->lock = 0;
}
-#define _raw_spin_relax(lock) cpu_relax()
-#define _raw_read_relax(lock) cpu_relax()
-#define _raw_write_relax(lock) cpu_relax()
+#define _raw_spin_relax(lock) __spin_yield(lock)
+#define _raw_read_relax(lock) __rw_yield(lock)
+#define _raw_write_relax(lock) __rw_yield(lock)
#endif /* __KERNEL__ */
#endif /* __ASM_SPINLOCK_H */
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists