From 29159d5b5de93b8a56ad195bc1b618e9584f2ec2 Mon Sep 17 00:00:00 2001 From: Luke Kenneth Casson Leighton Date: Fri, 27 Oct 2023 10:50:13 +0100 Subject: [PATCH] add copy of pifixedstore.mdwn renamed to pifixedstoreshift.mdwn modifications required to add "shifting" --- openpower/isa/pifixedstoreshift.mdwn | 225 +++++++++++++++++++++++++++ 1 file changed, 225 insertions(+) create mode 100644 openpower/isa/pifixedstoreshift.mdwn diff --git a/openpower/isa/pifixedstoreshift.mdwn b/openpower/isa/pifixedstoreshift.mdwn new file mode 100644 index 00000000..dfccc495 --- /dev/null +++ b/openpower/isa/pifixedstoreshift.mdwn @@ -0,0 +1,225 @@ + + + + + +# Store Byte with Post-Update + +D-Form + +* stbup RS,D(RA) + +Pseudo-code: + + EA <- (RA) + EXTS(D) + ea <- (RA) + MEM(ea, 1) <- (RS)[XLEN-8:XLEN-1] + RA <- EA + +Description: + + Let the effective address (EA) be the sum (RA)+ D. + + (RS)[56:63] are stored into the byte in storage addressed + by RA. + + EA is placed into register RA. + + If RA=0, the instruction form is invalid. + +Special Registers Altered: + + None + +# Store Byte with Post-Update Indexed + +X-Form + +* stbupx RS,RA,RB + +Pseudo-code: + + EA <- (RA) + (RB) + ea <- (RA) + MEM(ea, 1) <- (RS)[XLEN-8:XLEN-1] + RA <- EA + +Description: + + Let the effective address (EA) be the sum (RA)+ (RB). + + (RS)[56:63] are stored into the byte in storage addressed + by EA. + + EA is placed into register RA. + + If RA=0, the instruction form is invalid. + +Special Registers Altered: + + None + +# Store Halfword with Post-Update + +D-Form + +* sthup RS,D(RA) + +Pseudo-code: + + EA <- (RA) + EXTS(D) + ea <- (RA) + MEM(ea, 2) <- (RS)[XLEN-16:XLEN-1] + RA <- EA + +Description: + + Let the effective address (EA) be the sum (RA|0)+ D. + + (RS)[48:63] are stored into the halfword in storage + addressed by EA. + +Special Registers Altered: + + None + +# Store Halfword with Post-Update Indexed + +X-Form + +* sthupx RS,RA,RB + +Pseudo-code: + + EA <- (RA) + (RB) + ea <- (RA) + MEM(ea, 2) <- (RS)[XLEN-16:XLEN-1] + RA <- EA + +Description: + + Let the effective address (EA) be the sum (RA)+ (RB). + + (RS)[56:63] are stored into the byte in storage addressed + by EA. + + EA is placed into register RA. + + If RA=0, the instruction form is invalid + +Special Registers Altered: + + None + +# Store Word with Post-Update + +D-Form + +* stwup RS,D(RA) + +Pseudo-code: + + EA <- (RA) + EXTS(D) + ea <- (RA) + MEM(ea, 4) <- (RS)[XLEN-32:XLEN-1] + RA <- EA + +Description: + + Let the effective address (EA) be the sum (RA)+ D. + + (RS)[32:63] are stored into the word in storage addressed + by EA. + + EA is placed into register RA. + + If RA=0, the instruction form is invalid. + +Special Registers Altered: + + None + +# Store Word with Post-Update Indexed + +X-Form + +* stwupx RS,RA,RB + +Pseudo-code: + + EA <- (RA) + (RB) + ea <- (RA) + MEM(ea, 4) <- (RS)[XLEN-32:XLEN-1] + RA <- EA + +Description: + + Let the effective address (EA) be the sum (RA)+ (RB). + + (RS)[32:63] are stored into the word in storage addressed + by RA. + + EA is placed into register RA. + + If RA=0, the instruction form is invalid. + +Special Registers Altered: + + None + +# Store Doubleword with Post-Update + +DS-Form + +* stdup RS,DS(RA) + +Pseudo-code: + + EA <- (RA) + EXTS(DS || 0b00) + ea <- (RA) + MEM(ea, 8) <- (RS) + RA <- EA + +Description: + + Let the effective address (EA) be the sum. + + (RA)+ (DS||0b00). (RS) is stored into the doubleword in + storage addressed by RA. + + EA is placed into register RA. + + If RA=0, the instruction form is invalid. + +Special Registers Altered: + + None + +# Store Doubleword with Post-Update Indexed + +X-Form + +* stdupx RS,RA,RB + +Pseudo-code: + + EA <- (RA) + (RB) + ea <- (RA) + MEM(ea, 8) <- (RS) + RA <- EA + +Description: + + Let the effective address (EA) be the sum (RA)+ (RB). + + (RS) is stored into the doubleword in storage + addressed by RA. + + EA is placed into register RA. + + If RA=0, the instruction form is invalid. + +Special Registers Altered: + + None + -- 2.30.2