diff options
| author | Hunter Kvalevog <hunter@kvog.sh> | 2026-06-09 20:17:36 -0500 |
|---|---|---|
| committer | Hunter Kvalevog <hunter@kvog.sh> | 2026-06-09 20:17:36 -0500 |
| commit | af04560da6f41a0e8e8f00bb4b5eba1127caecef (patch) | |
| tree | 817469ca35c2377d5d070500e3c07d6ec4f78efe /aarch64/kusswurm_ch11.S | |
| parent | bbccc1a4879a828c963f1dd3de91d20281024599 (diff) | |
Diffstat (limited to 'aarch64/kusswurm_ch11.S')
| -rw-r--r-- | aarch64/kusswurm_ch11.S | 65 |
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 + |