diff options
| author | iximeow <me@iximeow.net> | 2025-10-19 20:50:09 +0000 | 
|---|---|---|
| committer | iximeow <me@iximeow.net> | 2025-10-19 23:29:05 +0000 | 
| commit | 153b5b3383d016a8a1440b2b932815efed25f847 (patch) | |
| tree | dd861216ad571e479b74a8bb48cab0c35c091592 /src/armv8 | |
| parent | d1fefcc4461363b30f69b3cab386254c77de08e0 (diff) | |
tag instruction decode fixes, differential test precision
Diffstat (limited to 'src/armv8')
| -rw-r--r-- | src/armv8/a64.rs | 20 | 
1 files changed, 19 insertions, 1 deletions
| diff --git a/src/armv8/a64.rs b/src/armv8/a64.rs index 56d9ef2..8775d77 100644 --- a/src/armv8/a64.rs +++ b/src/armv8/a64.rs @@ -1263,7 +1263,10 @@ pub enum Opcode {      DSB(u8),      DMB(u8),      SB, +    #[deprecated(since = "0.4.0", note = "i spelled `ssbb` incorrectly.")]      SSSB, +    PSSBB, +    SSBB,      HINT,      CLREX,      CSEL, @@ -1867,6 +1870,10 @@ impl Display for Opcode {              Opcode::MRS => "mrs",              Opcode::ISB => "isb",              Opcode::SB => "sb", +            Opcode::SSBB => "ssbb", +            Opcode::PSSBB => "pssbb", +            // this arm should never, never, never be hit +            #[allow(deprecated)]              Opcode::SSSB => "sssb",              Opcode::CLREX => "clrex",              Opcode::CSEL => "csel", @@ -8669,6 +8676,9 @@ impl Decoder<ARMv8> for InstDecoder {                              let Rt = ((word >> 0) & 0b11111) as u16;                              let simm = (((imm9 as i16) << 7) >> 7) as i32; +                            // tag granularity is 16 bytes, so tags are encoded with the low four +                            // (`LOG2_TAG_GRANULE `) zeroes shifted out for all tag instructions. +                            let simm = simm << 4;                              let opcode = &[                                  Opcode::STZGM, Opcode::STG, Opcode::STG, Opcode::STG, @@ -10597,7 +10607,15 @@ impl Decoder<ARMv8> for InstDecoder {                                                      },                                                      0b100 => {                                                          if CRm == 0b0000 { -                                                            inst.opcode = Opcode::SSSB; +                                                            inst.opcode = Opcode::SSBB; +                                                            inst.operands = [ +                                                                Operand::Nothing, +                                                                Operand::Nothing, +                                                                Operand::Nothing, +                                                                Operand::Nothing, +                                                            ]; +                                                        } else if CRm == 0b0100 { +                                                            inst.opcode = Opcode::PSSBB;                                                              inst.operands = [                                                                  Operand::Nothing,                                                                  Operand::Nothing, | 
