aboutsummaryrefslogtreecommitdiffstats
path: root/runtime
diff options
context:
space:
mode:
authorDavid Monniaux <david.monniaux@univ-grenoble-alpes.fr>2019-04-11 17:19:42 +0200
committerDavid Monniaux <david.monniaux@univ-grenoble-alpes.fr>2019-04-11 17:19:42 +0200
commitb782b7fda32a910ca0f011f99c5b2864eaeb3e55 (patch)
tree4582c36a7525629cf4a9d50b88be1436c98fdb9c /runtime
parentbaeed85dd8d1c7ef54a72bf2db2381d03de05cb6 (diff)
downloadcompcert-kvx-b782b7fda32a910ca0f011f99c5b2864eaeb3e55.tar.gz
compcert-kvx-b782b7fda32a910ca0f011f99c5b2864eaeb3e55.zip
__builtin_k1_acswapw
Diffstat (limited to 'runtime')
-rw-r--r--runtime/include/ccomp_k1c_fixes.h6
-rw-r--r--runtime/mppa_k1c/vararg.S7
2 files changed, 12 insertions, 1 deletions
diff --git a/runtime/include/ccomp_k1c_fixes.h b/runtime/include/ccomp_k1c_fixes.h
index b42323b8..9a2a26c1 100644
--- a/runtime/include/ccomp_k1c_fixes.h
+++ b/runtime/include/ccomp_k1c_fixes.h
@@ -11,6 +11,10 @@
struct __int128_ccomp { long __int128_ccomp_low; long __int128_ccomp_high; };
#define __int128 struct __int128_ccomp
+
#define __builtin_k1_acswapd __compcert_acswapd
-extern __int128 __compcert_acswapd(unsigned long long *address, unsigned long long new_value, unsigned long long old_value);
+extern __int128 __compcert_acswapd(void *address, unsigned long long new_value, unsigned long long old_value);
+
+#define __builtin_k1_acswapw __compcert_acswapw
+extern __int128 __compcert_acswapw(void *address, unsigned long long new_value, unsigned long long old_value);
#endif
diff --git a/runtime/mppa_k1c/vararg.S b/runtime/mppa_k1c/vararg.S
index dbd7b96d..0c96b2ff 100644
--- a/runtime/mppa_k1c/vararg.S
+++ b/runtime/mppa_k1c/vararg.S
@@ -84,3 +84,10 @@ __compcert_acswapd:
sq 0[$r0] = $r2r3
ret
;;
+ .globl __compcert_acswapw
+__compcert_acswapw:
+ acswapw 0[$r1] = $r2r3
+ ;;
+ sq 0[$r0] = $r2r3
+ ret
+ ;;