From b75f59eeee0e8b73a7116fd49f08810e7d4382fe Mon Sep 17 00:00:00 2001 From: David Monniaux Date: Sun, 7 Apr 2019 09:39:16 +0200 Subject: predicated experiments --- test/monniaux/predicated/predicated.s | 13 +++++++++++++ test/monniaux/predicated/predicated_run.c | 16 ++++++++++++++++ 2 files changed, 29 insertions(+) create mode 100644 test/monniaux/predicated/predicated.s create mode 100644 test/monniaux/predicated/predicated_run.c (limited to 'test/monniaux/predicated') diff --git a/test/monniaux/predicated/predicated.s b/test/monniaux/predicated/predicated.s new file mode 100644 index 00000000..f11606c2 --- /dev/null +++ b/test/monniaux/predicated/predicated.s @@ -0,0 +1,13 @@ + .text + + .globl predicated_write +predicated_write: + sd.wnez $r0? 8[$r1] = $r2 + ret + ;; + + .globl predicated_read +predicated_read: + ld.wnez $r1? $r0 = 8[$r2] + ret + ;; diff --git a/test/monniaux/predicated/predicated_run.c b/test/monniaux/predicated/predicated_run.c new file mode 100644 index 00000000..2a15318b --- /dev/null +++ b/test/monniaux/predicated/predicated_run.c @@ -0,0 +1,16 @@ +#include + +extern void predicated_write(int flag, long *buf, long data); +extern long predicated_read(long defval, int flag, long *buf); + +int main() { + long buf[2] = {42, 69}; + printf("%ld\n", buf[1]); + predicated_write(0, buf, 33); + printf("%ld\n", buf[1]); + predicated_write(1, buf, 45); + printf("%ld\n", buf[1]); + printf("%ld\n", predicated_read(1515, 0, buf)); + printf("%ld\n", predicated_read(1789, 1, buf)); + return 0; +} -- cgit From a114da2cc9f6caca4824582eea75ec91b8439cc7 Mon Sep 17 00:00:00 2001 From: David Monniaux Date: Wed, 28 Aug 2019 22:51:21 +0200 Subject: merge upstream including fma fixes --- test/monniaux/predicated/predicated.s | 13 ------------- 1 file changed, 13 deletions(-) delete mode 100644 test/monniaux/predicated/predicated.s (limited to 'test/monniaux/predicated') diff --git a/test/monniaux/predicated/predicated.s b/test/monniaux/predicated/predicated.s deleted file mode 100644 index f11606c2..00000000 --- a/test/monniaux/predicated/predicated.s +++ /dev/null @@ -1,13 +0,0 @@ - .text - - .globl predicated_write -predicated_write: - sd.wnez $r0? 8[$r1] = $r2 - ret - ;; - - .globl predicated_read -predicated_read: - ld.wnez $r1? $r0 = 8[$r2] - ret - ;; -- cgit