[ARM] MVE compare vector splat combine
[llvm-complete.git] / lib / Target / Hexagon / HexagonOperands.td
blob212cf03bee67d6f2aada6c7b8ce14dda807bf67c
1 //===--- HexagonOperands.td -----------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 def f32ImmOperand : AsmOperandClass { let Name = "f32Imm"; }
10 def f32Imm : Operand<f32> { let ParserMatchClass = f32ImmOperand; }
11 def f64ImmOperand : AsmOperandClass { let Name = "f64Imm"; }
12 def f64Imm : Operand<f64> { let ParserMatchClass = f64ImmOperand; }
13 def s8_0Imm64Pred  : PatLeaf<(i64 imm), [{ return isInt<8>(N->getSExtValue()); }]>;
14 def s9_0ImmOperand : AsmOperandClass { let Name = "s9_0Imm"; }
15 def s9_0Imm : Operand<i32> { let ParserMatchClass = s9_0ImmOperand; }
16 def s27_2ImmOperand : AsmOperandClass { let Name = "s27_2Imm"; let RenderMethod = "addSignedImmOperands"; }
17 def s27_2Imm : Operand<i32> { let ParserMatchClass = s27_2ImmOperand; }
18 def r32_0ImmPred  : PatLeaf<(i32 imm), [{
19   int64_t v = (int64_t)N->getSExtValue();
20   return isInt<32>(v);
21 }]>;
22 def u9_0ImmPred  : PatLeaf<(i32 imm), [{
23   int64_t v = (int64_t)N->getSExtValue();
24   return isUInt<9>(v);
25 }]>;
26 def u64_0ImmOperand : AsmOperandClass { let Name = "u64_0Imm"; let RenderMethod = "addImmOperands"; }
27 def u64_0Imm : Operand<i64> { let ParserMatchClass = u64_0ImmOperand; }
28 def n1ConstOperand : AsmOperandClass { let Name = "n1Const"; }
29 def n1Const : Operand<i32> { let ParserMatchClass = n1ConstOperand; }
31 def bblabel : Operand<i32>;
32 def bbl     : SDNode<"ISD::BasicBlock", SDTPtrLeaf, [], "BasicBlockSDNode">;