aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/aes32esi.h
diff options
context:
space:
mode:
Diffstat (limited to 'riscv/insns/aes32esi.h')
-rw-r--r--riscv/insns/aes32esi.h18
1 files changed, 18 insertions, 0 deletions
diff --git a/riscv/insns/aes32esi.h b/riscv/insns/aes32esi.h
new file mode 100644
index 0000000..e24124d
--- /dev/null
+++ b/riscv/insns/aes32esi.h
@@ -0,0 +1,18 @@
+
+#include "aes_common.h"
+
+require_rv32;
+require_extension('K');
+require(RD == 0); // Additional decoding required for RV32
+
+uint8_t bs = insn.bs();
+
+uint8_t t0 = RS2 >> (8*bs);
+uint8_t x = AES_ENC_SBOX[t0];
+uint32_t u = x;
+
+u = (u << (8*bs)) | (u >> (32-8*bs));
+
+uint64_t rd = insn.rs1(); // RD sourced from RS1 field.
+WRITE_REG(rd, u ^ RS1);
+