summaryrefslogtreecommitdiff
path: root/aarch64/kusswurm_ch11.S
diff options
context:
space:
mode:
authorHunter Kvalevog <hunter@kvog.sh>2026-06-09 20:17:36 -0500
committerHunter Kvalevog <hunter@kvog.sh>2026-06-09 20:17:36 -0500
commitaf04560da6f41a0e8e8f00bb4b5eba1127caecef (patch)
tree817469ca35c2377d5d070500e3c07d6ec4f78efe /aarch64/kusswurm_ch11.S
parentbbccc1a4879a828c963f1dd3de91d20281024599 (diff)
Diffstat (limited to 'aarch64/kusswurm_ch11.S')
-rw-r--r--aarch64/kusswurm_ch11.S65
1 files changed, 65 insertions, 0 deletions
diff --git a/aarch64/kusswurm_ch11.S b/aarch64/kusswurm_ch11.S
new file mode 100644
index 0000000..0407e92
--- /dev/null
+++ b/aarch64/kusswurm_ch11.S
@@ -0,0 +1,65 @@
+// ================================================================================================
+// Code written while reading chapter 11 of Modern Arm Assembly Language Programming
+//
+// License:
+// SPDX-License-Identifier: 0BSD
+// Copyright (c) 2026 Hunter Kvalevog
+//
+// Permission to use, copy, modify, and/or distribute this software for any
+// purpose with or without fee is hereby granted.
+//
+// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+// WITH REGARD TO THIS SOFTWARE.
+// ================================================================================================
+
+#include "common.S"
+
+TEXT_SEGMENT
+
+// example 1
+
+.global SYM(i32_add_sub)
+.global SYM(i64_add_sub)
+
+SYM(i32_add_sub):
+ // w0: a
+ // w1: b
+ // w2: c
+#if 0
+ add w3, w0, w1
+ sub w0, w3, w2
+#else
+ add w0, w0, w1
+ sub w0, w0, w2
+#endif
+ // w0: return
+ ret
+
+SYM(i64_add_sub):
+ // x0: a
+ // x1: b
+ // x2: c
+ add x3, x0, x1
+ sub x0, x3, x2
+ // x0: return
+ ret
+
+// example 2
+
+.global SYM(i32_mul)
+.global SYM(i32_mul_safe)
+
+SYM(i32_mul):
+ // w0: a
+ // w1: b
+ mul w0, w0, w1
+ // w0: return
+ ret
+
+SYM(i32_mul_safe):
+ // w0: a
+ // w1: b
+ smull x0, w0, w1
+ // x0: ret
+ ret
+