diff options
author | Vineet Gupta <vgupta@synopsys.com> | 2016-05-31 07:01:33 -0400 |
---|---|---|
committer | Vineet Gupta <vgupta@synopsys.com> | 2016-06-02 01:29:22 -0400 |
commit | 42316a201a60be38b07db1ebc3a1633107ed7209 (patch) | |
tree | abca1d4d5af079242c755149bc1411d3971f926c | |
parent | d140b9bfcad9e53f1da67ad09dd5092b44d55c7b (diff) |
Revert "ARCv2: spinlock/rwlock/atomics: reduce 1 instruction in exponential backoff"
This reverts commit 10971638701dedadb58c88ce4d31c9375b224ed6.
The issue was fixed in hardware in HS2.1C release and there are no known
external users of affected RTL - so revert thw whole delayed retry
series !
Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
-rw-r--r-- | arch/arc/include/asm/atomic.h | 3 | ||||
-rw-r--r-- | arch/arc/include/asm/spinlock.h | 3 |
2 files changed, 4 insertions, 2 deletions
diff --git a/arch/arc/include/asm/atomic.h b/arch/arc/include/asm/atomic.h index 5f3dcbbc0cc9..75c8226317f4 100644 --- a/arch/arc/include/asm/atomic.h +++ b/arch/arc/include/asm/atomic.h | |||
@@ -36,7 +36,8 @@ | |||
36 | " mov %[tmp], %[delay] \n" /* tmp = delay */ \ | 36 | " mov %[tmp], %[delay] \n" /* tmp = delay */ \ |
37 | "2: brne.d %[tmp], 0, 2b \n" /* while (tmp != 0) */ \ | 37 | "2: brne.d %[tmp], 0, 2b \n" /* while (tmp != 0) */ \ |
38 | " sub %[tmp], %[tmp], 1 \n" /* tmp-- */ \ | 38 | " sub %[tmp], %[tmp], 1 \n" /* tmp-- */ \ |
39 | " rol %[delay], %[delay] \n" /* delay *= 2 */ \ | 39 | " asl.f %[delay], %[delay], 1 \n" /* delay *= 2 */ \ |
40 | " mov.z %[delay], 1 \n" /* handle overflow */ \ | ||
40 | " b 1b \n" /* start over */ \ | 41 | " b 1b \n" /* start over */ \ |
41 | "4: ; --- success --- \n" \ | 42 | "4: ; --- success --- \n" \ |
42 | 43 | ||
diff --git a/arch/arc/include/asm/spinlock.h b/arch/arc/include/asm/spinlock.h index 800e7c430ca5..a86cb84fad2a 100644 --- a/arch/arc/include/asm/spinlock.h +++ b/arch/arc/include/asm/spinlock.h | |||
@@ -260,7 +260,8 @@ static inline void arch_write_unlock(arch_rwlock_t *rw) | |||
260 | " mov %[tmp], %[delay] \n" /* tmp = delay */ \ | 260 | " mov %[tmp], %[delay] \n" /* tmp = delay */ \ |
261 | "2: brne.d %[tmp], 0, 2b \n" /* while (tmp != 0) */ \ | 261 | "2: brne.d %[tmp], 0, 2b \n" /* while (tmp != 0) */ \ |
262 | " sub %[tmp], %[tmp], 1 \n" /* tmp-- */ \ | 262 | " sub %[tmp], %[tmp], 1 \n" /* tmp-- */ \ |
263 | " rol %[delay], %[delay] \n" /* delay *= 2 */ \ | 263 | " asl.f %[delay], %[delay], 1 \n" /* delay *= 2 */ \ |
264 | " mov.z %[delay], 1 \n" /* handle overflow */ \ | ||
264 | " b 1b \n" /* start over */ \ | 265 | " b 1b \n" /* start over */ \ |
265 | " \n" \ | 266 | " \n" \ |
266 | "4: ; --- done --- \n" \ | 267 | "4: ; --- done --- \n" \ |