diff options
author | David Monniaux <david.monniaux@univ-grenoble-alpes.fr> | 2020-03-03 08:17:40 +0100 |
---|---|---|
committer | David Monniaux <david.monniaux@univ-grenoble-alpes.fr> | 2020-03-03 08:17:40 +0100 |
commit | 1ab7b51c30e1b10ac45b0bd64cefdc01da0f7f68 (patch) | |
tree | 210ffc156c83f04fb0c61a40b4f9037d7ba8a7e1 /test/monniaux/nand | |
parent | 222c9047d61961db9c6b19fed5ca49829223fd33 (diff) | |
parent | 12be46d59a2483a10d77fa8ee67f7e0ca1bd702f (diff) | |
download | compcert-kvx-1ab7b51c30e1b10ac45b0bd64cefdc01da0f7f68.tar.gz compcert-kvx-1ab7b51c30e1b10ac45b0bd64cefdc01da0f7f68.zip |
Merge branch 'mppa-cse2' of gricad-gitlab.univ-grenoble-alpes.fr:sixcy/CompCert into mppa-work
Diffstat (limited to 'test/monniaux/nand')
-rw-r--r-- | test/monniaux/nand/nand.c | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/test/monniaux/nand/nand.c b/test/monniaux/nand/nand.c new file mode 100644 index 00000000..e628c1cf --- /dev/null +++ b/test/monniaux/nand/nand.c @@ -0,0 +1,48 @@ +#include <stdio.h> + +typedef unsigned long scalar; + +scalar not(scalar x) { + return ~x; +} + +scalar nand(scalar x, scalar y) { + return ~(x & y); +} + +scalar nor(scalar x, scalar y) { + return ~(x | y); +} + +scalar nxor(scalar x, scalar y) { + return ~(x ^ y); +} + +scalar andn1(scalar x, scalar y) { + return ~x & y; +} + +scalar andn2(scalar x, scalar y) { + return x & ~y; +} + +scalar orn1(scalar x, scalar y) { + return ~x | y; +} + +scalar orn2(scalar x, scalar y) { + return x | ~y; +} + +scalar nandimm(scalar x) { + return ~x & 45; +} + +scalar notnot(scalar x) { + return ~ ~ x; +} + +int main() { + scalar x = 0xF4, y = 0x33; + printf("%X\n", nxor(x, y)); +} |