From 22a631b2a0bd17e87e72c9bd94b7d4dfe25e747c Mon Sep 17 00:00:00 2001 From: Luke Kenneth Casson Leighton Date: Fri, 24 Jun 2022 15:51:02 +0100 Subject: [PATCH] invert mode-bits in bmask bm field --- openpower/isa/av.mdwn | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/openpower/isa/av.mdwn b/openpower/isa/av.mdwn index 862c26ec..e0b2fb6b 100644 --- a/openpower/isa/av.mdwn +++ b/openpower/isa/av.mdwn @@ -180,9 +180,10 @@ Pseudo-code: if _RB = 0 then mask <- [1] * XLEN else mask <- (RB) - a1 <- (RA) & mask - if bm[0] then a1 <- ¬ra - mode2 <- bm[1:2] + ra <- (RA) & mask + a1 <- ra + if bm[4] = 0 then a1 <- ¬ra + mode2 <- bm[2:3] if mode2 = 0 then a2 <- (¬ra)+1 if mode2 = 1 then a2 <- ra-1 if mode2 = 2 then a2 <- ra+1 @@ -190,7 +191,7 @@ Pseudo-code: a1 <- a1 & mask a2 <- a2 & mask # select operator - mode3 <- bm[3:4] + mode3 <- bm[0:1] if mode3 = 0 then result <- a1 | a2 if mode3 = 1 then result <- a1 & a2 if mode3 = 2 then result <- a1 ^ a2 -- 2.30.2