aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/aes32esi.h
blob: d0c0a63baa576cd5a4ba005af102eeff840f7ad9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

#include "aes_common.h"

require_rv32;
require_extension(EXT_ZKNE);

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));

WRITE_RD(sext_xlen(u ^ RS1));