summaryrefslogtreecommitdiff
path: root/arm/PrintAsm.ml
diff options
context:
space:
mode:
Diffstat (limited to 'arm/PrintAsm.ml')
-rw-r--r--arm/PrintAsm.ml20
1 files changed, 20 insertions, 0 deletions
diff --git a/arm/PrintAsm.ml b/arm/PrintAsm.ml
index 530a8f7..7ae4508 100644
--- a/arm/PrintAsm.ml
+++ b/arm/PrintAsm.ml
@@ -592,10 +592,30 @@ let print_builtin_inline oc name args res =
(* Synchronization *)
| "__builtin_membar", [], _ ->
0
+ | "__builtin_dmb", [], _ ->
+ fprintf oc " dmb\n"; 1
| "__builtin_dsb", [], _ ->
fprintf oc " dsb\n"; 1
| "__builtin_isb", [], _ ->
fprintf oc " isb\n"; 1
+ | "__builtin_ldrex", [IR addr], [IR dst] ->
+ fprintf oc " ldrex %a, [%a]\n" dst addr
+ | "__builtin_ldrexb", [IR addr], [IR dst] ->
+ fprintf oc " ldrexb %a, [%a]\n" dst addr
+ | "__builtin_ldrexd", [IR addr], [IR dsth; IR dstl] ->
+ fprintf oc " ldrexd %a, %a, [%a]\n" dstl dsth addr
+ | "__builtin_ldrexh", [IR addr], [IR dst] ->
+ fprintf oc " ldrexh %a, [%a]\n" dst addr
+ | "__builtin_strex", [IR addr; IR src], [IR res] ->
+ fprintf oc " strex %a, %a, [%a]\n" res src addr; 1
+ | "__builtin_strexb", [IR addr; IR src], [IR res] ->
+ fprintf oc " strexb %a, %a, [%a]\n" res src addr; 1
+ | "__builtin_strexd", [IR addr; IR srch; IR srcl], [IR res] ->
+ fprintf oc " strexd %a, %a, %a, [%a]\n" res srcl srch addr; 1
+ | "__builtin_strexh", [IR addr; IR src], [IR res] ->
+ fprintf oc " strexh %a, %a, [%a]\n" res src addr; 1
+
+
(* Vararg stuff *)
| "__builtin_va_start", [IR a], _ ->
print_builtin_va_start oc a