summaryrefslogtreecommitdiff
path: root/demo/mem.c
diff options
context:
space:
mode:
authorAlejandro Soto <alejandro@34project.org>2023-10-06 07:37:16 -0600
committerAlejandro Soto <alejandro@34project.org>2023-10-06 07:37:16 -0600
commit39fd8b8428da1e4bb0a182e1bcc61ec2d54563a4 (patch)
treea4dedd73b8fbfdfbfd1c2ca8c1a4c4a983fd9e26 /demo/mem.c
parentfac14c8c03592f101d34116cb8ecde908e92c18b (diff)
demo: implement remote cmds
Diffstat (limited to '')
-rw-r--r--demo/mem.c31
1 files changed, 31 insertions, 0 deletions
diff --git a/demo/mem.c b/demo/mem.c
new file mode 100644
index 0000000..2551385
--- /dev/null
+++ b/demo/mem.c
@@ -0,0 +1,31 @@
+#include "demo.h"
+
+void do_read(void *ptr)
+{
+ print("%p -> %x", ptr, *(volatile unsigned *)ptr);
+}
+
+void do_write(void *ptr, unsigned val)
+{
+ *(volatile unsigned *)ptr = val;
+ print("%p <- %x", ptr, val);
+}
+
+void remote_send(unsigned cpu, void *ptr, int write, unsigned val)
+{
+ unsigned long ptr_val = (unsigned)ptr & ~0b11;
+ unsigned long long send_word = ((unsigned long long)ptr_val | (write & 1) << 1 | 1) << 32 | val;
+
+ unsigned long long current = all_cpus[cpu].mailbox;
+ while (!compare_exchange_64(&all_cpus[cpu].mailbox, &current, send_word));
+}
+
+void remote_recv(void **ptr, int *write, unsigned *val)
+{
+ unsigned long long current = this_cpu->mailbox;
+ while (!compare_exchange_64(&this_cpu->mailbox, &current, 0) || !current);
+
+ *val = (unsigned long)current;
+ *ptr = (void *)((unsigned)((current >> 32) & ~0b11));
+ *write = (current >> 33) & 1;
+}