aboutsummaryrefslogtreecommitdiff
path: root/src/cpu/atomic/swap.a.h
diff options
context:
space:
mode:
authorChristian Cunningham <cc@localhost>2021-12-21 19:37:52 -0800
committerChristian Cunningham <cc@localhost>2021-12-21 19:37:52 -0800
commit8e52f3ff03eeaac35a9d7a792cdedff6a92434b4 (patch)
tree2519fee43cf68146b462a0968eabe45e82eb06ef /src/cpu/atomic/swap.a.h
parentcf2618101ef832a9652d84b43ed5f558da401248 (diff)
Move .a.h to .h
Diffstat (limited to 'src/cpu/atomic/swap.a.h')
-rw-r--r--src/cpu/atomic/swap.a.h36
1 files changed, 0 insertions, 36 deletions
diff --git a/src/cpu/atomic/swap.a.h b/src/cpu/atomic/swap.a.h
deleted file mode 100644
index 5e8ff57..0000000
--- a/src/cpu/atomic/swap.a.h
+++ /dev/null
@@ -1,36 +0,0 @@
-#ifndef CPU_ATOMIC_SWAP_A_H
-#define CPU_ATOMIC_SWAP_A_H
-#include "../../util/mutex.h"
-
-/// https://stackoverflow.com/questions/16329123/use-of-strexeq-instead-of-strex-for-spinlock-implementation-in-arm
-/// https://elixir.bootlin.com/linux/v4.9/source/arch/arm/include/asm/spinlock.h
-/// https://elixir.bootlin.com/linux/v4.9/source/arch/arm/include/asm/spinlock_types.h#L23
-/// https://www.cs.uic.edu/~jbell/CourseNotes/OperatingSystems/3_Processes.html
-
-static inline void atm_lock(unsigned long pid, unsigned long* addr) {
- unsigned long tmp, current_lock_value;
- asm volatile(
-"1: ldrex %0, [%3]\n"
-" cmp %0, #0\n"
-" wfene\n"
-" strexeq %1, %2, [%3]\n"
-" teq %1, #0\n"
-" bne 1b\n"
-" dmb"
- : "=&r" (current_lock_value), "=&r" (tmp)
- : "r" (pid), "r" (addr)
- : "cc");
-}
-
-static inline void atm_release(unsigned long* addr) {
- unsigned long cleared = NULL_PID;
- asm volatile(
-" dmb\n"
-" str %0, [%1]\n"
-" dsb\n"
-" sev"
- :: "r" (cleared), "r" (addr)
- : "cc");
-}
-
-#endif