30 lines
975 B
Diff
30 lines
975 B
Diff
|
# Commit f9cc3cd9b4de58cf032c8624406384c172937e57
|
||
|
# Date 2015-05-08 10:59:44 +0200
|
||
|
# Author David Vrabel <david.vrabel@citrix.com>
|
||
|
# Committer Jan Beulich <jbeulich@suse.com>
|
||
|
arm: provide arch_fetch_and_add()
|
||
|
|
||
|
arch_fetch_and_add() atomically adds a value and returns the previous
|
||
|
value.
|
||
|
|
||
|
This generic arm implementation uses the GCC __sync_fetch_and_add()
|
||
|
builtin. This builtin resulted in suitable inlined asm for GCC 4.8.3
|
||
|
(arm64) and GCC 4.6.3 (arm32).
|
||
|
|
||
|
This is needed to implement ticket locks.
|
||
|
|
||
|
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
|
||
|
Acked-by: Ian Campbell <ian.campbell@citrix.com>
|
||
|
|
||
|
--- sle12sp1.orig/xen/include/asm-arm/system.h 2015-01-14 18:44:18.000000000 +0100
|
||
|
+++ sle12sp1/xen/include/asm-arm/system.h 2015-07-08 12:35:16.000000000 +0200
|
||
|
@@ -51,6 +51,8 @@
|
||
|
# error "unknown ARM variant"
|
||
|
#endif
|
||
|
|
||
|
+#define arch_fetch_and_add(x, v) __sync_fetch_and_add(x, v)
|
||
|
+
|
||
|
extern struct vcpu *__context_switch(struct vcpu *prev, struct vcpu *next);
|
||
|
|
||
|
#endif
|