1 <!-- SVP64 Butterfly DCT Instructions here described are based on -->
3 <!-- PLEASE NOTE THESE ARE UNAPPROVED AND DRAFT, NOT SUBMITTED TO OPF ISA WG -->
5 # [DRAFT] Integer Butterfly Multiply Add/Sub FFT/DCT
9 * maddsubrs RT,RA,SH,RB
16 prod1 <- MULS(RB, sum)[XLEN:(XLEN*2)-1]
17 prod2 <- MULS(RB, diff)[XLEN:(XLEN*2)-1]
19 #round <- EXTS([0]*(XLEN-1) || [1]*1)
20 #prod1 <- ROTL64(prod1, 1)
21 #prod2 <- ROTL64(prod2, 1)
22 #prod1 <- prod1 + round
23 #prod2 <- prod2 + round
24 #res1 <- ROTL64(prod1, XLEN-1)
25 #res2 <- ROTL64(prod2, XLEN-1)
26 #m <- MASK(1, (XLEN-1))
30 round <- EXTS([0]*(XLEN -n -1) || [1]*1 || [0]*(n-1))
31 prod1 <- prod1 + round
32 prod2 <- prod2 + round
33 res1 <- ROTL64(prod1, XLEN-n)
34 res2 <- ROTL64(prod2, XLEN-n)
35 m <- MASK(n, (XLEN-1))
38 smask1 <- ([signbit1]*XLEN) & ¬m
39 smask2 <- ([signbit2]*XLEN) & ¬m
40 RT <- (res1 & m | smask1)
41 RS <- (res2 & m | smask2)
43 Special Registers Altered: