2015-07-10 15:21:29 +00:00
|
|
|
# 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>
|
|
|
|
|
2015-08-26 22:28:15 +00:00
|
|
|
--- a/xen/include/asm-arm/system.h
|
|
|
|
+++ b/xen/include/asm-arm/system.h
|
2015-07-10 15:21:29 +00:00
|
|
|
@@ -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
|