2007-10-16 07:41:44 +08:00
|
|
|
#ifndef _SPARC64_BACKOFF_H
|
|
|
|
#define _SPARC64_BACKOFF_H
|
|
|
|
|
|
|
|
#define BACKOFF_LIMIT (4 * 1024)
|
|
|
|
|
|
|
|
#ifdef CONFIG_SMP
|
|
|
|
|
|
|
|
#define BACKOFF_SETUP(reg) \
|
|
|
|
mov 1, reg
|
|
|
|
|
|
|
|
#define BACKOFF_SPIN(reg, tmp, label) \
|
|
|
|
mov reg, tmp; \
|
|
|
|
88: brnz,pt tmp, 88b; \
|
|
|
|
sub tmp, 1, tmp; \
|
2008-03-19 16:04:48 +08:00
|
|
|
set BACKOFF_LIMIT, tmp; \
|
|
|
|
cmp reg, tmp; \
|
2007-10-16 07:41:44 +08:00
|
|
|
bg,pn %xcc, label; \
|
|
|
|
nop; \
|
|
|
|
ba,pt %xcc, label; \
|
|
|
|
sllx reg, 1, reg;
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define BACKOFF_SETUP(reg)
|
2007-10-27 15:23:22 +08:00
|
|
|
#define BACKOFF_SPIN(reg, tmp, label) \
|
|
|
|
ba,pt %xcc, label; \
|
|
|
|
nop;
|
2007-10-16 07:41:44 +08:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _SPARC64_BACKOFF_H */
|