diff options
author | Ingo Molnar <mingo@elte.hu> | 2008-07-31 12:34:22 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-07-31 12:34:22 -0400 |
commit | 6679ce6e5f519096612b480d255d9ca97be0c2be (patch) | |
tree | cce6814d3e7c62adf59e565fb6ae95fd409f86ab /arch/sparc/include/asm/backoff.h | |
parent | 2c3d103ba90827cfb478bf10464d9b5b9cea369c (diff) | |
parent | 6e86841d05f371b5b9b86ce76c02aaee83352298 (diff) |
Merge branch 'linus' into sched/urgent
Diffstat (limited to 'arch/sparc/include/asm/backoff.h')
-rw-r--r-- | arch/sparc/include/asm/backoff.h | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/arch/sparc/include/asm/backoff.h b/arch/sparc/include/asm/backoff.h new file mode 100644 index 000000000000..fa1fdf67e350 --- /dev/null +++ b/arch/sparc/include/asm/backoff.h | |||
@@ -0,0 +1,31 @@ | |||
1 | #ifndef _SPARC64_BACKOFF_H | ||
2 | #define _SPARC64_BACKOFF_H | ||
3 | |||
4 | #define BACKOFF_LIMIT (4 * 1024) | ||
5 | |||
6 | #ifdef CONFIG_SMP | ||
7 | |||
8 | #define BACKOFF_SETUP(reg) \ | ||
9 | mov 1, reg | ||
10 | |||
11 | #define BACKOFF_SPIN(reg, tmp, label) \ | ||
12 | mov reg, tmp; \ | ||
13 | 88: brnz,pt tmp, 88b; \ | ||
14 | sub tmp, 1, tmp; \ | ||
15 | set BACKOFF_LIMIT, tmp; \ | ||
16 | cmp reg, tmp; \ | ||
17 | bg,pn %xcc, label; \ | ||
18 | nop; \ | ||
19 | ba,pt %xcc, label; \ | ||
20 | sllx reg, 1, reg; | ||
21 | |||
22 | #else | ||
23 | |||
24 | #define BACKOFF_SETUP(reg) | ||
25 | #define BACKOFF_SPIN(reg, tmp, label) \ | ||
26 | ba,pt %xcc, label; \ | ||
27 | nop; | ||
28 | |||
29 | #endif | ||
30 | |||
31 | #endif /* _SPARC64_BACKOFF_H */ | ||