// RUN: not llvm-mc -triple aarch64-none-linux-gnu -show-encoding -mattr=+v8.4a < %s 2> %t | FileCheck %s --check-prefix=CHECK // RUN: FileCheck --check-prefix=CHECK-RO < %t %s // RUN: not llvm-mc -triple aarch64-none-linux-gnu -show-encoding -mattr=-v8.4a < %s 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR //------------------------------------------------------------------------------ // ARMV8.4-A MPAM Extensions //------------------------------------------------------------------------------ msr MPAM0_EL1, x0 msr MPAM1_EL1, x0 msr MPAM2_EL2, x0 msr MPAM3_EL3, x0 msr MPAM1_EL12, x0 msr MPAMHCR_EL2, x0 msr MPAMVPMV_EL2, x0 msr MPAMVPM0_EL2, x0 msr MPAMVPM1_EL2, x0 msr MPAMVPM2_EL2, x0 msr MPAMVPM3_EL2, x0 msr MPAMVPM4_EL2, x0 msr MPAMVPM5_EL2, x0 msr MPAMVPM6_EL2, x0 msr MPAMVPM7_EL2, x0 msr MPAMIDR_EL1, x0 mrs x0, MPAM0_EL1 mrs x0, MPAM1_EL1 mrs x0, MPAM2_EL2 mrs x0, MPAM3_EL3 mrs x0, MPAM1_EL12 mrs x0, MPAMHCR_EL2 mrs x0, MPAMVPMV_EL2 mrs x0, MPAMVPM0_EL2 mrs x0, MPAMVPM1_EL2 mrs x0, MPAMVPM2_EL2 mrs x0, MPAMVPM3_EL2 mrs x0, MPAMVPM4_EL2 mrs x0, MPAMVPM5_EL2 mrs x0, MPAMVPM6_EL2 mrs x0, MPAMVPM7_EL2 mrs x0, MPAMIDR_EL1 //CHECK: msr MPAM0_EL1, x0 // encoding: [0x20,0xa5,0x18,0xd5] //CHECK: msr MPAM1_EL1, x0 // encoding: [0x00,0xa5,0x18,0xd5] //CHECK: msr MPAM2_EL2, x0 // encoding: [0x00,0xa5,0x1c,0xd5] //CHECK: msr MPAM3_EL3, x0 // encoding: [0x00,0xa5,0x1e,0xd5] //CHECK: msr MPAM1_EL12, x0 // encoding: [0x00,0xa5,0x1d,0xd5] //CHECK: msr MPAMHCR_EL2, x0 // encoding: [0x00,0xa4,0x1c,0xd5] //CHECK: msr MPAMVPMV_EL2, x0 // encoding: [0x20,0xa4,0x1c,0xd5] //CHECK: msr MPAMVPM0_EL2, x0 // encoding: [0x00,0xa6,0x1c,0xd5] //CHECK: msr MPAMVPM1_EL2, x0 // encoding: [0x20,0xa6,0x1c,0xd5] //CHECK: msr MPAMVPM2_EL2, x0 // encoding: [0x40,0xa6,0x1c,0xd5] //CHECK: msr MPAMVPM3_EL2, x0 // encoding: [0x60,0xa6,0x1c,0xd5] //CHECK: msr MPAMVPM4_EL2, x0 // encoding: [0x80,0xa6,0x1c,0xd5] //CHECK: msr MPAMVPM5_EL2, x0 // encoding: [0xa0,0xa6,0x1c,0xd5] //CHECK: msr MPAMVPM6_EL2, x0 // encoding: [0xc0,0xa6,0x1c,0xd5] //CHECK: msr MPAMVPM7_EL2, x0 // encoding: [0xe0,0xa6,0x1c,0xd5] //CHECK-RO: error: expected writable system register or pstate //CHECK-RO: msr MPAMIDR_EL1, x0 //CHECK-RO: ^ //CHECK: mrs x0, MPAM0_EL1 // encoding: [0x20,0xa5,0x38,0xd5] //CHECK: mrs x0, MPAM1_EL1 // encoding: [0x00,0xa5,0x38,0xd5] //CHECK: mrs x0, MPAM2_EL2 // encoding: [0x00,0xa5,0x3c,0xd5] //CHECK: mrs x0, MPAM3_EL3 // encoding: [0x00,0xa5,0x3e,0xd5] //CHECK: mrs x0, MPAM1_EL12 // encoding: [0x00,0xa5,0x3d,0xd5] //CHECK: mrs x0, MPAMHCR_EL2 // encoding: [0x00,0xa4,0x3c,0xd5] //CHECK: mrs x0, MPAMVPMV_EL2 // encoding: [0x20,0xa4,0x3c,0xd5] //CHECK: mrs x0, MPAMVPM0_EL2 // encoding: [0x00,0xa6,0x3c,0xd5] //CHECK: mrs x0, MPAMVPM1_EL2 // encoding: [0x20,0xa6,0x3c,0xd5] //CHECK: mrs x0, MPAMVPM2_EL2 // encoding: [0x40,0xa6,0x3c,0xd5] //CHECK: mrs x0, MPAMVPM3_EL2 // encoding: [0x60,0xa6,0x3c,0xd5] //CHECK: mrs x0, MPAMVPM4_EL2 // encoding: [0x80,0xa6,0x3c,0xd5] //CHECK: mrs x0, MPAMVPM5_EL2 // encoding: [0xa0,0xa6,0x3c,0xd5] //CHECK: mrs x0, MPAMVPM6_EL2 // encoding: [0xc0,0xa6,0x3c,0xd5] //CHECK: mrs x0, MPAMVPM7_EL2 // encoding: [0xe0,0xa6,0x3c,0xd5] //CHECK: mrs x0, MPAMIDR_EL1 // encoding: [0x80,0xa4,0x38,0xd5] //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAM0_EL1, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAM1_EL1, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAM2_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAM3_EL3, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAM1_EL12, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMHCR_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMVPMV_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMVPM0_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMVPM1_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMVPM2_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMVPM3_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMVPM4_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMVPM5_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMVPM6_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMVPM7_EL2, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected writable system register or pstate //CHECK-ERROR: msr MPAMIDR_EL1, x0 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAM0_EL1 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAM1_EL1 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAM2_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAM3_EL3 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAM1_EL12 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMHCR_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMVPMV_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMVPM0_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMVPM1_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMVPM2_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMVPM3_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMVPM4_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMVPM5_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMVPM6_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMVPM7_EL2 //CHECK-ERROR: ^ //CHECK-ERROR: error: expected readable system register //CHECK-ERROR: mrs x0, MPAMIDR_EL1 //CHECK-ERROR: ^