RE: [PATCH -mm 5/6] cpu_relax(): use in ACPI lock

From: Moore, Robert
Date: Wed Jun 21 2006 - 17:08:10 EST


I may be interpreting this incorrectly, but are you busy-waiting on the
ACPI Global Lock to become free?

Bob


> -----Original Message-----
> From: linux-acpi-owner@xxxxxxxxxxxxxxx [mailto:linux-acpi-
> owner@xxxxxxxxxxxxxxx] On Behalf Of Andreas Mohr
> Sent: Wednesday, June 21, 2006 2:01 PM
> To: Andrew Morton
> Cc: Brown, Len; linux-acpi@xxxxxxxxxxxxxxx;
linux-kernel@xxxxxxxxxxxxxxx
> Subject: [PATCH -mm 5/6] cpu_relax(): use in ACPI lock
>
>
> Use cpu_relax() in __acpi_acquire_global_lock() etc.
>
>
> This could be considered overkill given the previous unlikely(),
> but it is busy-looping in case of false condition after all...
>
> Tested on 2.6.17-mm1, i386 only (no x86_64 here).
>
> Signed-off-by: Andreas Mohr <andi@xxxxxxxx>
>
>
> diff -urN linux-2.6.17-mm1.orig/include/asm-i386/acpi.h linux-2.6.17-
> mm1.my/include/asm-i386/acpi.h
> --- linux-2.6.17-mm1.orig/include/asm-i386/acpi.h 2006-06-19
> 10:57:27.000000000 +0200
> +++ linux-2.6.17-mm1.my/include/asm-i386/acpi.h 2006-06-21
> 14:43:24.000000000 +0200
> @@ -61,11 +61,14 @@
> __acpi_acquire_global_lock (unsigned int *lock)
> {
> unsigned int old, new, val;
> - do {
> + while (1) {
> old = *lock;
> new = (((old & ~0x3) + 2) + ((old >> 1) & 0x1));
> val = cmpxchg(lock, old, new);
> - } while (unlikely (val != old));
> + if (likely(val == old))
> + break;
> + cpu_relax();
> + }
> return (new < 3) ? -1 : 0;
> }
>
> @@ -73,11 +76,14 @@
> __acpi_release_global_lock (unsigned int *lock)
> {
> unsigned int old, new, val;
> - do {
> + while (1) {
> old = *lock;
> new = old & ~0x3;
> val = cmpxchg(lock, old, new);
> - } while (unlikely (val != old));
> + if (likely(val == old))
> + break;
> + cpu_relax();
> + }
> return old & 0x1;
> }
>
> diff -urN linux-2.6.17-mm1.orig/include/asm-x86_64/acpi.h
linux-2.6.17-
> mm1.my/include/asm-x86_64/acpi.h
> --- linux-2.6.17-mm1.orig/include/asm-x86_64/acpi.h 2006-06-21
> 14:28:19.000000000 +0200
> +++ linux-2.6.17-mm1.my/include/asm-x86_64/acpi.h 2006-06-21
> 14:43:24.000000000 +0200
> @@ -59,11 +59,14 @@
> __acpi_acquire_global_lock (unsigned int *lock)
> {
> unsigned int old, new, val;
> - do {
> + while (1) {
> old = *lock;
> new = (((old & ~0x3) + 2) + ((old >> 1) & 0x1));
> val = cmpxchg(lock, old, new);
> - } while (unlikely (val != old));
> + if (likely(val == old))
> + break;
> + cpu_relax();
> + }
> return (new < 3) ? -1 : 0;
> }
>
> @@ -75,7 +78,10 @@
> old = *lock;
> new = old & ~0x3;
> val = cmpxchg(lock, old, new);
> - } while (unlikely (val != old));
> + if (likely(val == old))
> + break;
> + cpu_relax();
> + }
> return old & 0x1;
> }
>
> -
> To unsubscribe from this list: send the line "unsubscribe linux-acpi"
in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at http://vger.kernel.org/majordomo-info.html
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/