2015-03-31 20:58:17 +08:00
|
|
|
# For zEC12 only.
|
|
|
|
# RUN: not llvm-mc -triple s390x-linux-gnu -mcpu=zEC12 < %s 2> %t
|
|
|
|
# RUN: FileCheck < %t %s
|
|
|
|
|
2015-05-06 03:23:40 +08:00
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: lcbb %r0, 0, 0
|
|
|
|
|
|
|
|
lcbb %r0, 0, 0
|
|
|
|
|
[SystemZ] Support transactional execution on zEC12
The zEC12 provides the transactional-execution facility. This is exposed
to users via a set of builtin routines on other compilers. This patch
adds LLVM support to enable those builtins. In partciular, the patch:
- adds the transactional-execution and processor-assist facilities
- adds MC support for all instructions provided by those facilities
- adds LLVM intrinsics for those instructions and hooks them up for CodeGen
- adds CodeGen support to optimize CC return value checking
Since this is first use of target-specific intrinsics on the platform,
the patch creates the include/llvm/IR/IntrinsicsSystemZ.td file and
hooks it up in Intrinsics.td. I've also changed Triple::getArchTypePrefix
to return "s390" instead of "systemz", since the naming convention for
GCC intrinsics uses "s390" on the platform, and it neemed more straight-
forward to use the same convention for LLVM IR intrinsics.
An associated clang patch makes the intrinsics (and command line switches)
available at the source-language level.
For reference, the transactional-execution instructions are documented
in the z/Architecture Principles of Operation for the zEC12:
http://publibfp.boulder.ibm.com/cgi-bin/bookmgr/download/DZ9ZR009.pdf
The associated builtins are documented in the GCC manual:
http://gcc.gnu.org/onlinedocs/gcc/S_002f390-System-z-Built-in-Functions.html
Index: llvm-head/lib/Target/SystemZ/SystemZOperators.td
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZOperators.td
+++ llvm-head/lib/Target/SystemZ/SystemZOperators.td
@@ -79,6 +79,9 @@ def SDT_ZI32Intrinsic : SDTypeProf
def SDT_ZPrefetch : SDTypeProfile<0, 2,
[SDTCisVT<0, i32>,
SDTCisPtrTy<1>]>;
+def SDT_ZTBegin : SDTypeProfile<0, 2,
+ [SDTCisPtrTy<0>,
+ SDTCisVT<1, i32>]>;
//===----------------------------------------------------------------------===//
// Node definitions
@@ -180,6 +183,15 @@ def z_prefetch : SDNode<"System
[SDNPHasChain, SDNPMayLoad, SDNPMayStore,
SDNPMemOperand]>;
+def z_tbegin : SDNode<"SystemZISD::TBEGIN", SDT_ZTBegin,
+ [SDNPHasChain, SDNPOutGlue, SDNPMayStore,
+ SDNPSideEffect]>;
+def z_tbegin_nofloat : SDNode<"SystemZISD::TBEGIN_NOFLOAT", SDT_ZTBegin,
+ [SDNPHasChain, SDNPOutGlue, SDNPMayStore,
+ SDNPSideEffect]>;
+def z_tend : SDNode<"SystemZISD::TEND", SDTNone,
+ [SDNPHasChain, SDNPOutGlue, SDNPSideEffect]>;
+
//===----------------------------------------------------------------------===//
// Pattern fragments
//===----------------------------------------------------------------------===//
Index: llvm-head/lib/Target/SystemZ/SystemZInstrFormats.td
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZInstrFormats.td
+++ llvm-head/lib/Target/SystemZ/SystemZInstrFormats.td
@@ -473,6 +473,17 @@ class InstSS<bits<8> op, dag outs, dag i
let Inst{15-0} = BD2;
}
+class InstS<bits<16> op, dag outs, dag ins, string asmstr, list<dag> pattern>
+ : InstSystemZ<4, outs, ins, asmstr, pattern> {
+ field bits<32> Inst;
+ field bits<32> SoftFail = 0;
+
+ bits<16> BD2;
+
+ let Inst{31-16} = op;
+ let Inst{15-0} = BD2;
+}
+
//===----------------------------------------------------------------------===//
// Instruction definitions with semantics
//===----------------------------------------------------------------------===//
Index: llvm-head/lib/Target/SystemZ/SystemZInstrInfo.td
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZInstrInfo.td
+++ llvm-head/lib/Target/SystemZ/SystemZInstrInfo.td
@@ -1362,6 +1362,60 @@ let Defs = [CC] in {
}
//===----------------------------------------------------------------------===//
+// Transactional execution
+//===----------------------------------------------------------------------===//
+
+let Predicates = [FeatureTransactionalExecution] in {
+ // Transaction Begin
+ let hasSideEffects = 1, mayStore = 1,
+ usesCustomInserter = 1, Defs = [CC] in {
+ def TBEGIN : InstSIL<0xE560,
+ (outs), (ins bdaddr12only:$BD1, imm32zx16:$I2),
+ "tbegin\t$BD1, $I2",
+ [(z_tbegin bdaddr12only:$BD1, imm32zx16:$I2)]>;
+ def TBEGIN_nofloat : Pseudo<(outs), (ins bdaddr12only:$BD1, imm32zx16:$I2),
+ [(z_tbegin_nofloat bdaddr12only:$BD1,
+ imm32zx16:$I2)]>;
+ def TBEGINC : InstSIL<0xE561,
+ (outs), (ins bdaddr12only:$BD1, imm32zx16:$I2),
+ "tbeginc\t$BD1, $I2",
+ [(int_s390_tbeginc bdaddr12only:$BD1,
+ imm32zx16:$I2)]>;
+ }
+
+ // Transaction End
+ let hasSideEffects = 1, Defs = [CC], BD2 = 0 in
+ def TEND : InstS<0xB2F8, (outs), (ins), "tend", [(z_tend)]>;
+
+ // Transaction Abort
+ let hasSideEffects = 1, isTerminator = 1, isBarrier = 1 in
+ def TABORT : InstS<0xB2FC, (outs), (ins bdaddr12only:$BD2),
+ "tabort\t$BD2",
+ [(int_s390_tabort bdaddr12only:$BD2)]>;
+
+ // Nontransactional Store
+ let hasSideEffects = 1 in
+ def NTSTG : StoreRXY<"ntstg", 0xE325, int_s390_ntstg, GR64, 8>;
+
+ // Extract Transaction Nesting Depth
+ let hasSideEffects = 1 in
+ def ETND : InherentRRE<"etnd", 0xB2EC, GR32, (int_s390_etnd)>;
+}
+
+//===----------------------------------------------------------------------===//
+// Processor assist
+//===----------------------------------------------------------------------===//
+
+let Predicates = [FeatureProcessorAssist] in {
+ let hasSideEffects = 1, R4 = 0 in
+ def PPA : InstRRF<0xB2E8, (outs), (ins GR64:$R1, GR64:$R2, imm32zx4:$R3),
+ "ppa\t$R1, $R2, $R3", []>;
+ def : Pat<(int_s390_ppa_txassist GR32:$src),
+ (PPA (INSERT_SUBREG (i64 (IMPLICIT_DEF)), GR32:$src, subreg_l32),
+ 0, 1)>;
+}
+
+//===----------------------------------------------------------------------===//
// Miscellaneous Instructions.
//===----------------------------------------------------------------------===//
Index: llvm-head/lib/Target/SystemZ/SystemZProcessors.td
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZProcessors.td
+++ llvm-head/lib/Target/SystemZ/SystemZProcessors.td
@@ -60,6 +60,16 @@ def FeatureMiscellaneousExtensions : Sys
"Assume that the miscellaneous-extensions facility is installed"
>;
+def FeatureTransactionalExecution : SystemZFeature<
+ "transactional-execution", "TransactionalExecution",
+ "Assume that the transactional-execution facility is installed"
+>;
+
+def FeatureProcessorAssist : SystemZFeature<
+ "processor-assist", "ProcessorAssist",
+ "Assume that the processor-assist facility is installed"
+>;
+
def : Processor<"generic", NoItineraries, []>;
def : Processor<"z10", NoItineraries, []>;
def : Processor<"z196", NoItineraries,
@@ -70,4 +80,5 @@ def : Processor<"zEC12", NoItineraries,
[FeatureDistinctOps, FeatureLoadStoreOnCond, FeatureHighWord,
FeatureFPExtension, FeaturePopulationCount,
FeatureFastSerialization, FeatureInterlockedAccess1,
- FeatureMiscellaneousExtensions]>;
+ FeatureMiscellaneousExtensions,
+ FeatureTransactionalExecution, FeatureProcessorAssist]>;
Index: llvm-head/lib/Target/SystemZ/SystemZSubtarget.cpp
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZSubtarget.cpp
+++ llvm-head/lib/Target/SystemZ/SystemZSubtarget.cpp
@@ -40,6 +40,7 @@ SystemZSubtarget::SystemZSubtarget(const
HasLoadStoreOnCond(false), HasHighWord(false), HasFPExtension(false),
HasPopulationCount(false), HasFastSerialization(false),
HasInterlockedAccess1(false), HasMiscellaneousExtensions(false),
+ HasTransactionalExecution(false), HasProcessorAssist(false),
TargetTriple(TT), InstrInfo(initializeSubtargetDependencies(CPU, FS)),
TLInfo(TM, *this), TSInfo(*TM.getDataLayout()), FrameLowering() {}
Index: llvm-head/lib/Target/SystemZ/SystemZSubtarget.h
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZSubtarget.h
+++ llvm-head/lib/Target/SystemZ/SystemZSubtarget.h
@@ -42,6 +42,8 @@ protected:
bool HasFastSerialization;
bool HasInterlockedAccess1;
bool HasMiscellaneousExtensions;
+ bool HasTransactionalExecution;
+ bool HasProcessorAssist;
private:
Triple TargetTriple;
@@ -102,6 +104,12 @@ public:
return HasMiscellaneousExtensions;
}
+ // Return true if the target has the transactional-execution facility.
+ bool hasTransactionalExecution() const { return HasTransactionalExecution; }
+
+ // Return true if the target has the processor-assist facility.
+ bool hasProcessorAssist() const { return HasProcessorAssist; }
+
// Return true if GV can be accessed using LARL for reloc model RM
// and code model CM.
bool isPC32DBLSymbol(const GlobalValue *GV, Reloc::Model RM,
Index: llvm-head/lib/Support/Triple.cpp
===================================================================
--- llvm-head.orig/lib/Support/Triple.cpp
+++ llvm-head/lib/Support/Triple.cpp
@@ -92,7 +92,7 @@ const char *Triple::getArchTypePrefix(Ar
case sparcv9:
case sparc: return "sparc";
- case systemz: return "systemz";
+ case systemz: return "s390";
case x86:
case x86_64: return "x86";
Index: llvm-head/include/llvm/IR/Intrinsics.td
===================================================================
--- llvm-head.orig/include/llvm/IR/Intrinsics.td
+++ llvm-head/include/llvm/IR/Intrinsics.td
@@ -634,3 +634,4 @@ include "llvm/IR/IntrinsicsNVVM.td"
include "llvm/IR/IntrinsicsMips.td"
include "llvm/IR/IntrinsicsR600.td"
include "llvm/IR/IntrinsicsBPF.td"
+include "llvm/IR/IntrinsicsSystemZ.td"
Index: llvm-head/include/llvm/IR/IntrinsicsSystemZ.td
===================================================================
--- /dev/null
+++ llvm-head/include/llvm/IR/IntrinsicsSystemZ.td
@@ -0,0 +1,46 @@
+//===- IntrinsicsSystemZ.td - Defines SystemZ intrinsics ---*- tablegen -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file defines all of the SystemZ-specific intrinsics.
+//
+//===----------------------------------------------------------------------===//
+
+//===----------------------------------------------------------------------===//
+//
+// Transactional-execution intrinsics
+//
+//===----------------------------------------------------------------------===//
+
+let TargetPrefix = "s390" in {
+ def int_s390_tbegin : Intrinsic<[llvm_i32_ty], [llvm_ptr_ty, llvm_i32_ty],
+ [IntrNoDuplicate]>;
+
+ def int_s390_tbegin_nofloat : Intrinsic<[llvm_i32_ty],
+ [llvm_ptr_ty, llvm_i32_ty],
+ [IntrNoDuplicate]>;
+
+ def int_s390_tbeginc : Intrinsic<[], [llvm_ptr_ty, llvm_i32_ty],
+ [IntrNoDuplicate]>;
+
+ def int_s390_tabort : Intrinsic<[], [llvm_i64_ty],
+ [IntrNoReturn, Throws]>;
+
+ def int_s390_tend : GCCBuiltin<"__builtin_tend">,
+ Intrinsic<[llvm_i32_ty], []>;
+
+ def int_s390_etnd : GCCBuiltin<"__builtin_tx_nesting_depth">,
+ Intrinsic<[llvm_i32_ty], [], [IntrNoMem]>;
+
+ def int_s390_ntstg : Intrinsic<[], [llvm_i64_ty, llvm_ptr64_ty],
+ [IntrReadWriteArgMem]>;
+
+ def int_s390_ppa_txassist : GCCBuiltin<"__builtin_tx_assist">,
+ Intrinsic<[], [llvm_i32_ty]>;
+}
+
Index: llvm-head/lib/Target/SystemZ/SystemZ.h
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZ.h
+++ llvm-head/lib/Target/SystemZ/SystemZ.h
@@ -68,6 +68,18 @@ const unsigned CCMASK_TM_MSB_0 = C
const unsigned CCMASK_TM_MSB_1 = CCMASK_2 | CCMASK_3;
const unsigned CCMASK_TM = CCMASK_ANY;
+// Condition-code mask assignments for TRANSACTION_BEGIN.
+const unsigned CCMASK_TBEGIN_STARTED = CCMASK_0;
+const unsigned CCMASK_TBEGIN_INDETERMINATE = CCMASK_1;
+const unsigned CCMASK_TBEGIN_TRANSIENT = CCMASK_2;
+const unsigned CCMASK_TBEGIN_PERSISTENT = CCMASK_3;
+const unsigned CCMASK_TBEGIN = CCMASK_ANY;
+
+// Condition-code mask assignments for TRANSACTION_END.
+const unsigned CCMASK_TEND_TX = CCMASK_0;
+const unsigned CCMASK_TEND_NOTX = CCMASK_2;
+const unsigned CCMASK_TEND = CCMASK_TEND_TX | CCMASK_TEND_NOTX;
+
// The position of the low CC bit in an IPM result.
const unsigned IPM_CC = 28;
Index: llvm-head/lib/Target/SystemZ/SystemZISelLowering.h
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZISelLowering.h
+++ llvm-head/lib/Target/SystemZ/SystemZISelLowering.h
@@ -146,6 +146,15 @@ enum {
// Perform a serialization operation. (BCR 15,0 or BCR 14,0.)
SERIALIZE,
+ // Transaction begin. The first operand is the chain, the second
+ // the TDB pointer, and the third the immediate control field.
+ // Returns chain and glue.
+ TBEGIN,
+ TBEGIN_NOFLOAT,
+
+ // Transaction end. Just the chain operand. Returns chain and glue.
+ TEND,
+
// Wrappers around the inner loop of an 8- or 16-bit ATOMIC_SWAP or
// ATOMIC_LOAD_<op>.
//
@@ -318,6 +327,7 @@ private:
SDValue lowerSTACKSAVE(SDValue Op, SelectionDAG &DAG) const;
SDValue lowerSTACKRESTORE(SDValue Op, SelectionDAG &DAG) const;
SDValue lowerPREFETCH(SDValue Op, SelectionDAG &DAG) const;
+ SDValue lowerINTRINSIC_W_CHAIN(SDValue Op, SelectionDAG &DAG) const;
// If the last instruction before MBBI in MBB was some form of COMPARE,
// try to replace it with a COMPARE AND BRANCH just before MBBI.
@@ -355,6 +365,10 @@ private:
MachineBasicBlock *emitStringWrapper(MachineInstr *MI,
MachineBasicBlock *BB,
unsigned Opcode) const;
+ MachineBasicBlock *emitTransactionBegin(MachineInstr *MI,
+ MachineBasicBlock *MBB,
+ unsigned Opcode,
+ bool NoFloat) const;
};
} // end namespace llvm
Index: llvm-head/lib/Target/SystemZ/SystemZISelLowering.cpp
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZISelLowering.cpp
+++ llvm-head/lib/Target/SystemZ/SystemZISelLowering.cpp
@@ -20,6 +20,7 @@
#include "llvm/CodeGen/MachineInstrBuilder.h"
#include "llvm/CodeGen/MachineRegisterInfo.h"
#include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
+#include "llvm/IR/Intrinsics.h"
#include <cctype>
using namespace llvm;
@@ -304,6 +305,9 @@ SystemZTargetLowering::SystemZTargetLowe
// Codes for which we want to perform some z-specific combinations.
setTargetDAGCombine(ISD::SIGN_EXTEND);
+ // Handle intrinsics.
+ setOperationAction(ISD::INTRINSIC_W_CHAIN, MVT::Other, Custom);
+
// We want to use MVC in preference to even a single load/store pair.
MaxStoresPerMemcpy = 0;
MaxStoresPerMemcpyOptSize = 0;
@@ -1031,6 +1035,53 @@ prepareVolatileOrAtomicLoad(SDValue Chai
return DAG.getNode(SystemZISD::SERIALIZE, DL, MVT::Other, Chain);
}
+// Return true if Op is an intrinsic node with chain that returns the CC value
+// as its only (other) argument. Provide the associated SystemZISD opcode and
+// the mask of valid CC values if so.
+static bool isIntrinsicWithCCAndChain(SDValue Op, unsigned &Opcode,
+ unsigned &CCValid) {
+ unsigned Id = cast<ConstantSDNode>(Op.getOperand(1))->getZExtValue();
+ switch (Id) {
+ case Intrinsic::s390_tbegin:
+ Opcode = SystemZISD::TBEGIN;
+ CCValid = SystemZ::CCMASK_TBEGIN;
+ return true;
+
+ case Intrinsic::s390_tbegin_nofloat:
+ Opcode = SystemZISD::TBEGIN_NOFLOAT;
+ CCValid = SystemZ::CCMASK_TBEGIN;
+ return true;
+
+ case Intrinsic::s390_tend:
+ Opcode = SystemZISD::TEND;
+ CCValid = SystemZ::CCMASK_TEND;
+ return true;
+
+ default:
+ return false;
+ }
+}
+
+// Emit an intrinsic with chain with a glued value instead of its CC result.
+static SDValue emitIntrinsicWithChainAndGlue(SelectionDAG &DAG, SDValue Op,
+ unsigned Opcode) {
+ // Copy all operands except the intrinsic ID.
+ unsigned NumOps = Op.getNumOperands();
+ SmallVector<SDValue, 6> Ops;
+ Ops.reserve(NumOps - 1);
+ Ops.push_back(Op.getOperand(0));
+ for (unsigned I = 2; I < NumOps; ++I)
+ Ops.push_back(Op.getOperand(I));
+
+ assert(Op->getNumValues() == 2 && "Expected only CC result and chain");
+ SDVTList RawVTs = DAG.getVTList(MVT::Other, MVT::Glue);
+ SDValue Intr = DAG.getNode(Opcode, SDLoc(Op), RawVTs, Ops);
+ SDValue OldChain = SDValue(Op.getNode(), 1);
+ SDValue NewChain = SDValue(Intr.getNode(), 0);
+ DAG.ReplaceAllUsesOfValueWith(OldChain, NewChain);
+ return Intr;
+}
+
// CC is a comparison that will be implemented using an integer or
// floating-point comparison. Return the condition code mask for
// a branch on true. In the integer case, CCMASK_CMP_UO is set for
@@ -1588,9 +1639,53 @@ static void adjustForTestUnderMask(Selec
C.CCMask = NewCCMask;
}
+// Return a Comparison that tests the condition-code result of intrinsic
+// node Call against constant integer CC using comparison code Cond.
+// Opcode is the opcode of the SystemZISD operation for the intrinsic
+// and CCValid is the set of possible condition-code results.
+static Comparison getIntrinsicCmp(SelectionDAG &DAG, unsigned Opcode,
+ SDValue Call, unsigned CCValid, uint64_t CC,
+ ISD::CondCode Cond) {
+ Comparison C(Call, SDValue());
+ C.Opcode = Opcode;
+ C.CCValid = CCValid;
+ if (Cond == ISD::SETEQ)
+ // bit 3 for CC==0, bit 0 for CC==3, always false for CC>3.
+ C.CCMask = CC < 4 ? 1 << (3 - CC) : 0;
+ else if (Cond == ISD::SETNE)
+ // ...and the inverse of that.
+ C.CCMask = CC < 4 ? ~(1 << (3 - CC)) : -1;
+ else if (Cond == ISD::SETLT || Cond == ISD::SETULT)
+ // bits above bit 3 for CC==0 (always false), bits above bit 0 for CC==3,
+ // always true for CC>3.
+ C.CCMask = CC < 4 ? -1 << (4 - CC) : -1;
+ else if (Cond == ISD::SETGE || Cond == ISD::SETUGE)
+ // ...and the inverse of that.
+ C.CCMask = CC < 4 ? ~(-1 << (4 - CC)) : 0;
+ else if (Cond == ISD::SETLE || Cond == ISD::SETULE)
+ // bit 3 and above for CC==0, bit 0 and above for CC==3 (always true),
+ // always true for CC>3.
+ C.CCMask = CC < 4 ? -1 << (3 - CC) : -1;
+ else if (Cond == ISD::SETGT || Cond == ISD::SETUGT)
+ // ...and the inverse of that.
+ C.CCMask = CC < 4 ? ~(-1 << (3 - CC)) : 0;
+ else
+ llvm_unreachable("Unexpected integer comparison type");
+ C.CCMask &= CCValid;
+ return C;
+}
+
// Decide how to implement a comparison of type Cond between CmpOp0 with CmpOp1.
static Comparison getCmp(SelectionDAG &DAG, SDValue CmpOp0, SDValue CmpOp1,
ISD::CondCode Cond) {
+ if (CmpOp1.getOpcode() == ISD::Constant) {
+ uint64_t Constant = cast<ConstantSDNode>(CmpOp1)->getZExtValue();
+ unsigned Opcode, CCValid;
+ if (CmpOp0.getOpcode() == ISD::INTRINSIC_W_CHAIN &&
+ CmpOp0.getResNo() == 0 && CmpOp0->hasNUsesOfValue(1, 0) &&
+ isIntrinsicWithCCAndChain(CmpOp0, Opcode, CCValid))
+ return getIntrinsicCmp(DAG, Opcode, CmpOp0, CCValid, Constant, Cond);
+ }
Comparison C(CmpOp0, CmpOp1);
C.CCMask = CCMaskForCondCode(Cond);
if (C.Op0.getValueType().isFloatingPoint()) {
@@ -1632,6 +1727,17 @@ static Comparison getCmp(SelectionDAG &D
// Emit the comparison instruction described by C.
static SDValue emitCmp(SelectionDAG &DAG, SDLoc DL, Comparison &C) {
+ if (!C.Op1.getNode()) {
+ SDValue Op;
+ switch (C.Op0.getOpcode()) {
+ case ISD::INTRINSIC_W_CHAIN:
+ Op = emitIntrinsicWithChainAndGlue(DAG, C.Op0, C.Opcode);
+ break;
+ default:
+ llvm_unreachable("Invalid comparison operands");
+ }
+ return SDValue(Op.getNode(), Op->getNumValues() - 1);
+ }
if (C.Opcode == SystemZISD::ICMP)
return DAG.getNode(SystemZISD::ICMP, DL, MVT::Glue, C.Op0, C.Op1,
DAG.getConstant(C.ICmpType, MVT::i32));
@@ -1713,7 +1819,6 @@ SDValue SystemZTargetLowering::lowerSETC
}
SDValue SystemZTargetLowering::lowerBR_CC(SDValue Op, SelectionDAG &DAG) const {
- SDValue Chain = Op.getOperand(0);
ISD::CondCode CC = cast<CondCodeSDNode>(Op.getOperand(1))->get();
SDValue CmpOp0 = Op.getOperand(2);
SDValue CmpOp1 = Op.getOperand(3);
@@ -1723,7 +1828,7 @@ SDValue SystemZTargetLowering::lowerBR_C
Comparison C(getCmp(DAG, CmpOp0, CmpOp1, CC));
SDValue Glue = emitCmp(DAG, DL, C);
return DAG.getNode(SystemZISD::BR_CCMASK, DL, Op.getValueType(),
- Chain, DAG.getConstant(C.CCValid, MVT::i32),
+ Op.getOperand(0), DAG.getConstant(C.CCValid, MVT::i32),
DAG.getConstant(C.CCMask, MVT::i32), Dest, Glue);
}
@@ -2561,6 +2666,30 @@ SDValue SystemZTargetLowering::lowerPREF
Node->getMemoryVT(), Node->getMemOperand());
}
+// Return an i32 that contains the value of CC immediately after After,
+// whose final operand must be MVT::Glue.
+static SDValue getCCResult(SelectionDAG &DAG, SDNode *After) {
+ SDValue Glue = SDValue(After, After->getNumValues() - 1);
+ SDValue IPM = DAG.getNode(SystemZISD::IPM, SDLoc(After), MVT::i32, Glue);
+ return DAG.getNode(ISD::SRL, SDLoc(After), MVT::i32, IPM,
+ DAG.getConstant(SystemZ::IPM_CC, MVT::i32));
+}
+
+SDValue
+SystemZTargetLowering::lowerINTRINSIC_W_CHAIN(SDValue Op,
+ SelectionDAG &DAG) const {
+ unsigned Opcode, CCValid;
+ if (isIntrinsicWithCCAndChain(Op, Opcode, CCValid)) {
+ assert(Op->getNumValues() == 2 && "Expected only CC result and chain");
+ SDValue Glued = emitIntrinsicWithChainAndGlue(DAG, Op, Opcode);
+ SDValue CC = getCCResult(DAG, Glued.getNode());
+ DAG.ReplaceAllUsesOfValueWith(SDValue(Op.getNode(), 0), CC);
+ return SDValue();
+ }
+
+ return SDValue();
+}
+
SDValue SystemZTargetLowering::LowerOperation(SDValue Op,
SelectionDAG &DAG) const {
switch (Op.getOpcode()) {
@@ -2634,6 +2763,8 @@ SDValue SystemZTargetLowering::LowerOper
return lowerSTACKRESTORE(Op, DAG);
case ISD::PREFETCH:
return lowerPREFETCH(Op, DAG);
+ case ISD::INTRINSIC_W_CHAIN:
+ return lowerINTRINSIC_W_CHAIN(Op, DAG);
default:
llvm_unreachable("Unexpected node to lower");
}
@@ -2674,6 +2805,9 @@ const char *SystemZTargetLowering::getTa
OPCODE(SEARCH_STRING);
OPCODE(IPM);
OPCODE(SERIALIZE);
+ OPCODE(TBEGIN);
+ OPCODE(TBEGIN_NOFLOAT);
+ OPCODE(TEND);
OPCODE(ATOMIC_SWAPW);
OPCODE(ATOMIC_LOADW_ADD);
OPCODE(ATOMIC_LOADW_SUB);
@@ -3501,6 +3635,50 @@ SystemZTargetLowering::emitStringWrapper
return DoneMBB;
}
+// Update TBEGIN instruction with final opcode and register clobbers.
+MachineBasicBlock *
+SystemZTargetLowering::emitTransactionBegin(MachineInstr *MI,
+ MachineBasicBlock *MBB,
+ unsigned Opcode,
+ bool NoFloat) const {
+ MachineFunction &MF = *MBB->getParent();
+ const TargetFrameLowering *TFI = Subtarget.getFrameLowering();
+ const SystemZInstrInfo *TII = Subtarget.getInstrInfo();
+
+ // Update opcode.
+ MI->setDesc(TII->get(Opcode));
+
+ // We cannot handle a TBEGIN that clobbers the stack or frame pointer.
+ // Make sure to add the corresponding GRSM bits if they are missing.
+ uint64_t Control = MI->getOperand(2).getImm();
+ static const unsigned GPRControlBit[16] = {
+ 0x8000, 0x8000, 0x4000, 0x4000, 0x2000, 0x2000, 0x1000, 0x1000,
+ 0x0800, 0x0800, 0x0400, 0x0400, 0x0200, 0x0200, 0x0100, 0x0100
+ };
+ Control |= GPRControlBit[15];
+ if (TFI->hasFP(MF))
+ Control |= GPRControlBit[11];
+ MI->getOperand(2).setImm(Control);
+
+ // Add GPR clobbers.
+ for (int I = 0; I < 16; I++) {
+ if ((Control & GPRControlBit[I]) == 0) {
+ unsigned Reg = SystemZMC::GR64Regs[I];
+ MI->addOperand(MachineOperand::CreateReg(Reg, true, true));
+ }
+ }
+
+ // Add FPR clobbers.
+ if (!NoFloat && (Control & 4) != 0) {
+ for (int I = 0; I < 16; I++) {
+ unsigned Reg = SystemZMC::FP64Regs[I];
+ MI->addOperand(MachineOperand::CreateReg(Reg, true, true));
+ }
+ }
+
+ return MBB;
+}
+
MachineBasicBlock *SystemZTargetLowering::
EmitInstrWithCustomInserter(MachineInstr *MI, MachineBasicBlock *MBB) const {
switch (MI->getOpcode()) {
@@ -3742,6 +3920,12 @@ EmitInstrWithCustomInserter(MachineInstr
return emitStringWrapper(MI, MBB, SystemZ::MVST);
case SystemZ::SRSTLoop:
return emitStringWrapper(MI, MBB, SystemZ::SRST);
+ case SystemZ::TBEGIN:
+ return emitTransactionBegin(MI, MBB, SystemZ::TBEGIN, false);
+ case SystemZ::TBEGIN_nofloat:
+ return emitTransactionBegin(MI, MBB, SystemZ::TBEGIN, true);
+ case SystemZ::TBEGINC:
+ return emitTransactionBegin(MI, MBB, SystemZ::TBEGINC, true);
default:
llvm_unreachable("Unexpected instr type to insert");
}
Index: llvm-head/test/CodeGen/SystemZ/htm-intrinsics.ll
===================================================================
--- /dev/null
+++ llvm-head/test/CodeGen/SystemZ/htm-intrinsics.ll
@@ -0,0 +1,352 @@
+; Test transactional-execution intrinsics.
+;
+; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=zEC12 | FileCheck %s
+
+declare i32 @llvm.s390.tbegin(i8 *, i32)
+declare i32 @llvm.s390.tbegin.nofloat(i8 *, i32)
+declare void @llvm.s390.tbeginc(i8 *, i32)
+declare i32 @llvm.s390.tend()
+declare void @llvm.s390.tabort(i64)
+declare void @llvm.s390.ntstg(i64, i64 *)
+declare i32 @llvm.s390.etnd()
+declare void @llvm.s390.ppa.txassist(i32)
+
+; TBEGIN.
+define void @test_tbegin() {
+; CHECK-LABEL: test_tbegin:
+; CHECK-NOT: stmg
+; CHECK: std %f8,
+; CHECK: std %f9,
+; CHECK: std %f10,
+; CHECK: std %f11,
+; CHECK: std %f12,
+; CHECK: std %f13,
+; CHECK: std %f14,
+; CHECK: std %f15,
+; CHECK: tbegin 0, 65292
+; CHECK: ld %f8,
+; CHECK: ld %f9,
+; CHECK: ld %f10,
+; CHECK: ld %f11,
+; CHECK: ld %f12,
+; CHECK: ld %f13,
+; CHECK: ld %f14,
+; CHECK: ld %f15,
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin(i8 *null, i32 65292)
+ ret void
+}
+
+; TBEGIN (nofloat).
+define void @test_tbegin_nofloat1() {
+; CHECK-LABEL: test_tbegin_nofloat1:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65292
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65292)
+ ret void
+}
+
+; TBEGIN (nofloat) with integer CC return value.
+define i32 @test_tbegin_nofloat2() {
+; CHECK-LABEL: test_tbegin_nofloat2:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65292
+; CHECK: ipm %r2
+; CHECK: srl %r2, 28
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65292)
+ ret i32 %res
+}
+
+; TBEGIN (nofloat) with implicit CC check.
+define void @test_tbegin_nofloat3(i32 *%ptr) {
+; CHECK-LABEL: test_tbegin_nofloat3:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65292
+; CHECK: jnh {{\.L*}}
+; CHECK: mvhi 0(%r2), 0
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65292)
+ %cmp = icmp eq i32 %res, 2
+ br i1 %cmp, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ store i32 0, i32* %ptr, align 4
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ ret void
+}
+
+; TBEGIN (nofloat) with dual CC use.
+define i32 @test_tbegin_nofloat4(i32 %pad, i32 *%ptr) {
+; CHECK-LABEL: test_tbegin_nofloat4:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65292
+; CHECK: ipm %r2
+; CHECK: srl %r2, 28
+; CHECK: cijlh %r2, 2, {{\.L*}}
+; CHECK: mvhi 0(%r3), 0
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65292)
+ %cmp = icmp eq i32 %res, 2
+ br i1 %cmp, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ store i32 0, i32* %ptr, align 4
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ ret i32 %res
+}
+
+; TBEGIN (nofloat) with register.
+define void @test_tbegin_nofloat5(i8 *%ptr) {
+; CHECK-LABEL: test_tbegin_nofloat5:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0(%r2), 65292
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *%ptr, i32 65292)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0x0f00.
+define void @test_tbegin_nofloat6() {
+; CHECK-LABEL: test_tbegin_nofloat6:
+; CHECK: stmg %r6, %r15,
+; CHECK-NOT: std
+; CHECK: tbegin 0, 3840
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 3840)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0xf100.
+define void @test_tbegin_nofloat7() {
+; CHECK-LABEL: test_tbegin_nofloat7:
+; CHECK: stmg %r8, %r15,
+; CHECK-NOT: std
+; CHECK: tbegin 0, 61696
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 61696)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0xfe00 -- stack pointer added automatically.
+define void @test_tbegin_nofloat8() {
+; CHECK-LABEL: test_tbegin_nofloat8:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65280
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65024)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0xfb00 -- no frame pointer needed.
+define void @test_tbegin_nofloat9() {
+; CHECK-LABEL: test_tbegin_nofloat9:
+; CHECK: stmg %r10, %r15,
+; CHECK-NOT: std
+; CHECK: tbegin 0, 64256
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 64256)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0xfb00 -- frame pointer added automatically.
+define void @test_tbegin_nofloat10(i64 %n) {
+; CHECK-LABEL: test_tbegin_nofloat10:
+; CHECK: stmg %r11, %r15,
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65280
+; CHECK: br %r14
+ %buf = alloca i8, i64 %n
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 64256)
+ ret void
+}
+
+; TBEGINC.
+define void @test_tbeginc() {
+; CHECK-LABEL: test_tbeginc:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbeginc 0, 65288
+; CHECK: br %r14
+ call void @llvm.s390.tbeginc(i8 *null, i32 65288)
+ ret void
+}
+
+; TEND with integer CC return value.
+define i32 @test_tend1() {
+; CHECK-LABEL: test_tend1:
+; CHECK: tend
+; CHECK: ipm %r2
+; CHECK: srl %r2, 28
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tend()
+ ret i32 %res
+}
+
+; TEND with implicit CC check.
+define void @test_tend3(i32 *%ptr) {
+; CHECK-LABEL: test_tend3:
+; CHECK: tend
+; CHECK: je {{\.L*}}
+; CHECK: mvhi 0(%r2), 0
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tend()
+ %cmp = icmp eq i32 %res, 2
+ br i1 %cmp, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ store i32 0, i32* %ptr, align 4
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ ret void
+}
+
+; TEND with dual CC use.
+define i32 @test_tend2(i32 %pad, i32 *%ptr) {
+; CHECK-LABEL: test_tend2:
+; CHECK: tend
+; CHECK: ipm %r2
+; CHECK: srl %r2, 28
+; CHECK: cijlh %r2, 2, {{\.L*}}
+; CHECK: mvhi 0(%r3), 0
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tend()
+ %cmp = icmp eq i32 %res, 2
+ br i1 %cmp, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ store i32 0, i32* %ptr, align 4
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ ret i32 %res
+}
+
+; TABORT with register only.
+define void @test_tabort1(i64 %val) {
+; CHECK-LABEL: test_tabort1:
+; CHECK: tabort 0(%r2)
+; CHECK: br %r14
+ call void @llvm.s390.tabort(i64 %val)
+ ret void
+}
+
+; TABORT with immediate only.
+define void @test_tabort2(i64 %val) {
+; CHECK-LABEL: test_tabort2:
+; CHECK: tabort 1234
+; CHECK: br %r14
+ call void @llvm.s390.tabort(i64 1234)
+ ret void
+}
+
+; TABORT with register + immediate.
+define void @test_tabort3(i64 %val) {
+; CHECK-LABEL: test_tabort3:
+; CHECK: tabort 1234(%r2)
+; CHECK: br %r14
+ %sum = add i64 %val, 1234
+ call void @llvm.s390.tabort(i64 %sum)
+ ret void
+}
+
+; TABORT with out-of-range immediate.
+define void @test_tabort4(i64 %val) {
+; CHECK-LABEL: test_tabort4:
+; CHECK: tabort 0({{%r[1-5]}})
+; CHECK: br %r14
+ call void @llvm.s390.tabort(i64 4096)
+ ret void
+}
+
+; NTSTG with base pointer only.
+define void @test_ntstg1(i64 *%ptr, i64 %val) {
+; CHECK-LABEL: test_ntstg1:
+; CHECK: ntstg %r3, 0(%r2)
+; CHECK: br %r14
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with base and index.
+; Check that VSTL doesn't allow an index.
+define void @test_ntstg2(i64 *%base, i64 %index, i64 %val) {
+; CHECK-LABEL: test_ntstg2:
+; CHECK: sllg [[REG:%r[1-5]]], %r3, 3
+; CHECK: ntstg %r4, 0([[REG]],%r2)
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 %index
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with the highest in-range displacement.
+define void @test_ntstg3(i64 *%base, i64 %val) {
+; CHECK-LABEL: test_ntstg3:
+; CHECK: ntstg %r3, 524280(%r2)
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 65535
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with an out-of-range positive displacement.
+define void @test_ntstg4(i64 *%base, i64 %val) {
+; CHECK-LABEL: test_ntstg4:
+; CHECK: ntstg %r3, 0({{%r[1-5]}})
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 65536
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with the lowest in-range displacement.
+define void @test_ntstg5(i64 *%base, i64 %val) {
+; CHECK-LABEL: test_ntstg5:
+; CHECK: ntstg %r3, -524288(%r2)
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 -65536
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with an out-of-range negative displacement.
+define void @test_ntstg6(i64 *%base, i64 %val) {
+; CHECK-LABEL: test_ntstg6:
+; CHECK: ntstg %r3, 0({{%r[1-5]}})
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 -65537
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; ETND.
+define i32 @test_etnd() {
+; CHECK-LABEL: test_etnd:
+; CHECK: etnd %r2
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.etnd()
+ ret i32 %res
+}
+
+; PPA (Transaction-Abort Assist)
+define void @test_ppa_txassist(i32 %val) {
+; CHECK-LABEL: test_ppa_txassist:
+; CHECK: ppa %r2, 0, 1
+; CHECK: br %r14
+ call void @llvm.s390.ppa.txassist(i32 %val)
+ ret void
+}
+
Index: llvm-head/test/MC/SystemZ/insn-bad-zEC12.s
===================================================================
--- llvm-head.orig/test/MC/SystemZ/insn-bad-zEC12.s
+++ llvm-head/test/MC/SystemZ/insn-bad-zEC12.s
@@ -3,6 +3,22 @@
# RUN: FileCheck < %t %s
#CHECK: error: invalid operand
+#CHECK: ntstg %r0, -524289
+#CHECK: error: invalid operand
+#CHECK: ntstg %r0, 524288
+
+ ntstg %r0, -524289
+ ntstg %r0, 524288
+
+#CHECK: error: invalid operand
+#CHECK: ppa %r0, %r0, -1
+#CHECK: error: invalid operand
+#CHECK: ppa %r0, %r0, 16
+
+ ppa %r0, %r0, -1
+ ppa %r0, %r0, 16
+
+#CHECK: error: invalid operand
#CHECK: risbgn %r0,%r0,0,0,-1
#CHECK: error: invalid operand
#CHECK: risbgn %r0,%r0,0,0,64
@@ -22,3 +38,47 @@
risbgn %r0,%r0,-1,0,0
risbgn %r0,%r0,256,0,0
+#CHECK: error: invalid operand
+#CHECK: tabort -1
+#CHECK: error: invalid operand
+#CHECK: tabort 4096
+#CHECK: error: invalid use of indexed addressing
+#CHECK: tabort 0(%r1,%r2)
+
+ tabort -1
+ tabort 4096
+ tabort 0(%r1,%r2)
+
+#CHECK: error: invalid operand
+#CHECK: tbegin -1, 0
+#CHECK: error: invalid operand
+#CHECK: tbegin 4096, 0
+#CHECK: error: invalid use of indexed addressing
+#CHECK: tbegin 0(%r1,%r2), 0
+#CHECK: error: invalid operand
+#CHECK: tbegin 0, -1
+#CHECK: error: invalid operand
+#CHECK: tbegin 0, 65536
+
+ tbegin -1, 0
+ tbegin 4096, 0
+ tbegin 0(%r1,%r2), 0
+ tbegin 0, -1
+ tbegin 0, 65536
+
+#CHECK: error: invalid operand
+#CHECK: tbeginc -1, 0
+#CHECK: error: invalid operand
+#CHECK: tbeginc 4096, 0
+#CHECK: error: invalid use of indexed addressing
+#CHECK: tbeginc 0(%r1,%r2), 0
+#CHECK: error: invalid operand
+#CHECK: tbeginc 0, -1
+#CHECK: error: invalid operand
+#CHECK: tbeginc 0, 65536
+
+ tbeginc -1, 0
+ tbeginc 4096, 0
+ tbeginc 0(%r1,%r2), 0
+ tbeginc 0, -1
+ tbeginc 0, 65536
Index: llvm-head/test/MC/SystemZ/insn-good-zEC12.s
===================================================================
--- llvm-head.orig/test/MC/SystemZ/insn-good-zEC12.s
+++ llvm-head/test/MC/SystemZ/insn-good-zEC12.s
@@ -1,6 +1,48 @@
# For zEC12 and above.
# RUN: llvm-mc -triple s390x-linux-gnu -mcpu=zEC12 -show-encoding %s | FileCheck %s
+#CHECK: etnd %r0 # encoding: [0xb2,0xec,0x00,0x00]
+#CHECK: etnd %r15 # encoding: [0xb2,0xec,0x00,0xf0]
+#CHECK: etnd %r7 # encoding: [0xb2,0xec,0x00,0x70]
+
+ etnd %r0
+ etnd %r15
+ etnd %r7
+
+#CHECK: ntstg %r0, -524288 # encoding: [0xe3,0x00,0x00,0x00,0x80,0x25]
+#CHECK: ntstg %r0, -1 # encoding: [0xe3,0x00,0x0f,0xff,0xff,0x25]
+#CHECK: ntstg %r0, 0 # encoding: [0xe3,0x00,0x00,0x00,0x00,0x25]
+#CHECK: ntstg %r0, 1 # encoding: [0xe3,0x00,0x00,0x01,0x00,0x25]
+#CHECK: ntstg %r0, 524287 # encoding: [0xe3,0x00,0x0f,0xff,0x7f,0x25]
+#CHECK: ntstg %r0, 0(%r1) # encoding: [0xe3,0x00,0x10,0x00,0x00,0x25]
+#CHECK: ntstg %r0, 0(%r15) # encoding: [0xe3,0x00,0xf0,0x00,0x00,0x25]
+#CHECK: ntstg %r0, 524287(%r1,%r15) # encoding: [0xe3,0x01,0xff,0xff,0x7f,0x25]
+#CHECK: ntstg %r0, 524287(%r15,%r1) # encoding: [0xe3,0x0f,0x1f,0xff,0x7f,0x25]
+#CHECK: ntstg %r15, 0 # encoding: [0xe3,0xf0,0x00,0x00,0x00,0x25]
+
+ ntstg %r0, -524288
+ ntstg %r0, -1
+ ntstg %r0, 0
+ ntstg %r0, 1
+ ntstg %r0, 524287
+ ntstg %r0, 0(%r1)
+ ntstg %r0, 0(%r15)
+ ntstg %r0, 524287(%r1,%r15)
+ ntstg %r0, 524287(%r15,%r1)
+ ntstg %r15, 0
+
+#CHECK: ppa %r0, %r0, 0 # encoding: [0xb2,0xe8,0x00,0x00]
+#CHECK: ppa %r0, %r0, 15 # encoding: [0xb2,0xe8,0xf0,0x00]
+#CHECK: ppa %r0, %r15, 0 # encoding: [0xb2,0xe8,0x00,0x0f]
+#CHECK: ppa %r4, %r6, 7 # encoding: [0xb2,0xe8,0x70,0x46]
+#CHECK: ppa %r15, %r0, 0 # encoding: [0xb2,0xe8,0x00,0xf0]
+
+ ppa %r0, %r0, 0
+ ppa %r0, %r0, 15
+ ppa %r0, %r15, 0
+ ppa %r4, %r6, 7
+ ppa %r15, %r0, 0
+
#CHECK: risbgn %r0, %r0, 0, 0, 0 # encoding: [0xec,0x00,0x00,0x00,0x00,0x59]
#CHECK: risbgn %r0, %r0, 0, 0, 63 # encoding: [0xec,0x00,0x00,0x00,0x3f,0x59]
#CHECK: risbgn %r0, %r0, 0, 255, 0 # encoding: [0xec,0x00,0x00,0xff,0x00,0x59]
@@ -17,3 +59,68 @@
risbgn %r15,%r0,0,0,0
risbgn %r4,%r5,6,7,8
+#CHECK: tabort 0 # encoding: [0xb2,0xfc,0x00,0x00]
+#CHECK: tabort 0(%r1) # encoding: [0xb2,0xfc,0x10,0x00]
+#CHECK: tabort 0(%r15) # encoding: [0xb2,0xfc,0xf0,0x00]
+#CHECK: tabort 4095 # encoding: [0xb2,0xfc,0x0f,0xff]
+#CHECK: tabort 4095(%r1) # encoding: [0xb2,0xfc,0x1f,0xff]
+#CHECK: tabort 4095(%r15) # encoding: [0xb2,0xfc,0xff,0xff]
+
+ tabort 0
+ tabort 0(%r1)
+ tabort 0(%r15)
+ tabort 4095
+ tabort 4095(%r1)
+ tabort 4095(%r15)
+
+#CHECK: tbegin 0, 0 # encoding: [0xe5,0x60,0x00,0x00,0x00,0x00]
+#CHECK: tbegin 4095, 0 # encoding: [0xe5,0x60,0x0f,0xff,0x00,0x00]
+#CHECK: tbegin 0, 0 # encoding: [0xe5,0x60,0x00,0x00,0x00,0x00]
+#CHECK: tbegin 0, 1 # encoding: [0xe5,0x60,0x00,0x00,0x00,0x01]
+#CHECK: tbegin 0, 32767 # encoding: [0xe5,0x60,0x00,0x00,0x7f,0xff]
+#CHECK: tbegin 0, 32768 # encoding: [0xe5,0x60,0x00,0x00,0x80,0x00]
+#CHECK: tbegin 0, 65535 # encoding: [0xe5,0x60,0x00,0x00,0xff,0xff]
+#CHECK: tbegin 0(%r1), 42 # encoding: [0xe5,0x60,0x10,0x00,0x00,0x2a]
+#CHECK: tbegin 0(%r15), 42 # encoding: [0xe5,0x60,0xf0,0x00,0x00,0x2a]
+#CHECK: tbegin 4095(%r1), 42 # encoding: [0xe5,0x60,0x1f,0xff,0x00,0x2a]
+#CHECK: tbegin 4095(%r15), 42 # encoding: [0xe5,0x60,0xff,0xff,0x00,0x2a]
+
+ tbegin 0, 0
+ tbegin 4095, 0
+ tbegin 0, 0
+ tbegin 0, 1
+ tbegin 0, 32767
+ tbegin 0, 32768
+ tbegin 0, 65535
+ tbegin 0(%r1), 42
+ tbegin 0(%r15), 42
+ tbegin 4095(%r1), 42
+ tbegin 4095(%r15), 42
+
+#CHECK: tbeginc 0, 0 # encoding: [0xe5,0x61,0x00,0x00,0x00,0x00]
+#CHECK: tbeginc 4095, 0 # encoding: [0xe5,0x61,0x0f,0xff,0x00,0x00]
+#CHECK: tbeginc 0, 0 # encoding: [0xe5,0x61,0x00,0x00,0x00,0x00]
+#CHECK: tbeginc 0, 1 # encoding: [0xe5,0x61,0x00,0x00,0x00,0x01]
+#CHECK: tbeginc 0, 32767 # encoding: [0xe5,0x61,0x00,0x00,0x7f,0xff]
+#CHECK: tbeginc 0, 32768 # encoding: [0xe5,0x61,0x00,0x00,0x80,0x00]
+#CHECK: tbeginc 0, 65535 # encoding: [0xe5,0x61,0x00,0x00,0xff,0xff]
+#CHECK: tbeginc 0(%r1), 42 # encoding: [0xe5,0x61,0x10,0x00,0x00,0x2a]
+#CHECK: tbeginc 0(%r15), 42 # encoding: [0xe5,0x61,0xf0,0x00,0x00,0x2a]
+#CHECK: tbeginc 4095(%r1), 42 # encoding: [0xe5,0x61,0x1f,0xff,0x00,0x2a]
+#CHECK: tbeginc 4095(%r15), 42 # encoding: [0xe5,0x61,0xff,0xff,0x00,0x2a]
+
+ tbeginc 0, 0
+ tbeginc 4095, 0
+ tbeginc 0, 0
+ tbeginc 0, 1
+ tbeginc 0, 32767
+ tbeginc 0, 32768
+ tbeginc 0, 65535
+ tbeginc 0(%r1), 42
+ tbeginc 0(%r15), 42
+ tbeginc 4095(%r1), 42
+ tbeginc 4095(%r15), 42
+
+#CHECK: tend # encoding: [0xb2,0xf8,0x00,0x00]
+
+ tend
Index: llvm-head/test/MC/SystemZ/insn-bad-z196.s
===================================================================
--- llvm-head.orig/test/MC/SystemZ/insn-bad-z196.s
+++ llvm-head/test/MC/SystemZ/insn-bad-z196.s
@@ -244,6 +244,11 @@
cxlgbr %f0, 16, %r0, 0
cxlgbr %f2, 0, %r0, 0
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: etnd %r7
+
+ etnd %r7
+
#CHECK: error: invalid operand
#CHECK: fidbra %f0, 0, %f0, -1
#CHECK: error: invalid operand
@@ -546,6 +551,16 @@
locr %r0,%r0,-1
locr %r0,%r0,16
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: ntstg %r0, 524287(%r1,%r15)
+
+ ntstg %r0, 524287(%r1,%r15)
+
+#CHECK: error: {{(instruction requires: processor-assist)?}}
+#CHECK: ppa %r4, %r6, 7
+
+ ppa %r4, %r6, 7
+
#CHECK: error: {{(instruction requires: miscellaneous-extensions)?}}
#CHECK: risbgn %r1, %r2, 0, 0, 0
@@ -690,3 +705,24 @@
stocg %r0,-524289,1
stocg %r0,524288,1
stocg %r0,0(%r1,%r2),1
+
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: tabort 4095(%r1)
+
+ tabort 4095(%r1)
+
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: tbegin 4095(%r1), 42
+
+ tbegin 4095(%r1), 42
+
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: tbeginc 4095(%r1), 42
+
+ tbeginc 4095(%r1), 42
+
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: tend
+
+ tend
+
Index: llvm-head/test/MC/Disassembler/SystemZ/insns.txt
===================================================================
--- llvm-head.orig/test/MC/Disassembler/SystemZ/insns.txt
+++ llvm-head/test/MC/Disassembler/SystemZ/insns.txt
@@ -2503,6 +2503,15 @@
# CHECK: ear %r15, %a15
0xb2 0x4f 0x00 0xff
+# CHECK: etnd %r0
+0xb2 0xec 0x00 0x00
+
+# CHECK: etnd %r15
+0xb2 0xec 0x00 0xf0
+
+# CHECK: etnd %r7
+0xb2 0xec 0x00 0x70
+
# CHECK: fidbr %f0, 0, %f0
0xb3 0x5f 0x00 0x00
@@ -6034,6 +6043,36 @@
# CHECK: ny %r15, 0
0xe3 0xf0 0x00 0x00 0x00 0x54
+# CHECK: ntstg %r0, -524288
+0xe3 0x00 0x00 0x00 0x80 0x25
+
+# CHECK: ntstg %r0, -1
+0xe3 0x00 0x0f 0xff 0xff 0x25
+
+# CHECK: ntstg %r0, 0
+0xe3 0x00 0x00 0x00 0x00 0x25
+
+# CHECK: ntstg %r0, 1
+0xe3 0x00 0x00 0x01 0x00 0x25
+
+# CHECK: ntstg %r0, 524287
+0xe3 0x00 0x0f 0xff 0x7f 0x25
+
+# CHECK: ntstg %r0, 0(%r1)
+0xe3 0x00 0x10 0x00 0x00 0x25
+
+# CHECK: ntstg %r0, 0(%r15)
+0xe3 0x00 0xf0 0x00 0x00 0x25
+
+# CHECK: ntstg %r0, 524287(%r1,%r15)
+0xe3 0x01 0xff 0xff 0x7f 0x25
+
+# CHECK: ntstg %r0, 524287(%r15,%r1)
+0xe3 0x0f 0x1f 0xff 0x7f 0x25
+
+# CHECK: ntstg %r15, 0
+0xe3 0xf0 0x00 0x00 0x00 0x25
+
# CHECK: oc 0(1), 0
0xd6 0x00 0x00 0x00 0x00 0x00
@@ -6346,6 +6385,21 @@
# CHECK: popcnt %r7, %r8
0xb9 0xe1 0x00 0x78
+# CHECK: ppa %r0, %r0, 0
+0xb2 0xe8 0x00 0x00
+
+# CHECK: ppa %r0, %r0, 15
+0xb2 0xe8 0xf0 0x00
+
+# CHECK: ppa %r0, %r15, 0
+0xb2 0xe8 0x00 0x0f
+
+# CHECK: ppa %r4, %r6, 7
+0xb2 0xe8 0x70 0x46
+
+# CHECK: ppa %r15, %r0, 0
+0xb2 0xe8 0x00 0xf0
+
# CHECK: risbg %r0, %r0, 0, 0, 0
0xec 0x00 0x00 0x00 0x00 0x55
@@ -8062,6 +8116,93 @@
# CHECK: sy %r15, 0
0xe3 0xf0 0x00 0x00 0x00 0x5b
+# CHECK: tabort 0
+0xb2 0xfc 0x00 0x00
+
+# CHECK: tabort 0(%r1)
+0xb2 0xfc 0x10 0x00
+
+# CHECK: tabort 0(%r15)
+0xb2 0xfc 0xf0 0x00
+
+# CHECK: tabort 4095
+0xb2 0xfc 0x0f 0xff
+
+# CHECK: tabort 4095(%r1)
+0xb2 0xfc 0x1f 0xff
+
+# CHECK: tabort 4095(%r15)
+0xb2 0xfc 0xff 0xff
+
+# CHECK: tbegin 0, 0
+0xe5 0x60 0x00 0x00 0x00 0x00
+
+# CHECK: tbegin 4095, 0
+0xe5 0x60 0x0f 0xff 0x00 0x00
+
+# CHECK: tbegin 0, 0
+0xe5 0x60 0x00 0x00 0x00 0x00
+
+# CHECK: tbegin 0, 1
+0xe5 0x60 0x00 0x00 0x00 0x01
+
+# CHECK: tbegin 0, 32767
+0xe5 0x60 0x00 0x00 0x7f 0xff
+
+# CHECK: tbegin 0, 32768
+0xe5 0x60 0x00 0x00 0x80 0x00
+
+# CHECK: tbegin 0, 65535
+0xe5 0x60 0x00 0x00 0xff 0xff
+
+# CHECK: tbegin 0(%r1), 42
+0xe5 0x60 0x10 0x00 0x00 0x2a
+
+# CHECK: tbegin 0(%r15), 42
+0xe5 0x60 0xf0 0x00 0x00 0x2a
+
+# CHECK: tbegin 4095(%r1), 42
+0xe5 0x60 0x1f 0xff 0x00 0x2a
+
+# CHECK: tbegin 4095(%r15), 42
+0xe5 0x60 0xff 0xff 0x00 0x2a
+
+# CHECK: tbeginc 0, 0
+0xe5 0x61 0x00 0x00 0x00 0x00
+
+# CHECK: tbeginc 4095, 0
+0xe5 0x61 0x0f 0xff 0x00 0x00
+
+# CHECK: tbeginc 0, 0
+0xe5 0x61 0x00 0x00 0x00 0x00
+
+# CHECK: tbeginc 0, 1
+0xe5 0x61 0x00 0x00 0x00 0x01
+
+# CHECK: tbeginc 0, 32767
+0xe5 0x61 0x00 0x00 0x7f 0xff
+
+# CHECK: tbeginc 0, 32768
+0xe5 0x61 0x00 0x00 0x80 0x00
+
+# CHECK: tbeginc 0, 65535
+0xe5 0x61 0x00 0x00 0xff 0xff
+
+# CHECK: tbeginc 0(%r1), 42
+0xe5 0x61 0x10 0x00 0x00 0x2a
+
+# CHECK: tbeginc 0(%r15), 42
+0xe5 0x61 0xf0 0x00 0x00 0x2a
+
+# CHECK: tbeginc 4095(%r1), 42
+0xe5 0x61 0x1f 0xff 0x00 0x2a
+
+# CHECK: tbeginc 4095(%r15), 42
+0xe5 0x61 0xff 0xff 0x00 0x2a
+
+# CHECK: tend
+0xb2 0xf8 0x00 0x00
+
# CHECK: tm 0, 0
0x91 0x00 0x00 0x00
llvm-svn: 233803
2015-04-01 20:51:43 +08:00
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: ntstg %r0, -524289
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: ntstg %r0, 524288
|
|
|
|
|
|
|
|
ntstg %r0, -524289
|
|
|
|
ntstg %r0, 524288
|
|
|
|
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: ppa %r0, %r0, -1
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: ppa %r0, %r0, 16
|
|
|
|
|
|
|
|
ppa %r0, %r0, -1
|
|
|
|
ppa %r0, %r0, 16
|
|
|
|
|
2015-03-31 20:58:17 +08:00
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: risbgn %r0,%r0,0,0,-1
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: risbgn %r0,%r0,0,0,64
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: risbgn %r0,%r0,0,-1,0
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: risbgn %r0,%r0,0,256,0
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: risbgn %r0,%r0,-1,0,0
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: risbgn %r0,%r0,256,0,0
|
|
|
|
|
|
|
|
risbgn %r0,%r0,0,0,-1
|
|
|
|
risbgn %r0,%r0,0,0,64
|
|
|
|
risbgn %r0,%r0,0,-1,0
|
|
|
|
risbgn %r0,%r0,0,256,0
|
|
|
|
risbgn %r0,%r0,-1,0,0
|
|
|
|
risbgn %r0,%r0,256,0,0
|
|
|
|
|
[SystemZ] Support transactional execution on zEC12
The zEC12 provides the transactional-execution facility. This is exposed
to users via a set of builtin routines on other compilers. This patch
adds LLVM support to enable those builtins. In partciular, the patch:
- adds the transactional-execution and processor-assist facilities
- adds MC support for all instructions provided by those facilities
- adds LLVM intrinsics for those instructions and hooks them up for CodeGen
- adds CodeGen support to optimize CC return value checking
Since this is first use of target-specific intrinsics on the platform,
the patch creates the include/llvm/IR/IntrinsicsSystemZ.td file and
hooks it up in Intrinsics.td. I've also changed Triple::getArchTypePrefix
to return "s390" instead of "systemz", since the naming convention for
GCC intrinsics uses "s390" on the platform, and it neemed more straight-
forward to use the same convention for LLVM IR intrinsics.
An associated clang patch makes the intrinsics (and command line switches)
available at the source-language level.
For reference, the transactional-execution instructions are documented
in the z/Architecture Principles of Operation for the zEC12:
http://publibfp.boulder.ibm.com/cgi-bin/bookmgr/download/DZ9ZR009.pdf
The associated builtins are documented in the GCC manual:
http://gcc.gnu.org/onlinedocs/gcc/S_002f390-System-z-Built-in-Functions.html
Index: llvm-head/lib/Target/SystemZ/SystemZOperators.td
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZOperators.td
+++ llvm-head/lib/Target/SystemZ/SystemZOperators.td
@@ -79,6 +79,9 @@ def SDT_ZI32Intrinsic : SDTypeProf
def SDT_ZPrefetch : SDTypeProfile<0, 2,
[SDTCisVT<0, i32>,
SDTCisPtrTy<1>]>;
+def SDT_ZTBegin : SDTypeProfile<0, 2,
+ [SDTCisPtrTy<0>,
+ SDTCisVT<1, i32>]>;
//===----------------------------------------------------------------------===//
// Node definitions
@@ -180,6 +183,15 @@ def z_prefetch : SDNode<"System
[SDNPHasChain, SDNPMayLoad, SDNPMayStore,
SDNPMemOperand]>;
+def z_tbegin : SDNode<"SystemZISD::TBEGIN", SDT_ZTBegin,
+ [SDNPHasChain, SDNPOutGlue, SDNPMayStore,
+ SDNPSideEffect]>;
+def z_tbegin_nofloat : SDNode<"SystemZISD::TBEGIN_NOFLOAT", SDT_ZTBegin,
+ [SDNPHasChain, SDNPOutGlue, SDNPMayStore,
+ SDNPSideEffect]>;
+def z_tend : SDNode<"SystemZISD::TEND", SDTNone,
+ [SDNPHasChain, SDNPOutGlue, SDNPSideEffect]>;
+
//===----------------------------------------------------------------------===//
// Pattern fragments
//===----------------------------------------------------------------------===//
Index: llvm-head/lib/Target/SystemZ/SystemZInstrFormats.td
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZInstrFormats.td
+++ llvm-head/lib/Target/SystemZ/SystemZInstrFormats.td
@@ -473,6 +473,17 @@ class InstSS<bits<8> op, dag outs, dag i
let Inst{15-0} = BD2;
}
+class InstS<bits<16> op, dag outs, dag ins, string asmstr, list<dag> pattern>
+ : InstSystemZ<4, outs, ins, asmstr, pattern> {
+ field bits<32> Inst;
+ field bits<32> SoftFail = 0;
+
+ bits<16> BD2;
+
+ let Inst{31-16} = op;
+ let Inst{15-0} = BD2;
+}
+
//===----------------------------------------------------------------------===//
// Instruction definitions with semantics
//===----------------------------------------------------------------------===//
Index: llvm-head/lib/Target/SystemZ/SystemZInstrInfo.td
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZInstrInfo.td
+++ llvm-head/lib/Target/SystemZ/SystemZInstrInfo.td
@@ -1362,6 +1362,60 @@ let Defs = [CC] in {
}
//===----------------------------------------------------------------------===//
+// Transactional execution
+//===----------------------------------------------------------------------===//
+
+let Predicates = [FeatureTransactionalExecution] in {
+ // Transaction Begin
+ let hasSideEffects = 1, mayStore = 1,
+ usesCustomInserter = 1, Defs = [CC] in {
+ def TBEGIN : InstSIL<0xE560,
+ (outs), (ins bdaddr12only:$BD1, imm32zx16:$I2),
+ "tbegin\t$BD1, $I2",
+ [(z_tbegin bdaddr12only:$BD1, imm32zx16:$I2)]>;
+ def TBEGIN_nofloat : Pseudo<(outs), (ins bdaddr12only:$BD1, imm32zx16:$I2),
+ [(z_tbegin_nofloat bdaddr12only:$BD1,
+ imm32zx16:$I2)]>;
+ def TBEGINC : InstSIL<0xE561,
+ (outs), (ins bdaddr12only:$BD1, imm32zx16:$I2),
+ "tbeginc\t$BD1, $I2",
+ [(int_s390_tbeginc bdaddr12only:$BD1,
+ imm32zx16:$I2)]>;
+ }
+
+ // Transaction End
+ let hasSideEffects = 1, Defs = [CC], BD2 = 0 in
+ def TEND : InstS<0xB2F8, (outs), (ins), "tend", [(z_tend)]>;
+
+ // Transaction Abort
+ let hasSideEffects = 1, isTerminator = 1, isBarrier = 1 in
+ def TABORT : InstS<0xB2FC, (outs), (ins bdaddr12only:$BD2),
+ "tabort\t$BD2",
+ [(int_s390_tabort bdaddr12only:$BD2)]>;
+
+ // Nontransactional Store
+ let hasSideEffects = 1 in
+ def NTSTG : StoreRXY<"ntstg", 0xE325, int_s390_ntstg, GR64, 8>;
+
+ // Extract Transaction Nesting Depth
+ let hasSideEffects = 1 in
+ def ETND : InherentRRE<"etnd", 0xB2EC, GR32, (int_s390_etnd)>;
+}
+
+//===----------------------------------------------------------------------===//
+// Processor assist
+//===----------------------------------------------------------------------===//
+
+let Predicates = [FeatureProcessorAssist] in {
+ let hasSideEffects = 1, R4 = 0 in
+ def PPA : InstRRF<0xB2E8, (outs), (ins GR64:$R1, GR64:$R2, imm32zx4:$R3),
+ "ppa\t$R1, $R2, $R3", []>;
+ def : Pat<(int_s390_ppa_txassist GR32:$src),
+ (PPA (INSERT_SUBREG (i64 (IMPLICIT_DEF)), GR32:$src, subreg_l32),
+ 0, 1)>;
+}
+
+//===----------------------------------------------------------------------===//
// Miscellaneous Instructions.
//===----------------------------------------------------------------------===//
Index: llvm-head/lib/Target/SystemZ/SystemZProcessors.td
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZProcessors.td
+++ llvm-head/lib/Target/SystemZ/SystemZProcessors.td
@@ -60,6 +60,16 @@ def FeatureMiscellaneousExtensions : Sys
"Assume that the miscellaneous-extensions facility is installed"
>;
+def FeatureTransactionalExecution : SystemZFeature<
+ "transactional-execution", "TransactionalExecution",
+ "Assume that the transactional-execution facility is installed"
+>;
+
+def FeatureProcessorAssist : SystemZFeature<
+ "processor-assist", "ProcessorAssist",
+ "Assume that the processor-assist facility is installed"
+>;
+
def : Processor<"generic", NoItineraries, []>;
def : Processor<"z10", NoItineraries, []>;
def : Processor<"z196", NoItineraries,
@@ -70,4 +80,5 @@ def : Processor<"zEC12", NoItineraries,
[FeatureDistinctOps, FeatureLoadStoreOnCond, FeatureHighWord,
FeatureFPExtension, FeaturePopulationCount,
FeatureFastSerialization, FeatureInterlockedAccess1,
- FeatureMiscellaneousExtensions]>;
+ FeatureMiscellaneousExtensions,
+ FeatureTransactionalExecution, FeatureProcessorAssist]>;
Index: llvm-head/lib/Target/SystemZ/SystemZSubtarget.cpp
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZSubtarget.cpp
+++ llvm-head/lib/Target/SystemZ/SystemZSubtarget.cpp
@@ -40,6 +40,7 @@ SystemZSubtarget::SystemZSubtarget(const
HasLoadStoreOnCond(false), HasHighWord(false), HasFPExtension(false),
HasPopulationCount(false), HasFastSerialization(false),
HasInterlockedAccess1(false), HasMiscellaneousExtensions(false),
+ HasTransactionalExecution(false), HasProcessorAssist(false),
TargetTriple(TT), InstrInfo(initializeSubtargetDependencies(CPU, FS)),
TLInfo(TM, *this), TSInfo(*TM.getDataLayout()), FrameLowering() {}
Index: llvm-head/lib/Target/SystemZ/SystemZSubtarget.h
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZSubtarget.h
+++ llvm-head/lib/Target/SystemZ/SystemZSubtarget.h
@@ -42,6 +42,8 @@ protected:
bool HasFastSerialization;
bool HasInterlockedAccess1;
bool HasMiscellaneousExtensions;
+ bool HasTransactionalExecution;
+ bool HasProcessorAssist;
private:
Triple TargetTriple;
@@ -102,6 +104,12 @@ public:
return HasMiscellaneousExtensions;
}
+ // Return true if the target has the transactional-execution facility.
+ bool hasTransactionalExecution() const { return HasTransactionalExecution; }
+
+ // Return true if the target has the processor-assist facility.
+ bool hasProcessorAssist() const { return HasProcessorAssist; }
+
// Return true if GV can be accessed using LARL for reloc model RM
// and code model CM.
bool isPC32DBLSymbol(const GlobalValue *GV, Reloc::Model RM,
Index: llvm-head/lib/Support/Triple.cpp
===================================================================
--- llvm-head.orig/lib/Support/Triple.cpp
+++ llvm-head/lib/Support/Triple.cpp
@@ -92,7 +92,7 @@ const char *Triple::getArchTypePrefix(Ar
case sparcv9:
case sparc: return "sparc";
- case systemz: return "systemz";
+ case systemz: return "s390";
case x86:
case x86_64: return "x86";
Index: llvm-head/include/llvm/IR/Intrinsics.td
===================================================================
--- llvm-head.orig/include/llvm/IR/Intrinsics.td
+++ llvm-head/include/llvm/IR/Intrinsics.td
@@ -634,3 +634,4 @@ include "llvm/IR/IntrinsicsNVVM.td"
include "llvm/IR/IntrinsicsMips.td"
include "llvm/IR/IntrinsicsR600.td"
include "llvm/IR/IntrinsicsBPF.td"
+include "llvm/IR/IntrinsicsSystemZ.td"
Index: llvm-head/include/llvm/IR/IntrinsicsSystemZ.td
===================================================================
--- /dev/null
+++ llvm-head/include/llvm/IR/IntrinsicsSystemZ.td
@@ -0,0 +1,46 @@
+//===- IntrinsicsSystemZ.td - Defines SystemZ intrinsics ---*- tablegen -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file defines all of the SystemZ-specific intrinsics.
+//
+//===----------------------------------------------------------------------===//
+
+//===----------------------------------------------------------------------===//
+//
+// Transactional-execution intrinsics
+//
+//===----------------------------------------------------------------------===//
+
+let TargetPrefix = "s390" in {
+ def int_s390_tbegin : Intrinsic<[llvm_i32_ty], [llvm_ptr_ty, llvm_i32_ty],
+ [IntrNoDuplicate]>;
+
+ def int_s390_tbegin_nofloat : Intrinsic<[llvm_i32_ty],
+ [llvm_ptr_ty, llvm_i32_ty],
+ [IntrNoDuplicate]>;
+
+ def int_s390_tbeginc : Intrinsic<[], [llvm_ptr_ty, llvm_i32_ty],
+ [IntrNoDuplicate]>;
+
+ def int_s390_tabort : Intrinsic<[], [llvm_i64_ty],
+ [IntrNoReturn, Throws]>;
+
+ def int_s390_tend : GCCBuiltin<"__builtin_tend">,
+ Intrinsic<[llvm_i32_ty], []>;
+
+ def int_s390_etnd : GCCBuiltin<"__builtin_tx_nesting_depth">,
+ Intrinsic<[llvm_i32_ty], [], [IntrNoMem]>;
+
+ def int_s390_ntstg : Intrinsic<[], [llvm_i64_ty, llvm_ptr64_ty],
+ [IntrReadWriteArgMem]>;
+
+ def int_s390_ppa_txassist : GCCBuiltin<"__builtin_tx_assist">,
+ Intrinsic<[], [llvm_i32_ty]>;
+}
+
Index: llvm-head/lib/Target/SystemZ/SystemZ.h
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZ.h
+++ llvm-head/lib/Target/SystemZ/SystemZ.h
@@ -68,6 +68,18 @@ const unsigned CCMASK_TM_MSB_0 = C
const unsigned CCMASK_TM_MSB_1 = CCMASK_2 | CCMASK_3;
const unsigned CCMASK_TM = CCMASK_ANY;
+// Condition-code mask assignments for TRANSACTION_BEGIN.
+const unsigned CCMASK_TBEGIN_STARTED = CCMASK_0;
+const unsigned CCMASK_TBEGIN_INDETERMINATE = CCMASK_1;
+const unsigned CCMASK_TBEGIN_TRANSIENT = CCMASK_2;
+const unsigned CCMASK_TBEGIN_PERSISTENT = CCMASK_3;
+const unsigned CCMASK_TBEGIN = CCMASK_ANY;
+
+// Condition-code mask assignments for TRANSACTION_END.
+const unsigned CCMASK_TEND_TX = CCMASK_0;
+const unsigned CCMASK_TEND_NOTX = CCMASK_2;
+const unsigned CCMASK_TEND = CCMASK_TEND_TX | CCMASK_TEND_NOTX;
+
// The position of the low CC bit in an IPM result.
const unsigned IPM_CC = 28;
Index: llvm-head/lib/Target/SystemZ/SystemZISelLowering.h
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZISelLowering.h
+++ llvm-head/lib/Target/SystemZ/SystemZISelLowering.h
@@ -146,6 +146,15 @@ enum {
// Perform a serialization operation. (BCR 15,0 or BCR 14,0.)
SERIALIZE,
+ // Transaction begin. The first operand is the chain, the second
+ // the TDB pointer, and the third the immediate control field.
+ // Returns chain and glue.
+ TBEGIN,
+ TBEGIN_NOFLOAT,
+
+ // Transaction end. Just the chain operand. Returns chain and glue.
+ TEND,
+
// Wrappers around the inner loop of an 8- or 16-bit ATOMIC_SWAP or
// ATOMIC_LOAD_<op>.
//
@@ -318,6 +327,7 @@ private:
SDValue lowerSTACKSAVE(SDValue Op, SelectionDAG &DAG) const;
SDValue lowerSTACKRESTORE(SDValue Op, SelectionDAG &DAG) const;
SDValue lowerPREFETCH(SDValue Op, SelectionDAG &DAG) const;
+ SDValue lowerINTRINSIC_W_CHAIN(SDValue Op, SelectionDAG &DAG) const;
// If the last instruction before MBBI in MBB was some form of COMPARE,
// try to replace it with a COMPARE AND BRANCH just before MBBI.
@@ -355,6 +365,10 @@ private:
MachineBasicBlock *emitStringWrapper(MachineInstr *MI,
MachineBasicBlock *BB,
unsigned Opcode) const;
+ MachineBasicBlock *emitTransactionBegin(MachineInstr *MI,
+ MachineBasicBlock *MBB,
+ unsigned Opcode,
+ bool NoFloat) const;
};
} // end namespace llvm
Index: llvm-head/lib/Target/SystemZ/SystemZISelLowering.cpp
===================================================================
--- llvm-head.orig/lib/Target/SystemZ/SystemZISelLowering.cpp
+++ llvm-head/lib/Target/SystemZ/SystemZISelLowering.cpp
@@ -20,6 +20,7 @@
#include "llvm/CodeGen/MachineInstrBuilder.h"
#include "llvm/CodeGen/MachineRegisterInfo.h"
#include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
+#include "llvm/IR/Intrinsics.h"
#include <cctype>
using namespace llvm;
@@ -304,6 +305,9 @@ SystemZTargetLowering::SystemZTargetLowe
// Codes for which we want to perform some z-specific combinations.
setTargetDAGCombine(ISD::SIGN_EXTEND);
+ // Handle intrinsics.
+ setOperationAction(ISD::INTRINSIC_W_CHAIN, MVT::Other, Custom);
+
// We want to use MVC in preference to even a single load/store pair.
MaxStoresPerMemcpy = 0;
MaxStoresPerMemcpyOptSize = 0;
@@ -1031,6 +1035,53 @@ prepareVolatileOrAtomicLoad(SDValue Chai
return DAG.getNode(SystemZISD::SERIALIZE, DL, MVT::Other, Chain);
}
+// Return true if Op is an intrinsic node with chain that returns the CC value
+// as its only (other) argument. Provide the associated SystemZISD opcode and
+// the mask of valid CC values if so.
+static bool isIntrinsicWithCCAndChain(SDValue Op, unsigned &Opcode,
+ unsigned &CCValid) {
+ unsigned Id = cast<ConstantSDNode>(Op.getOperand(1))->getZExtValue();
+ switch (Id) {
+ case Intrinsic::s390_tbegin:
+ Opcode = SystemZISD::TBEGIN;
+ CCValid = SystemZ::CCMASK_TBEGIN;
+ return true;
+
+ case Intrinsic::s390_tbegin_nofloat:
+ Opcode = SystemZISD::TBEGIN_NOFLOAT;
+ CCValid = SystemZ::CCMASK_TBEGIN;
+ return true;
+
+ case Intrinsic::s390_tend:
+ Opcode = SystemZISD::TEND;
+ CCValid = SystemZ::CCMASK_TEND;
+ return true;
+
+ default:
+ return false;
+ }
+}
+
+// Emit an intrinsic with chain with a glued value instead of its CC result.
+static SDValue emitIntrinsicWithChainAndGlue(SelectionDAG &DAG, SDValue Op,
+ unsigned Opcode) {
+ // Copy all operands except the intrinsic ID.
+ unsigned NumOps = Op.getNumOperands();
+ SmallVector<SDValue, 6> Ops;
+ Ops.reserve(NumOps - 1);
+ Ops.push_back(Op.getOperand(0));
+ for (unsigned I = 2; I < NumOps; ++I)
+ Ops.push_back(Op.getOperand(I));
+
+ assert(Op->getNumValues() == 2 && "Expected only CC result and chain");
+ SDVTList RawVTs = DAG.getVTList(MVT::Other, MVT::Glue);
+ SDValue Intr = DAG.getNode(Opcode, SDLoc(Op), RawVTs, Ops);
+ SDValue OldChain = SDValue(Op.getNode(), 1);
+ SDValue NewChain = SDValue(Intr.getNode(), 0);
+ DAG.ReplaceAllUsesOfValueWith(OldChain, NewChain);
+ return Intr;
+}
+
// CC is a comparison that will be implemented using an integer or
// floating-point comparison. Return the condition code mask for
// a branch on true. In the integer case, CCMASK_CMP_UO is set for
@@ -1588,9 +1639,53 @@ static void adjustForTestUnderMask(Selec
C.CCMask = NewCCMask;
}
+// Return a Comparison that tests the condition-code result of intrinsic
+// node Call against constant integer CC using comparison code Cond.
+// Opcode is the opcode of the SystemZISD operation for the intrinsic
+// and CCValid is the set of possible condition-code results.
+static Comparison getIntrinsicCmp(SelectionDAG &DAG, unsigned Opcode,
+ SDValue Call, unsigned CCValid, uint64_t CC,
+ ISD::CondCode Cond) {
+ Comparison C(Call, SDValue());
+ C.Opcode = Opcode;
+ C.CCValid = CCValid;
+ if (Cond == ISD::SETEQ)
+ // bit 3 for CC==0, bit 0 for CC==3, always false for CC>3.
+ C.CCMask = CC < 4 ? 1 << (3 - CC) : 0;
+ else if (Cond == ISD::SETNE)
+ // ...and the inverse of that.
+ C.CCMask = CC < 4 ? ~(1 << (3 - CC)) : -1;
+ else if (Cond == ISD::SETLT || Cond == ISD::SETULT)
+ // bits above bit 3 for CC==0 (always false), bits above bit 0 for CC==3,
+ // always true for CC>3.
+ C.CCMask = CC < 4 ? -1 << (4 - CC) : -1;
+ else if (Cond == ISD::SETGE || Cond == ISD::SETUGE)
+ // ...and the inverse of that.
+ C.CCMask = CC < 4 ? ~(-1 << (4 - CC)) : 0;
+ else if (Cond == ISD::SETLE || Cond == ISD::SETULE)
+ // bit 3 and above for CC==0, bit 0 and above for CC==3 (always true),
+ // always true for CC>3.
+ C.CCMask = CC < 4 ? -1 << (3 - CC) : -1;
+ else if (Cond == ISD::SETGT || Cond == ISD::SETUGT)
+ // ...and the inverse of that.
+ C.CCMask = CC < 4 ? ~(-1 << (3 - CC)) : 0;
+ else
+ llvm_unreachable("Unexpected integer comparison type");
+ C.CCMask &= CCValid;
+ return C;
+}
+
// Decide how to implement a comparison of type Cond between CmpOp0 with CmpOp1.
static Comparison getCmp(SelectionDAG &DAG, SDValue CmpOp0, SDValue CmpOp1,
ISD::CondCode Cond) {
+ if (CmpOp1.getOpcode() == ISD::Constant) {
+ uint64_t Constant = cast<ConstantSDNode>(CmpOp1)->getZExtValue();
+ unsigned Opcode, CCValid;
+ if (CmpOp0.getOpcode() == ISD::INTRINSIC_W_CHAIN &&
+ CmpOp0.getResNo() == 0 && CmpOp0->hasNUsesOfValue(1, 0) &&
+ isIntrinsicWithCCAndChain(CmpOp0, Opcode, CCValid))
+ return getIntrinsicCmp(DAG, Opcode, CmpOp0, CCValid, Constant, Cond);
+ }
Comparison C(CmpOp0, CmpOp1);
C.CCMask = CCMaskForCondCode(Cond);
if (C.Op0.getValueType().isFloatingPoint()) {
@@ -1632,6 +1727,17 @@ static Comparison getCmp(SelectionDAG &D
// Emit the comparison instruction described by C.
static SDValue emitCmp(SelectionDAG &DAG, SDLoc DL, Comparison &C) {
+ if (!C.Op1.getNode()) {
+ SDValue Op;
+ switch (C.Op0.getOpcode()) {
+ case ISD::INTRINSIC_W_CHAIN:
+ Op = emitIntrinsicWithChainAndGlue(DAG, C.Op0, C.Opcode);
+ break;
+ default:
+ llvm_unreachable("Invalid comparison operands");
+ }
+ return SDValue(Op.getNode(), Op->getNumValues() - 1);
+ }
if (C.Opcode == SystemZISD::ICMP)
return DAG.getNode(SystemZISD::ICMP, DL, MVT::Glue, C.Op0, C.Op1,
DAG.getConstant(C.ICmpType, MVT::i32));
@@ -1713,7 +1819,6 @@ SDValue SystemZTargetLowering::lowerSETC
}
SDValue SystemZTargetLowering::lowerBR_CC(SDValue Op, SelectionDAG &DAG) const {
- SDValue Chain = Op.getOperand(0);
ISD::CondCode CC = cast<CondCodeSDNode>(Op.getOperand(1))->get();
SDValue CmpOp0 = Op.getOperand(2);
SDValue CmpOp1 = Op.getOperand(3);
@@ -1723,7 +1828,7 @@ SDValue SystemZTargetLowering::lowerBR_C
Comparison C(getCmp(DAG, CmpOp0, CmpOp1, CC));
SDValue Glue = emitCmp(DAG, DL, C);
return DAG.getNode(SystemZISD::BR_CCMASK, DL, Op.getValueType(),
- Chain, DAG.getConstant(C.CCValid, MVT::i32),
+ Op.getOperand(0), DAG.getConstant(C.CCValid, MVT::i32),
DAG.getConstant(C.CCMask, MVT::i32), Dest, Glue);
}
@@ -2561,6 +2666,30 @@ SDValue SystemZTargetLowering::lowerPREF
Node->getMemoryVT(), Node->getMemOperand());
}
+// Return an i32 that contains the value of CC immediately after After,
+// whose final operand must be MVT::Glue.
+static SDValue getCCResult(SelectionDAG &DAG, SDNode *After) {
+ SDValue Glue = SDValue(After, After->getNumValues() - 1);
+ SDValue IPM = DAG.getNode(SystemZISD::IPM, SDLoc(After), MVT::i32, Glue);
+ return DAG.getNode(ISD::SRL, SDLoc(After), MVT::i32, IPM,
+ DAG.getConstant(SystemZ::IPM_CC, MVT::i32));
+}
+
+SDValue
+SystemZTargetLowering::lowerINTRINSIC_W_CHAIN(SDValue Op,
+ SelectionDAG &DAG) const {
+ unsigned Opcode, CCValid;
+ if (isIntrinsicWithCCAndChain(Op, Opcode, CCValid)) {
+ assert(Op->getNumValues() == 2 && "Expected only CC result and chain");
+ SDValue Glued = emitIntrinsicWithChainAndGlue(DAG, Op, Opcode);
+ SDValue CC = getCCResult(DAG, Glued.getNode());
+ DAG.ReplaceAllUsesOfValueWith(SDValue(Op.getNode(), 0), CC);
+ return SDValue();
+ }
+
+ return SDValue();
+}
+
SDValue SystemZTargetLowering::LowerOperation(SDValue Op,
SelectionDAG &DAG) const {
switch (Op.getOpcode()) {
@@ -2634,6 +2763,8 @@ SDValue SystemZTargetLowering::LowerOper
return lowerSTACKRESTORE(Op, DAG);
case ISD::PREFETCH:
return lowerPREFETCH(Op, DAG);
+ case ISD::INTRINSIC_W_CHAIN:
+ return lowerINTRINSIC_W_CHAIN(Op, DAG);
default:
llvm_unreachable("Unexpected node to lower");
}
@@ -2674,6 +2805,9 @@ const char *SystemZTargetLowering::getTa
OPCODE(SEARCH_STRING);
OPCODE(IPM);
OPCODE(SERIALIZE);
+ OPCODE(TBEGIN);
+ OPCODE(TBEGIN_NOFLOAT);
+ OPCODE(TEND);
OPCODE(ATOMIC_SWAPW);
OPCODE(ATOMIC_LOADW_ADD);
OPCODE(ATOMIC_LOADW_SUB);
@@ -3501,6 +3635,50 @@ SystemZTargetLowering::emitStringWrapper
return DoneMBB;
}
+// Update TBEGIN instruction with final opcode and register clobbers.
+MachineBasicBlock *
+SystemZTargetLowering::emitTransactionBegin(MachineInstr *MI,
+ MachineBasicBlock *MBB,
+ unsigned Opcode,
+ bool NoFloat) const {
+ MachineFunction &MF = *MBB->getParent();
+ const TargetFrameLowering *TFI = Subtarget.getFrameLowering();
+ const SystemZInstrInfo *TII = Subtarget.getInstrInfo();
+
+ // Update opcode.
+ MI->setDesc(TII->get(Opcode));
+
+ // We cannot handle a TBEGIN that clobbers the stack or frame pointer.
+ // Make sure to add the corresponding GRSM bits if they are missing.
+ uint64_t Control = MI->getOperand(2).getImm();
+ static const unsigned GPRControlBit[16] = {
+ 0x8000, 0x8000, 0x4000, 0x4000, 0x2000, 0x2000, 0x1000, 0x1000,
+ 0x0800, 0x0800, 0x0400, 0x0400, 0x0200, 0x0200, 0x0100, 0x0100
+ };
+ Control |= GPRControlBit[15];
+ if (TFI->hasFP(MF))
+ Control |= GPRControlBit[11];
+ MI->getOperand(2).setImm(Control);
+
+ // Add GPR clobbers.
+ for (int I = 0; I < 16; I++) {
+ if ((Control & GPRControlBit[I]) == 0) {
+ unsigned Reg = SystemZMC::GR64Regs[I];
+ MI->addOperand(MachineOperand::CreateReg(Reg, true, true));
+ }
+ }
+
+ // Add FPR clobbers.
+ if (!NoFloat && (Control & 4) != 0) {
+ for (int I = 0; I < 16; I++) {
+ unsigned Reg = SystemZMC::FP64Regs[I];
+ MI->addOperand(MachineOperand::CreateReg(Reg, true, true));
+ }
+ }
+
+ return MBB;
+}
+
MachineBasicBlock *SystemZTargetLowering::
EmitInstrWithCustomInserter(MachineInstr *MI, MachineBasicBlock *MBB) const {
switch (MI->getOpcode()) {
@@ -3742,6 +3920,12 @@ EmitInstrWithCustomInserter(MachineInstr
return emitStringWrapper(MI, MBB, SystemZ::MVST);
case SystemZ::SRSTLoop:
return emitStringWrapper(MI, MBB, SystemZ::SRST);
+ case SystemZ::TBEGIN:
+ return emitTransactionBegin(MI, MBB, SystemZ::TBEGIN, false);
+ case SystemZ::TBEGIN_nofloat:
+ return emitTransactionBegin(MI, MBB, SystemZ::TBEGIN, true);
+ case SystemZ::TBEGINC:
+ return emitTransactionBegin(MI, MBB, SystemZ::TBEGINC, true);
default:
llvm_unreachable("Unexpected instr type to insert");
}
Index: llvm-head/test/CodeGen/SystemZ/htm-intrinsics.ll
===================================================================
--- /dev/null
+++ llvm-head/test/CodeGen/SystemZ/htm-intrinsics.ll
@@ -0,0 +1,352 @@
+; Test transactional-execution intrinsics.
+;
+; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=zEC12 | FileCheck %s
+
+declare i32 @llvm.s390.tbegin(i8 *, i32)
+declare i32 @llvm.s390.tbegin.nofloat(i8 *, i32)
+declare void @llvm.s390.tbeginc(i8 *, i32)
+declare i32 @llvm.s390.tend()
+declare void @llvm.s390.tabort(i64)
+declare void @llvm.s390.ntstg(i64, i64 *)
+declare i32 @llvm.s390.etnd()
+declare void @llvm.s390.ppa.txassist(i32)
+
+; TBEGIN.
+define void @test_tbegin() {
+; CHECK-LABEL: test_tbegin:
+; CHECK-NOT: stmg
+; CHECK: std %f8,
+; CHECK: std %f9,
+; CHECK: std %f10,
+; CHECK: std %f11,
+; CHECK: std %f12,
+; CHECK: std %f13,
+; CHECK: std %f14,
+; CHECK: std %f15,
+; CHECK: tbegin 0, 65292
+; CHECK: ld %f8,
+; CHECK: ld %f9,
+; CHECK: ld %f10,
+; CHECK: ld %f11,
+; CHECK: ld %f12,
+; CHECK: ld %f13,
+; CHECK: ld %f14,
+; CHECK: ld %f15,
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin(i8 *null, i32 65292)
+ ret void
+}
+
+; TBEGIN (nofloat).
+define void @test_tbegin_nofloat1() {
+; CHECK-LABEL: test_tbegin_nofloat1:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65292
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65292)
+ ret void
+}
+
+; TBEGIN (nofloat) with integer CC return value.
+define i32 @test_tbegin_nofloat2() {
+; CHECK-LABEL: test_tbegin_nofloat2:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65292
+; CHECK: ipm %r2
+; CHECK: srl %r2, 28
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65292)
+ ret i32 %res
+}
+
+; TBEGIN (nofloat) with implicit CC check.
+define void @test_tbegin_nofloat3(i32 *%ptr) {
+; CHECK-LABEL: test_tbegin_nofloat3:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65292
+; CHECK: jnh {{\.L*}}
+; CHECK: mvhi 0(%r2), 0
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65292)
+ %cmp = icmp eq i32 %res, 2
+ br i1 %cmp, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ store i32 0, i32* %ptr, align 4
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ ret void
+}
+
+; TBEGIN (nofloat) with dual CC use.
+define i32 @test_tbegin_nofloat4(i32 %pad, i32 *%ptr) {
+; CHECK-LABEL: test_tbegin_nofloat4:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65292
+; CHECK: ipm %r2
+; CHECK: srl %r2, 28
+; CHECK: cijlh %r2, 2, {{\.L*}}
+; CHECK: mvhi 0(%r3), 0
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65292)
+ %cmp = icmp eq i32 %res, 2
+ br i1 %cmp, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ store i32 0, i32* %ptr, align 4
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ ret i32 %res
+}
+
+; TBEGIN (nofloat) with register.
+define void @test_tbegin_nofloat5(i8 *%ptr) {
+; CHECK-LABEL: test_tbegin_nofloat5:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0(%r2), 65292
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *%ptr, i32 65292)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0x0f00.
+define void @test_tbegin_nofloat6() {
+; CHECK-LABEL: test_tbegin_nofloat6:
+; CHECK: stmg %r6, %r15,
+; CHECK-NOT: std
+; CHECK: tbegin 0, 3840
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 3840)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0xf100.
+define void @test_tbegin_nofloat7() {
+; CHECK-LABEL: test_tbegin_nofloat7:
+; CHECK: stmg %r8, %r15,
+; CHECK-NOT: std
+; CHECK: tbegin 0, 61696
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 61696)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0xfe00 -- stack pointer added automatically.
+define void @test_tbegin_nofloat8() {
+; CHECK-LABEL: test_tbegin_nofloat8:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65280
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 65024)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0xfb00 -- no frame pointer needed.
+define void @test_tbegin_nofloat9() {
+; CHECK-LABEL: test_tbegin_nofloat9:
+; CHECK: stmg %r10, %r15,
+; CHECK-NOT: std
+; CHECK: tbegin 0, 64256
+; CHECK: br %r14
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 64256)
+ ret void
+}
+
+; TBEGIN (nofloat) with GRSM 0xfb00 -- frame pointer added automatically.
+define void @test_tbegin_nofloat10(i64 %n) {
+; CHECK-LABEL: test_tbegin_nofloat10:
+; CHECK: stmg %r11, %r15,
+; CHECK-NOT: std
+; CHECK: tbegin 0, 65280
+; CHECK: br %r14
+ %buf = alloca i8, i64 %n
+ call i32 @llvm.s390.tbegin.nofloat(i8 *null, i32 64256)
+ ret void
+}
+
+; TBEGINC.
+define void @test_tbeginc() {
+; CHECK-LABEL: test_tbeginc:
+; CHECK-NOT: stmg
+; CHECK-NOT: std
+; CHECK: tbeginc 0, 65288
+; CHECK: br %r14
+ call void @llvm.s390.tbeginc(i8 *null, i32 65288)
+ ret void
+}
+
+; TEND with integer CC return value.
+define i32 @test_tend1() {
+; CHECK-LABEL: test_tend1:
+; CHECK: tend
+; CHECK: ipm %r2
+; CHECK: srl %r2, 28
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tend()
+ ret i32 %res
+}
+
+; TEND with implicit CC check.
+define void @test_tend3(i32 *%ptr) {
+; CHECK-LABEL: test_tend3:
+; CHECK: tend
+; CHECK: je {{\.L*}}
+; CHECK: mvhi 0(%r2), 0
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tend()
+ %cmp = icmp eq i32 %res, 2
+ br i1 %cmp, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ store i32 0, i32* %ptr, align 4
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ ret void
+}
+
+; TEND with dual CC use.
+define i32 @test_tend2(i32 %pad, i32 *%ptr) {
+; CHECK-LABEL: test_tend2:
+; CHECK: tend
+; CHECK: ipm %r2
+; CHECK: srl %r2, 28
+; CHECK: cijlh %r2, 2, {{\.L*}}
+; CHECK: mvhi 0(%r3), 0
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.tend()
+ %cmp = icmp eq i32 %res, 2
+ br i1 %cmp, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ store i32 0, i32* %ptr, align 4
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ ret i32 %res
+}
+
+; TABORT with register only.
+define void @test_tabort1(i64 %val) {
+; CHECK-LABEL: test_tabort1:
+; CHECK: tabort 0(%r2)
+; CHECK: br %r14
+ call void @llvm.s390.tabort(i64 %val)
+ ret void
+}
+
+; TABORT with immediate only.
+define void @test_tabort2(i64 %val) {
+; CHECK-LABEL: test_tabort2:
+; CHECK: tabort 1234
+; CHECK: br %r14
+ call void @llvm.s390.tabort(i64 1234)
+ ret void
+}
+
+; TABORT with register + immediate.
+define void @test_tabort3(i64 %val) {
+; CHECK-LABEL: test_tabort3:
+; CHECK: tabort 1234(%r2)
+; CHECK: br %r14
+ %sum = add i64 %val, 1234
+ call void @llvm.s390.tabort(i64 %sum)
+ ret void
+}
+
+; TABORT with out-of-range immediate.
+define void @test_tabort4(i64 %val) {
+; CHECK-LABEL: test_tabort4:
+; CHECK: tabort 0({{%r[1-5]}})
+; CHECK: br %r14
+ call void @llvm.s390.tabort(i64 4096)
+ ret void
+}
+
+; NTSTG with base pointer only.
+define void @test_ntstg1(i64 *%ptr, i64 %val) {
+; CHECK-LABEL: test_ntstg1:
+; CHECK: ntstg %r3, 0(%r2)
+; CHECK: br %r14
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with base and index.
+; Check that VSTL doesn't allow an index.
+define void @test_ntstg2(i64 *%base, i64 %index, i64 %val) {
+; CHECK-LABEL: test_ntstg2:
+; CHECK: sllg [[REG:%r[1-5]]], %r3, 3
+; CHECK: ntstg %r4, 0([[REG]],%r2)
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 %index
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with the highest in-range displacement.
+define void @test_ntstg3(i64 *%base, i64 %val) {
+; CHECK-LABEL: test_ntstg3:
+; CHECK: ntstg %r3, 524280(%r2)
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 65535
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with an out-of-range positive displacement.
+define void @test_ntstg4(i64 *%base, i64 %val) {
+; CHECK-LABEL: test_ntstg4:
+; CHECK: ntstg %r3, 0({{%r[1-5]}})
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 65536
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with the lowest in-range displacement.
+define void @test_ntstg5(i64 *%base, i64 %val) {
+; CHECK-LABEL: test_ntstg5:
+; CHECK: ntstg %r3, -524288(%r2)
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 -65536
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; NTSTG with an out-of-range negative displacement.
+define void @test_ntstg6(i64 *%base, i64 %val) {
+; CHECK-LABEL: test_ntstg6:
+; CHECK: ntstg %r3, 0({{%r[1-5]}})
+; CHECK: br %r14
+ %ptr = getelementptr i64, i64 *%base, i64 -65537
+ call void @llvm.s390.ntstg(i64 %val, i64 *%ptr)
+ ret void
+}
+
+; ETND.
+define i32 @test_etnd() {
+; CHECK-LABEL: test_etnd:
+; CHECK: etnd %r2
+; CHECK: br %r14
+ %res = call i32 @llvm.s390.etnd()
+ ret i32 %res
+}
+
+; PPA (Transaction-Abort Assist)
+define void @test_ppa_txassist(i32 %val) {
+; CHECK-LABEL: test_ppa_txassist:
+; CHECK: ppa %r2, 0, 1
+; CHECK: br %r14
+ call void @llvm.s390.ppa.txassist(i32 %val)
+ ret void
+}
+
Index: llvm-head/test/MC/SystemZ/insn-bad-zEC12.s
===================================================================
--- llvm-head.orig/test/MC/SystemZ/insn-bad-zEC12.s
+++ llvm-head/test/MC/SystemZ/insn-bad-zEC12.s
@@ -3,6 +3,22 @@
# RUN: FileCheck < %t %s
#CHECK: error: invalid operand
+#CHECK: ntstg %r0, -524289
+#CHECK: error: invalid operand
+#CHECK: ntstg %r0, 524288
+
+ ntstg %r0, -524289
+ ntstg %r0, 524288
+
+#CHECK: error: invalid operand
+#CHECK: ppa %r0, %r0, -1
+#CHECK: error: invalid operand
+#CHECK: ppa %r0, %r0, 16
+
+ ppa %r0, %r0, -1
+ ppa %r0, %r0, 16
+
+#CHECK: error: invalid operand
#CHECK: risbgn %r0,%r0,0,0,-1
#CHECK: error: invalid operand
#CHECK: risbgn %r0,%r0,0,0,64
@@ -22,3 +38,47 @@
risbgn %r0,%r0,-1,0,0
risbgn %r0,%r0,256,0,0
+#CHECK: error: invalid operand
+#CHECK: tabort -1
+#CHECK: error: invalid operand
+#CHECK: tabort 4096
+#CHECK: error: invalid use of indexed addressing
+#CHECK: tabort 0(%r1,%r2)
+
+ tabort -1
+ tabort 4096
+ tabort 0(%r1,%r2)
+
+#CHECK: error: invalid operand
+#CHECK: tbegin -1, 0
+#CHECK: error: invalid operand
+#CHECK: tbegin 4096, 0
+#CHECK: error: invalid use of indexed addressing
+#CHECK: tbegin 0(%r1,%r2), 0
+#CHECK: error: invalid operand
+#CHECK: tbegin 0, -1
+#CHECK: error: invalid operand
+#CHECK: tbegin 0, 65536
+
+ tbegin -1, 0
+ tbegin 4096, 0
+ tbegin 0(%r1,%r2), 0
+ tbegin 0, -1
+ tbegin 0, 65536
+
+#CHECK: error: invalid operand
+#CHECK: tbeginc -1, 0
+#CHECK: error: invalid operand
+#CHECK: tbeginc 4096, 0
+#CHECK: error: invalid use of indexed addressing
+#CHECK: tbeginc 0(%r1,%r2), 0
+#CHECK: error: invalid operand
+#CHECK: tbeginc 0, -1
+#CHECK: error: invalid operand
+#CHECK: tbeginc 0, 65536
+
+ tbeginc -1, 0
+ tbeginc 4096, 0
+ tbeginc 0(%r1,%r2), 0
+ tbeginc 0, -1
+ tbeginc 0, 65536
Index: llvm-head/test/MC/SystemZ/insn-good-zEC12.s
===================================================================
--- llvm-head.orig/test/MC/SystemZ/insn-good-zEC12.s
+++ llvm-head/test/MC/SystemZ/insn-good-zEC12.s
@@ -1,6 +1,48 @@
# For zEC12 and above.
# RUN: llvm-mc -triple s390x-linux-gnu -mcpu=zEC12 -show-encoding %s | FileCheck %s
+#CHECK: etnd %r0 # encoding: [0xb2,0xec,0x00,0x00]
+#CHECK: etnd %r15 # encoding: [0xb2,0xec,0x00,0xf0]
+#CHECK: etnd %r7 # encoding: [0xb2,0xec,0x00,0x70]
+
+ etnd %r0
+ etnd %r15
+ etnd %r7
+
+#CHECK: ntstg %r0, -524288 # encoding: [0xe3,0x00,0x00,0x00,0x80,0x25]
+#CHECK: ntstg %r0, -1 # encoding: [0xe3,0x00,0x0f,0xff,0xff,0x25]
+#CHECK: ntstg %r0, 0 # encoding: [0xe3,0x00,0x00,0x00,0x00,0x25]
+#CHECK: ntstg %r0, 1 # encoding: [0xe3,0x00,0x00,0x01,0x00,0x25]
+#CHECK: ntstg %r0, 524287 # encoding: [0xe3,0x00,0x0f,0xff,0x7f,0x25]
+#CHECK: ntstg %r0, 0(%r1) # encoding: [0xe3,0x00,0x10,0x00,0x00,0x25]
+#CHECK: ntstg %r0, 0(%r15) # encoding: [0xe3,0x00,0xf0,0x00,0x00,0x25]
+#CHECK: ntstg %r0, 524287(%r1,%r15) # encoding: [0xe3,0x01,0xff,0xff,0x7f,0x25]
+#CHECK: ntstg %r0, 524287(%r15,%r1) # encoding: [0xe3,0x0f,0x1f,0xff,0x7f,0x25]
+#CHECK: ntstg %r15, 0 # encoding: [0xe3,0xf0,0x00,0x00,0x00,0x25]
+
+ ntstg %r0, -524288
+ ntstg %r0, -1
+ ntstg %r0, 0
+ ntstg %r0, 1
+ ntstg %r0, 524287
+ ntstg %r0, 0(%r1)
+ ntstg %r0, 0(%r15)
+ ntstg %r0, 524287(%r1,%r15)
+ ntstg %r0, 524287(%r15,%r1)
+ ntstg %r15, 0
+
+#CHECK: ppa %r0, %r0, 0 # encoding: [0xb2,0xe8,0x00,0x00]
+#CHECK: ppa %r0, %r0, 15 # encoding: [0xb2,0xe8,0xf0,0x00]
+#CHECK: ppa %r0, %r15, 0 # encoding: [0xb2,0xe8,0x00,0x0f]
+#CHECK: ppa %r4, %r6, 7 # encoding: [0xb2,0xe8,0x70,0x46]
+#CHECK: ppa %r15, %r0, 0 # encoding: [0xb2,0xe8,0x00,0xf0]
+
+ ppa %r0, %r0, 0
+ ppa %r0, %r0, 15
+ ppa %r0, %r15, 0
+ ppa %r4, %r6, 7
+ ppa %r15, %r0, 0
+
#CHECK: risbgn %r0, %r0, 0, 0, 0 # encoding: [0xec,0x00,0x00,0x00,0x00,0x59]
#CHECK: risbgn %r0, %r0, 0, 0, 63 # encoding: [0xec,0x00,0x00,0x00,0x3f,0x59]
#CHECK: risbgn %r0, %r0, 0, 255, 0 # encoding: [0xec,0x00,0x00,0xff,0x00,0x59]
@@ -17,3 +59,68 @@
risbgn %r15,%r0,0,0,0
risbgn %r4,%r5,6,7,8
+#CHECK: tabort 0 # encoding: [0xb2,0xfc,0x00,0x00]
+#CHECK: tabort 0(%r1) # encoding: [0xb2,0xfc,0x10,0x00]
+#CHECK: tabort 0(%r15) # encoding: [0xb2,0xfc,0xf0,0x00]
+#CHECK: tabort 4095 # encoding: [0xb2,0xfc,0x0f,0xff]
+#CHECK: tabort 4095(%r1) # encoding: [0xb2,0xfc,0x1f,0xff]
+#CHECK: tabort 4095(%r15) # encoding: [0xb2,0xfc,0xff,0xff]
+
+ tabort 0
+ tabort 0(%r1)
+ tabort 0(%r15)
+ tabort 4095
+ tabort 4095(%r1)
+ tabort 4095(%r15)
+
+#CHECK: tbegin 0, 0 # encoding: [0xe5,0x60,0x00,0x00,0x00,0x00]
+#CHECK: tbegin 4095, 0 # encoding: [0xe5,0x60,0x0f,0xff,0x00,0x00]
+#CHECK: tbegin 0, 0 # encoding: [0xe5,0x60,0x00,0x00,0x00,0x00]
+#CHECK: tbegin 0, 1 # encoding: [0xe5,0x60,0x00,0x00,0x00,0x01]
+#CHECK: tbegin 0, 32767 # encoding: [0xe5,0x60,0x00,0x00,0x7f,0xff]
+#CHECK: tbegin 0, 32768 # encoding: [0xe5,0x60,0x00,0x00,0x80,0x00]
+#CHECK: tbegin 0, 65535 # encoding: [0xe5,0x60,0x00,0x00,0xff,0xff]
+#CHECK: tbegin 0(%r1), 42 # encoding: [0xe5,0x60,0x10,0x00,0x00,0x2a]
+#CHECK: tbegin 0(%r15), 42 # encoding: [0xe5,0x60,0xf0,0x00,0x00,0x2a]
+#CHECK: tbegin 4095(%r1), 42 # encoding: [0xe5,0x60,0x1f,0xff,0x00,0x2a]
+#CHECK: tbegin 4095(%r15), 42 # encoding: [0xe5,0x60,0xff,0xff,0x00,0x2a]
+
+ tbegin 0, 0
+ tbegin 4095, 0
+ tbegin 0, 0
+ tbegin 0, 1
+ tbegin 0, 32767
+ tbegin 0, 32768
+ tbegin 0, 65535
+ tbegin 0(%r1), 42
+ tbegin 0(%r15), 42
+ tbegin 4095(%r1), 42
+ tbegin 4095(%r15), 42
+
+#CHECK: tbeginc 0, 0 # encoding: [0xe5,0x61,0x00,0x00,0x00,0x00]
+#CHECK: tbeginc 4095, 0 # encoding: [0xe5,0x61,0x0f,0xff,0x00,0x00]
+#CHECK: tbeginc 0, 0 # encoding: [0xe5,0x61,0x00,0x00,0x00,0x00]
+#CHECK: tbeginc 0, 1 # encoding: [0xe5,0x61,0x00,0x00,0x00,0x01]
+#CHECK: tbeginc 0, 32767 # encoding: [0xe5,0x61,0x00,0x00,0x7f,0xff]
+#CHECK: tbeginc 0, 32768 # encoding: [0xe5,0x61,0x00,0x00,0x80,0x00]
+#CHECK: tbeginc 0, 65535 # encoding: [0xe5,0x61,0x00,0x00,0xff,0xff]
+#CHECK: tbeginc 0(%r1), 42 # encoding: [0xe5,0x61,0x10,0x00,0x00,0x2a]
+#CHECK: tbeginc 0(%r15), 42 # encoding: [0xe5,0x61,0xf0,0x00,0x00,0x2a]
+#CHECK: tbeginc 4095(%r1), 42 # encoding: [0xe5,0x61,0x1f,0xff,0x00,0x2a]
+#CHECK: tbeginc 4095(%r15), 42 # encoding: [0xe5,0x61,0xff,0xff,0x00,0x2a]
+
+ tbeginc 0, 0
+ tbeginc 4095, 0
+ tbeginc 0, 0
+ tbeginc 0, 1
+ tbeginc 0, 32767
+ tbeginc 0, 32768
+ tbeginc 0, 65535
+ tbeginc 0(%r1), 42
+ tbeginc 0(%r15), 42
+ tbeginc 4095(%r1), 42
+ tbeginc 4095(%r15), 42
+
+#CHECK: tend # encoding: [0xb2,0xf8,0x00,0x00]
+
+ tend
Index: llvm-head/test/MC/SystemZ/insn-bad-z196.s
===================================================================
--- llvm-head.orig/test/MC/SystemZ/insn-bad-z196.s
+++ llvm-head/test/MC/SystemZ/insn-bad-z196.s
@@ -244,6 +244,11 @@
cxlgbr %f0, 16, %r0, 0
cxlgbr %f2, 0, %r0, 0
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: etnd %r7
+
+ etnd %r7
+
#CHECK: error: invalid operand
#CHECK: fidbra %f0, 0, %f0, -1
#CHECK: error: invalid operand
@@ -546,6 +551,16 @@
locr %r0,%r0,-1
locr %r0,%r0,16
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: ntstg %r0, 524287(%r1,%r15)
+
+ ntstg %r0, 524287(%r1,%r15)
+
+#CHECK: error: {{(instruction requires: processor-assist)?}}
+#CHECK: ppa %r4, %r6, 7
+
+ ppa %r4, %r6, 7
+
#CHECK: error: {{(instruction requires: miscellaneous-extensions)?}}
#CHECK: risbgn %r1, %r2, 0, 0, 0
@@ -690,3 +705,24 @@
stocg %r0,-524289,1
stocg %r0,524288,1
stocg %r0,0(%r1,%r2),1
+
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: tabort 4095(%r1)
+
+ tabort 4095(%r1)
+
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: tbegin 4095(%r1), 42
+
+ tbegin 4095(%r1), 42
+
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: tbeginc 4095(%r1), 42
+
+ tbeginc 4095(%r1), 42
+
+#CHECK: error: {{(instruction requires: transactional-execution)?}}
+#CHECK: tend
+
+ tend
+
Index: llvm-head/test/MC/Disassembler/SystemZ/insns.txt
===================================================================
--- llvm-head.orig/test/MC/Disassembler/SystemZ/insns.txt
+++ llvm-head/test/MC/Disassembler/SystemZ/insns.txt
@@ -2503,6 +2503,15 @@
# CHECK: ear %r15, %a15
0xb2 0x4f 0x00 0xff
+# CHECK: etnd %r0
+0xb2 0xec 0x00 0x00
+
+# CHECK: etnd %r15
+0xb2 0xec 0x00 0xf0
+
+# CHECK: etnd %r7
+0xb2 0xec 0x00 0x70
+
# CHECK: fidbr %f0, 0, %f0
0xb3 0x5f 0x00 0x00
@@ -6034,6 +6043,36 @@
# CHECK: ny %r15, 0
0xe3 0xf0 0x00 0x00 0x00 0x54
+# CHECK: ntstg %r0, -524288
+0xe3 0x00 0x00 0x00 0x80 0x25
+
+# CHECK: ntstg %r0, -1
+0xe3 0x00 0x0f 0xff 0xff 0x25
+
+# CHECK: ntstg %r0, 0
+0xe3 0x00 0x00 0x00 0x00 0x25
+
+# CHECK: ntstg %r0, 1
+0xe3 0x00 0x00 0x01 0x00 0x25
+
+# CHECK: ntstg %r0, 524287
+0xe3 0x00 0x0f 0xff 0x7f 0x25
+
+# CHECK: ntstg %r0, 0(%r1)
+0xe3 0x00 0x10 0x00 0x00 0x25
+
+# CHECK: ntstg %r0, 0(%r15)
+0xe3 0x00 0xf0 0x00 0x00 0x25
+
+# CHECK: ntstg %r0, 524287(%r1,%r15)
+0xe3 0x01 0xff 0xff 0x7f 0x25
+
+# CHECK: ntstg %r0, 524287(%r15,%r1)
+0xe3 0x0f 0x1f 0xff 0x7f 0x25
+
+# CHECK: ntstg %r15, 0
+0xe3 0xf0 0x00 0x00 0x00 0x25
+
# CHECK: oc 0(1), 0
0xd6 0x00 0x00 0x00 0x00 0x00
@@ -6346,6 +6385,21 @@
# CHECK: popcnt %r7, %r8
0xb9 0xe1 0x00 0x78
+# CHECK: ppa %r0, %r0, 0
+0xb2 0xe8 0x00 0x00
+
+# CHECK: ppa %r0, %r0, 15
+0xb2 0xe8 0xf0 0x00
+
+# CHECK: ppa %r0, %r15, 0
+0xb2 0xe8 0x00 0x0f
+
+# CHECK: ppa %r4, %r6, 7
+0xb2 0xe8 0x70 0x46
+
+# CHECK: ppa %r15, %r0, 0
+0xb2 0xe8 0x00 0xf0
+
# CHECK: risbg %r0, %r0, 0, 0, 0
0xec 0x00 0x00 0x00 0x00 0x55
@@ -8062,6 +8116,93 @@
# CHECK: sy %r15, 0
0xe3 0xf0 0x00 0x00 0x00 0x5b
+# CHECK: tabort 0
+0xb2 0xfc 0x00 0x00
+
+# CHECK: tabort 0(%r1)
+0xb2 0xfc 0x10 0x00
+
+# CHECK: tabort 0(%r15)
+0xb2 0xfc 0xf0 0x00
+
+# CHECK: tabort 4095
+0xb2 0xfc 0x0f 0xff
+
+# CHECK: tabort 4095(%r1)
+0xb2 0xfc 0x1f 0xff
+
+# CHECK: tabort 4095(%r15)
+0xb2 0xfc 0xff 0xff
+
+# CHECK: tbegin 0, 0
+0xe5 0x60 0x00 0x00 0x00 0x00
+
+# CHECK: tbegin 4095, 0
+0xe5 0x60 0x0f 0xff 0x00 0x00
+
+# CHECK: tbegin 0, 0
+0xe5 0x60 0x00 0x00 0x00 0x00
+
+# CHECK: tbegin 0, 1
+0xe5 0x60 0x00 0x00 0x00 0x01
+
+# CHECK: tbegin 0, 32767
+0xe5 0x60 0x00 0x00 0x7f 0xff
+
+# CHECK: tbegin 0, 32768
+0xe5 0x60 0x00 0x00 0x80 0x00
+
+# CHECK: tbegin 0, 65535
+0xe5 0x60 0x00 0x00 0xff 0xff
+
+# CHECK: tbegin 0(%r1), 42
+0xe5 0x60 0x10 0x00 0x00 0x2a
+
+# CHECK: tbegin 0(%r15), 42
+0xe5 0x60 0xf0 0x00 0x00 0x2a
+
+# CHECK: tbegin 4095(%r1), 42
+0xe5 0x60 0x1f 0xff 0x00 0x2a
+
+# CHECK: tbegin 4095(%r15), 42
+0xe5 0x60 0xff 0xff 0x00 0x2a
+
+# CHECK: tbeginc 0, 0
+0xe5 0x61 0x00 0x00 0x00 0x00
+
+# CHECK: tbeginc 4095, 0
+0xe5 0x61 0x0f 0xff 0x00 0x00
+
+# CHECK: tbeginc 0, 0
+0xe5 0x61 0x00 0x00 0x00 0x00
+
+# CHECK: tbeginc 0, 1
+0xe5 0x61 0x00 0x00 0x00 0x01
+
+# CHECK: tbeginc 0, 32767
+0xe5 0x61 0x00 0x00 0x7f 0xff
+
+# CHECK: tbeginc 0, 32768
+0xe5 0x61 0x00 0x00 0x80 0x00
+
+# CHECK: tbeginc 0, 65535
+0xe5 0x61 0x00 0x00 0xff 0xff
+
+# CHECK: tbeginc 0(%r1), 42
+0xe5 0x61 0x10 0x00 0x00 0x2a
+
+# CHECK: tbeginc 0(%r15), 42
+0xe5 0x61 0xf0 0x00 0x00 0x2a
+
+# CHECK: tbeginc 4095(%r1), 42
+0xe5 0x61 0x1f 0xff 0x00 0x2a
+
+# CHECK: tbeginc 4095(%r15), 42
+0xe5 0x61 0xff 0xff 0x00 0x2a
+
+# CHECK: tend
+0xb2 0xf8 0x00 0x00
+
# CHECK: tm 0, 0
0x91 0x00 0x00 0x00
llvm-svn: 233803
2015-04-01 20:51:43 +08:00
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tabort -1
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tabort 4096
|
|
|
|
#CHECK: error: invalid use of indexed addressing
|
|
|
|
#CHECK: tabort 0(%r1,%r2)
|
|
|
|
|
|
|
|
tabort -1
|
|
|
|
tabort 4096
|
|
|
|
tabort 0(%r1,%r2)
|
|
|
|
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tbegin -1, 0
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tbegin 4096, 0
|
|
|
|
#CHECK: error: invalid use of indexed addressing
|
|
|
|
#CHECK: tbegin 0(%r1,%r2), 0
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tbegin 0, -1
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tbegin 0, 65536
|
|
|
|
|
|
|
|
tbegin -1, 0
|
|
|
|
tbegin 4096, 0
|
|
|
|
tbegin 0(%r1,%r2), 0
|
|
|
|
tbegin 0, -1
|
|
|
|
tbegin 0, 65536
|
|
|
|
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tbeginc -1, 0
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tbeginc 4096, 0
|
|
|
|
#CHECK: error: invalid use of indexed addressing
|
|
|
|
#CHECK: tbeginc 0(%r1,%r2), 0
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tbeginc 0, -1
|
|
|
|
#CHECK: error: invalid operand
|
|
|
|
#CHECK: tbeginc 0, 65536
|
|
|
|
|
|
|
|
tbeginc -1, 0
|
|
|
|
tbeginc 4096, 0
|
|
|
|
tbeginc 0(%r1,%r2), 0
|
|
|
|
tbeginc 0, -1
|
|
|
|
tbeginc 0, 65536
|
2015-05-06 03:23:40 +08:00
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vab %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vaf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vag %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vah %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vaq %v0, %v0, %v0
|
|
|
|
|
|
|
|
vab %v0, %v0, %v0
|
|
|
|
vaf %v0, %v0, %v0
|
|
|
|
vag %v0, %v0, %v0
|
|
|
|
vah %v0, %v0, %v0
|
|
|
|
vaq %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vaccb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vaccf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vaccg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vacch %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vaccq %v0, %v0, %v0
|
|
|
|
|
|
|
|
vaccb %v0, %v0, %v0
|
|
|
|
vaccf %v0, %v0, %v0
|
|
|
|
vaccg %v0, %v0, %v0
|
|
|
|
vacch %v0, %v0, %v0
|
|
|
|
vaccq %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vacccq %v0, %v0, %v0
|
|
|
|
|
|
|
|
vacccq %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vacq %v0, %v0, %v0
|
|
|
|
|
|
|
|
vacq %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vavgb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vavgf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vavgg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vavgh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vavgb %v0, %v0, %v0
|
|
|
|
vavgf %v0, %v0, %v0
|
|
|
|
vavgg %v0, %v0, %v0
|
|
|
|
vavgh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vavglb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vavglf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vavglg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vavglh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vavglb %v0, %v0, %v0
|
|
|
|
vavglf %v0, %v0, %v0
|
|
|
|
vavglg %v0, %v0, %v0
|
|
|
|
vavglh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vcdgb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
vcdgb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vcdlgb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
vcdlgb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vceqb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vceqf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vceqg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vceqh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vceqbs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vceqhs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vceqfs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vceqgs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vceqb %v0, %v0, %v0
|
|
|
|
vceqf %v0, %v0, %v0
|
|
|
|
vceqg %v0, %v0, %v0
|
|
|
|
vceqh %v0, %v0, %v0
|
|
|
|
vceqbs %v0, %v0, %v0
|
|
|
|
vceqhs %v0, %v0, %v0
|
|
|
|
vceqfs %v0, %v0, %v0
|
|
|
|
vceqgs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vcgdb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
vcgdb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchbs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchhs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchfs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchgs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vchb %v0, %v0, %v0
|
|
|
|
vchf %v0, %v0, %v0
|
|
|
|
vchg %v0, %v0, %v0
|
|
|
|
vchh %v0, %v0, %v0
|
|
|
|
vchbs %v0, %v0, %v0
|
|
|
|
vchhs %v0, %v0, %v0
|
|
|
|
vchfs %v0, %v0, %v0
|
|
|
|
vchgs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchlb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchlf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchlg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchlh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchlbs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchlhs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchlfs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vchlgs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vchlb %v0, %v0, %v0
|
|
|
|
vchlf %v0, %v0, %v0
|
|
|
|
vchlg %v0, %v0, %v0
|
|
|
|
vchlh %v0, %v0, %v0
|
|
|
|
vchlbs %v0, %v0, %v0
|
|
|
|
vchlhs %v0, %v0, %v0
|
|
|
|
vchlfs %v0, %v0, %v0
|
|
|
|
vchlgs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vcksm %v0, %v0, %v0
|
|
|
|
|
|
|
|
vcksm %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vclgdb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
vclgdb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vclzb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vclzf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vclzg %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vclzh %v0, %v0
|
|
|
|
|
|
|
|
vclzb %v0, %v0
|
|
|
|
vclzf %v0, %v0
|
|
|
|
vclzg %v0, %v0
|
|
|
|
vclzh %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vctzb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vctzf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vctzg %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vctzh %v0, %v0
|
|
|
|
|
|
|
|
vctzb %v0, %v0
|
|
|
|
vctzf %v0, %v0
|
|
|
|
vctzg %v0, %v0
|
|
|
|
vctzh %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vecb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vecf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vecg %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vech %v0, %v0
|
|
|
|
|
|
|
|
vecb %v0, %v0
|
|
|
|
vecf %v0, %v0
|
|
|
|
vecg %v0, %v0
|
|
|
|
vech %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verimb %v0, %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verimf %v0, %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verimg %v0, %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verimh %v0, %v0, %v0, 0
|
|
|
|
|
|
|
|
verimb %v0, %v0, %v0, 0
|
|
|
|
verimf %v0, %v0, %v0, 0
|
|
|
|
verimg %v0, %v0, %v0, 0
|
|
|
|
verimh %v0, %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veclb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veclf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veclg %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veclh %v0, %v0
|
|
|
|
|
|
|
|
veclb %v0, %v0
|
|
|
|
veclf %v0, %v0
|
|
|
|
veclg %v0, %v0
|
|
|
|
veclh %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verllvb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verllvf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verllvg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verllvh %v0, %v0, %v0
|
|
|
|
|
|
|
|
verllvb %v0, %v0, %v0
|
|
|
|
verllvf %v0, %v0, %v0
|
|
|
|
verllvg %v0, %v0, %v0
|
|
|
|
verllvh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verllb %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verllf %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verllg %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: verllh %v0, %v0, 0
|
|
|
|
|
|
|
|
verllb %v0, %v0, 0
|
|
|
|
verllf %v0, %v0, 0
|
|
|
|
verllg %v0, %v0, 0
|
|
|
|
verllh %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veslvb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veslvf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veslvg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veslvh %v0, %v0, %v0
|
|
|
|
|
|
|
|
veslvb %v0, %v0, %v0
|
|
|
|
veslvf %v0, %v0, %v0
|
|
|
|
veslvg %v0, %v0, %v0
|
|
|
|
veslvh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veslb %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veslf %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veslg %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: veslh %v0, %v0, 0
|
|
|
|
|
|
|
|
veslb %v0, %v0, 0
|
|
|
|
veslf %v0, %v0, 0
|
|
|
|
veslg %v0, %v0, 0
|
|
|
|
veslh %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesravb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesravf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesravg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesravh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vesravb %v0, %v0, %v0
|
|
|
|
vesravf %v0, %v0, %v0
|
|
|
|
vesravg %v0, %v0, %v0
|
|
|
|
vesravh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrab %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesraf %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrag %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrah %v0, %v0, 0
|
|
|
|
|
|
|
|
vesrab %v0, %v0, 0
|
|
|
|
vesraf %v0, %v0, 0
|
|
|
|
vesrag %v0, %v0, 0
|
|
|
|
vesrah %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrlvb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrlvf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrlvg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrlvh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vesrlvb %v0, %v0, %v0
|
|
|
|
vesrlvf %v0, %v0, %v0
|
|
|
|
vesrlvg %v0, %v0, %v0
|
|
|
|
vesrlvh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrlb %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrlf %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrlg %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vesrlh %v0, %v0, 0
|
|
|
|
|
|
|
|
vesrlb %v0, %v0, 0
|
|
|
|
vesrlf %v0, %v0, 0
|
|
|
|
vesrlg %v0, %v0, 0
|
|
|
|
vesrlh %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfadb %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfadb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfcedb %v0, %v0, %v0
|
|
|
|
#CHECK: vfcedbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfcedb %v0, %v0, %v0
|
|
|
|
vfcedbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfchdb %v0, %v0, %v0
|
|
|
|
#CHECK: vfchdbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfchdb %v0, %v0, %v0
|
|
|
|
vfchdbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfddb %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfddb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaeb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaezb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaebs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaezbs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaeh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaezh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaehs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaezhs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaef %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaezf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaefs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfaezfs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfaeb %v0, %v0, %v0
|
|
|
|
vfaezb %v0, %v0, %v0
|
|
|
|
vfaebs %v0, %v0, %v0
|
|
|
|
vfaezbs %v0, %v0, %v0
|
|
|
|
vfaeh %v0, %v0, %v0
|
|
|
|
vfaezh %v0, %v0, %v0
|
|
|
|
vfaehs %v0, %v0, %v0
|
|
|
|
vfaezhs %v0, %v0, %v0
|
|
|
|
vfaef %v0, %v0, %v0
|
|
|
|
vfaezf %v0, %v0, %v0
|
|
|
|
vfaefs %v0, %v0, %v0
|
|
|
|
vfaezfs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeeb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeezb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeebs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeezbs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeeh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeezh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeehs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeezhs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeef %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeezf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeefs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeezfs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfeeb %v0, %v0, %v0
|
|
|
|
vfeezb %v0, %v0, %v0
|
|
|
|
vfeebs %v0, %v0, %v0
|
|
|
|
vfeezbs %v0, %v0, %v0
|
|
|
|
vfeeh %v0, %v0, %v0
|
|
|
|
vfeezh %v0, %v0, %v0
|
|
|
|
vfeehs %v0, %v0, %v0
|
|
|
|
vfeezhs %v0, %v0, %v0
|
|
|
|
vfeef %v0, %v0, %v0
|
|
|
|
vfeezf %v0, %v0, %v0
|
|
|
|
vfeefs %v0, %v0, %v0
|
|
|
|
vfeezfs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeneb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenezb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenebs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenezbs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfeneh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenezh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenehs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenezhs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenef %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenezf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenefs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfenezfs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfeneb %v0, %v0, %v0
|
|
|
|
vfenezb %v0, %v0, %v0
|
|
|
|
vfenebs %v0, %v0, %v0
|
|
|
|
vfenezbs %v0, %v0, %v0
|
|
|
|
vfeneh %v0, %v0, %v0
|
|
|
|
vfenezh %v0, %v0, %v0
|
|
|
|
vfenehs %v0, %v0, %v0
|
|
|
|
vfenezhs %v0, %v0, %v0
|
|
|
|
vfenef %v0, %v0, %v0
|
|
|
|
vfenezf %v0, %v0, %v0
|
|
|
|
vfenefs %v0, %v0, %v0
|
|
|
|
vfenezfs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfidb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
vfidb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vistrb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vistrbs %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vistrh %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vistrhs %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vistrf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vistrfs %v0, %v0
|
|
|
|
|
|
|
|
vistrb %v0, %v0
|
|
|
|
vistrbs %v0, %v0
|
|
|
|
vistrh %v0, %v0
|
|
|
|
vistrhs %v0, %v0
|
|
|
|
vistrf %v0, %v0
|
|
|
|
vistrfs %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vflcdb %v0, %v0
|
|
|
|
|
|
|
|
vflcdb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vflndb %v0, %v0
|
|
|
|
|
|
|
|
vflndb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vflpdb %v0, %v0
|
|
|
|
|
|
|
|
vflpdb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfmadb %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfmadb %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfmdb %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfmdb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfmsdb %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfmsdb %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfsdb %v0, %v0, %v0
|
|
|
|
|
|
|
|
vfsdb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vfsqdb %v0, %v0
|
|
|
|
|
|
|
|
vfsqdb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vftcidb %v0, %v0, 0
|
|
|
|
|
|
|
|
vftcidb %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgbm %v0, 0
|
|
|
|
|
|
|
|
vgbm %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgef %v0, 0(%v0, %r1), 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgeg %v0, 0(%v0, %r1), 0
|
|
|
|
|
|
|
|
vgef %v0, 0(%v0, %r1), 0
|
|
|
|
vgeg %v0, 0(%v0, %r1), 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgfmab %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgfmaf %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgfmag %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgfmah %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vgfmab %v0, %v0, %v0, %v0
|
|
|
|
vgfmaf %v0, %v0, %v0, %v0
|
|
|
|
vgfmag %v0, %v0, %v0, %v0
|
|
|
|
vgfmah %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgfmb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgfmf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgfmg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgfmh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vgfmb %v0, %v0, %v0
|
|
|
|
vgfmf %v0, %v0, %v0
|
|
|
|
vgfmg %v0, %v0, %v0
|
|
|
|
vgfmh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgmb %v0, 0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgmf %v0, 0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgmg %v0, 0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vgmh %v0, 0, 0
|
|
|
|
|
|
|
|
vgmb %v0, 0, 0
|
|
|
|
vgmf %v0, 0, 0
|
|
|
|
vgmg %v0, 0, 0
|
|
|
|
vgmh %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vl %v0, 0
|
|
|
|
|
|
|
|
vl %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlbb %v0, 0, 0
|
|
|
|
|
|
|
|
vlbb %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlcb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlcf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlcg %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlch %v0, %v0
|
|
|
|
|
|
|
|
vlcb %v0, %v0
|
|
|
|
vlcf %v0, %v0
|
|
|
|
vlcg %v0, %v0
|
|
|
|
vlch %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vldeb %v0, %v0
|
|
|
|
|
|
|
|
vldeb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vleb %v0, 0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlef %v0, 0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vleg %v0, 0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vleh %v0, 0, 0
|
|
|
|
|
|
|
|
vleb %v0, 0, 0
|
|
|
|
vlef %v0, 0, 0
|
|
|
|
vleg %v0, 0, 0
|
|
|
|
vleh %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vledb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
vledb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vleib %v0, 0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vleif %v0, 0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vleig %v0, 0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vleih %v0, 0, 0
|
|
|
|
|
|
|
|
vleib %v0, 0, 0
|
|
|
|
vleif %v0, 0, 0
|
|
|
|
vleig %v0, 0, 0
|
|
|
|
vleih %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlgvb %r0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlgvf %r0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlgvg %r0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlgvh %r0, %v0, 0
|
|
|
|
|
|
|
|
vlgvb %r0, %v0, 0
|
|
|
|
vlgvf %r0, %v0, 0
|
|
|
|
vlgvg %r0, %v0, 0
|
|
|
|
vlgvh %r0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vll %v0, %r0, 0
|
|
|
|
|
|
|
|
vll %v0, %r0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vllezb %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vllezf %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vllezg %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vllezh %v0, 0
|
|
|
|
|
|
|
|
vllezb %v0, 0
|
|
|
|
vllezf %v0, 0
|
|
|
|
vllezg %v0, 0
|
|
|
|
vllezh %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlm %v0, %v0, 0
|
|
|
|
|
|
|
|
vlm %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlpb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlpf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlpg %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlph %v0, %v0
|
|
|
|
|
|
|
|
vlpb %v0, %v0
|
|
|
|
vlpf %v0, %v0
|
|
|
|
vlpg %v0, %v0
|
|
|
|
vlph %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlr %v0, %v0
|
|
|
|
|
|
|
|
vlr %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlrepb %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlrepf %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlrepg %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlreph %v0, 0
|
|
|
|
|
|
|
|
vlrepb %v0, 0
|
|
|
|
vlrepf %v0, 0
|
|
|
|
vlrepg %v0, 0
|
|
|
|
vlreph %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlvgb %v0, %r0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlvgf %v0, %r0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlvgg %v0, %r0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlvgh %v0, %r0, 0
|
|
|
|
|
|
|
|
vlvgb %v0, %r0, 0
|
|
|
|
vlvgf %v0, %r0, 0
|
|
|
|
vlvgg %v0, %r0, 0
|
|
|
|
vlvgh %v0, %r0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vlvgp %v0, %r0, %r0
|
|
|
|
|
|
|
|
vlvgp %v0, %r0, %r0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmaeb %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmaef %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmaeh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmaeb %v0, %v0, %v0, %v0
|
|
|
|
vmaef %v0, %v0, %v0, %v0
|
|
|
|
vmaeh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmahb %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmahf %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmahh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmahb %v0, %v0, %v0, %v0
|
|
|
|
vmahf %v0, %v0, %v0, %v0
|
|
|
|
vmahh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmalb %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmalf %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmalhw %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmalb %v0, %v0, %v0, %v0
|
|
|
|
vmalf %v0, %v0, %v0, %v0
|
|
|
|
vmalhw %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmaleb %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmalef %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmaleh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmaleb %v0, %v0, %v0, %v0
|
|
|
|
vmalef %v0, %v0, %v0, %v0
|
|
|
|
vmaleh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmalhb %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmalhf %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmalhh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmalhb %v0, %v0, %v0, %v0
|
|
|
|
vmalhf %v0, %v0, %v0, %v0
|
|
|
|
vmalhh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmalob %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmalof %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmaloh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmalob %v0, %v0, %v0, %v0
|
|
|
|
vmalof %v0, %v0, %v0, %v0
|
|
|
|
vmaloh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmaob %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmaof %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmaoh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmaob %v0, %v0, %v0, %v0
|
|
|
|
vmaof %v0, %v0, %v0, %v0
|
|
|
|
vmaoh %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmeb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmef %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmeh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmeb %v0, %v0, %v0
|
|
|
|
vmef %v0, %v0, %v0
|
|
|
|
vmeh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmhb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmhf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmhh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmhb %v0, %v0, %v0
|
|
|
|
vmhf %v0, %v0, %v0
|
|
|
|
vmhh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmlb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmlf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmlh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmlb %v0, %v0, %v0
|
|
|
|
vmlf %v0, %v0, %v0
|
|
|
|
vmlh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmleb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmlef %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmleh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmleb %v0, %v0, %v0
|
|
|
|
vmlef %v0, %v0, %v0
|
|
|
|
vmleh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmlhb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmlhf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmlhh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmlhb %v0, %v0, %v0
|
|
|
|
vmlhf %v0, %v0, %v0
|
|
|
|
vmlhh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmlob %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmlof %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmloh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmlob %v0, %v0, %v0
|
|
|
|
vmlof %v0, %v0, %v0
|
|
|
|
vmloh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmnb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmnf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmng %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmnh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmnb %v0, %v0, %v0
|
|
|
|
vmnf %v0, %v0, %v0
|
|
|
|
vmng %v0, %v0, %v0
|
|
|
|
vmnh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmnlb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmnlf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmnlg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmnlh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmnlb %v0, %v0, %v0
|
|
|
|
vmnlf %v0, %v0, %v0
|
|
|
|
vmnlg %v0, %v0, %v0
|
|
|
|
vmnlh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmob %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmof %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmoh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmob %v0, %v0, %v0
|
|
|
|
vmof %v0, %v0, %v0
|
|
|
|
vmoh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmrhb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmrhf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmrhg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmrhh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmrhb %v0, %v0, %v0
|
|
|
|
vmrhf %v0, %v0, %v0
|
|
|
|
vmrhg %v0, %v0, %v0
|
|
|
|
vmrhh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmrlb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmrlf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmrlg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmrlh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmrlb %v0, %v0, %v0
|
|
|
|
vmrlf %v0, %v0, %v0
|
|
|
|
vmrlg %v0, %v0, %v0
|
|
|
|
vmrlh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmxb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmxf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmxg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmxh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmxb %v0, %v0, %v0
|
|
|
|
vmxf %v0, %v0, %v0
|
|
|
|
vmxg %v0, %v0, %v0
|
|
|
|
vmxh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmxlb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmxlf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmxlg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vmxlh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vmxlb %v0, %v0, %v0
|
|
|
|
vmxlf %v0, %v0, %v0
|
|
|
|
vmxlg %v0, %v0, %v0
|
|
|
|
vmxlh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vn %v0, %v0, %v0
|
|
|
|
|
|
|
|
vn %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vnc %v0, %v0, %v0
|
|
|
|
|
|
|
|
vnc %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vno %v0, %v0, %v0
|
|
|
|
|
|
|
|
vno %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vo %v0, %v0, %v0
|
|
|
|
|
|
|
|
vo %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vone %v0
|
|
|
|
|
|
|
|
vone %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpdi %v0, %v0, %v0, 0
|
|
|
|
|
|
|
|
vpdi %v0, %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vperm %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vperm %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpkf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpkg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpkh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vpkf %v0, %v0, %v0
|
|
|
|
vpkg %v0, %v0, %v0
|
|
|
|
vpkh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpksf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpksg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpksh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpksfs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpksgs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpkshs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vpksf %v0, %v0, %v0
|
|
|
|
vpksg %v0, %v0, %v0
|
|
|
|
vpksh %v0, %v0, %v0
|
|
|
|
vpksfs %v0, %v0, %v0
|
|
|
|
vpksgs %v0, %v0, %v0
|
|
|
|
vpkshs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpklsf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpklsg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpklsh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpklsfs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpklsgs %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpklshs %v0, %v0, %v0
|
|
|
|
|
|
|
|
vpklsf %v0, %v0, %v0
|
|
|
|
vpklsg %v0, %v0, %v0
|
|
|
|
vpklsh %v0, %v0, %v0
|
|
|
|
vpklsfs %v0, %v0, %v0
|
|
|
|
vpklsgs %v0, %v0, %v0
|
|
|
|
vpklshs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vpopct %v0, %v0
|
|
|
|
|
|
|
|
vpopct %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vrepb %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vrepf %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vrepg %v0, %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vreph %v0, %v0, 0
|
|
|
|
|
|
|
|
vrepb %v0, %v0, 0
|
|
|
|
vrepf %v0, %v0, 0
|
|
|
|
vrepg %v0, %v0, 0
|
|
|
|
vreph %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vrepib %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vrepif %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vrepig %v0, 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vrepih %v0, 0
|
|
|
|
|
|
|
|
vrepib %v0, 0
|
|
|
|
vrepif %v0, 0
|
|
|
|
vrepig %v0, 0
|
|
|
|
vrepih %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsg %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsq %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsb %v0, %v0, %v0
|
|
|
|
vsf %v0, %v0, %v0
|
|
|
|
vsg %v0, %v0, %v0
|
|
|
|
vsh %v0, %v0, %v0
|
|
|
|
vsq %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsbcbiq %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsbcbiq %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsbiq %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsbiq %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vscbib %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vscbif %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vscbig %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vscbih %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vscbiq %v0, %v0, %v0
|
|
|
|
|
|
|
|
vscbib %v0, %v0, %v0
|
|
|
|
vscbif %v0, %v0, %v0
|
|
|
|
vscbig %v0, %v0, %v0
|
|
|
|
vscbih %v0, %v0, %v0
|
|
|
|
vscbiq %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vscef %v0, 0(%v0, %r1), 0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsceg %v0, 0(%v0, %r1), 0
|
|
|
|
|
|
|
|
vscef %v0, 0(%v0, %r1), 0
|
|
|
|
vsceg %v0, 0(%v0, %r1), 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsegb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsegf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsegh %v0, %v0
|
|
|
|
|
|
|
|
vsegb %v0, %v0
|
|
|
|
vsegf %v0, %v0
|
|
|
|
vsegh %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsel %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsel %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsl %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsl %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vslb %v0, %v0, %v0
|
|
|
|
|
|
|
|
vslb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsldb %v0, %v0, %v0, 0
|
|
|
|
|
|
|
|
vsldb %v0, %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsra %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsra %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsrab %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsrab %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsrl %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsrl %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsrlb %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsrlb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vst %v0, 0
|
|
|
|
|
|
|
|
vst %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstl %v0, %r0, 0
|
|
|
|
|
|
|
|
vstl %v0, %r0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstm %v0, %v0, 0
|
|
|
|
|
|
|
|
vstm %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrcb %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrczb %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrcbs %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrczbs %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrch %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrczh %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrchs %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrczhs %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrcf %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrczf %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrcfs %v0, %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vstrczfs %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
vstrcb %v0, %v0, %v0, %v0
|
|
|
|
vstrczb %v0, %v0, %v0, %v0
|
|
|
|
vstrcbs %v0, %v0, %v0, %v0
|
|
|
|
vstrczbs %v0, %v0, %v0, %v0
|
|
|
|
vstrch %v0, %v0, %v0, %v0
|
|
|
|
vstrczh %v0, %v0, %v0, %v0
|
|
|
|
vstrchs %v0, %v0, %v0, %v0
|
|
|
|
vstrczhs %v0, %v0, %v0, %v0
|
|
|
|
vstrcf %v0, %v0, %v0, %v0
|
|
|
|
vstrczf %v0, %v0, %v0, %v0
|
|
|
|
vstrcfs %v0, %v0, %v0, %v0
|
|
|
|
vstrczfs %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsumgh %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsumgf %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsumgh %v0, %v0, %v0
|
|
|
|
vsumgf %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsumqf %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsumqg %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsumqf %v0, %v0, %v0
|
|
|
|
vsumqg %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsumb %v0, %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vsumh %v0, %v0, %v0
|
|
|
|
|
|
|
|
vsumb %v0, %v0, %v0
|
|
|
|
vsumh %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vtm %v0, %v0
|
|
|
|
|
|
|
|
vtm %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vuphb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vuphf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vuphh %v0, %v0
|
|
|
|
|
|
|
|
vuphb %v0, %v0
|
|
|
|
vuphf %v0, %v0
|
|
|
|
vuphh %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vuplhb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vuplhf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vuplhh %v0, %v0
|
|
|
|
|
|
|
|
vuplhb %v0, %v0
|
|
|
|
vuplhf %v0, %v0
|
|
|
|
vuplhh %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vuplb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vuplf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vuplhw %v0, %v0
|
|
|
|
|
|
|
|
vuplb %v0, %v0
|
|
|
|
vuplf %v0, %v0
|
|
|
|
vuplhw %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vupllb %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vupllf %v0, %v0
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vupllh %v0, %v0
|
|
|
|
|
|
|
|
vupllb %v0, %v0
|
|
|
|
vupllf %v0, %v0
|
|
|
|
vupllh %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vx %v0, %v0, %v0
|
|
|
|
|
|
|
|
vx %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: vzero %v0
|
|
|
|
|
|
|
|
vzero %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wcdgb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
wcdgb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wcdlgb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
wcdlgb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wcgdb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
wcgdb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wclgdb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
wclgdb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfadb %v0, %v0, %v0
|
|
|
|
|
|
|
|
wfadb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfcdb %v0, %v0
|
|
|
|
|
|
|
|
wfcdb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfcedb %v0, %v0, %v0
|
|
|
|
#CHECK: wfcedbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
wfcedb %v0, %v0, %v0
|
|
|
|
wfcedbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfchdb %v0, %v0, %v0
|
|
|
|
#CHECK: wfchdbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
wfchdb %v0, %v0, %v0
|
|
|
|
wfchdbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfchedb %v0, %v0, %v0
|
|
|
|
#CHECK: wfchedbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
wfchedb %v0, %v0, %v0
|
|
|
|
wfchedbs %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfddb %v0, %v0, %v0
|
|
|
|
|
|
|
|
wfddb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfidb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
wfidb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfkdb %v0, %v0
|
|
|
|
|
|
|
|
wfkdb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wflcdb %v0, %v0
|
|
|
|
|
|
|
|
wflcdb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wflndb %v0, %v0
|
|
|
|
|
|
|
|
wflndb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wflpdb %v0, %v0
|
|
|
|
|
|
|
|
wflpdb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfmadb %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
wfmadb %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfmdb %v0, %v0, %v0
|
|
|
|
|
|
|
|
wfmdb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfmsdb %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
wfmsdb %v0, %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfsdb %v0, %v0, %v0
|
|
|
|
|
|
|
|
wfsdb %v0, %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wfsqdb %v0, %v0
|
|
|
|
|
|
|
|
wfsqdb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wftcidb %v0, %v0, 0
|
|
|
|
|
|
|
|
wftcidb %v0, %v0, 0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wldeb %v0, %v0
|
|
|
|
|
|
|
|
wldeb %v0, %v0
|
|
|
|
|
|
|
|
#CHECK: error: {{(instruction requires: vector)?}}
|
|
|
|
#CHECK: wledb %v0, %v0, 0, 0
|
|
|
|
|
|
|
|
wledb %v0, %v0, 0, 0
|