mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-13 07:50:50 +00:00
[Hexagon] Adding and64, or64, and xor64 instructions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@222846 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f87cce1540
commit
1df05cd7b6
@ -701,6 +701,19 @@ def A2_subp : T_ALU64_arith<"sub", 0b001, 0b111, 0, 1, 0>;
|
||||
def: Pat<(i64 (add I64:$Rs, I64:$Rt)), (A2_addp I64:$Rs, I64:$Rt)>;
|
||||
def: Pat<(i64 (sub I64:$Rs, I64:$Rt)), (A2_subp I64:$Rs, I64:$Rt)>;
|
||||
|
||||
class T_ALU64_logical<string mnemonic, bits<3> MinOp, bit OpsRev, bit IsComm,
|
||||
bit IsNeg>
|
||||
: T_ALU64_rr<mnemonic, "", 0b0011, 0b111, MinOp, OpsRev, IsComm,
|
||||
!if(IsNeg,"~","")>;
|
||||
|
||||
def A2_andp : T_ALU64_logical<"and", 0b000, 0, 1, 0>;
|
||||
def A2_orp : T_ALU64_logical<"or", 0b010, 0, 1, 0>;
|
||||
def A2_xorp : T_ALU64_logical<"xor", 0b100, 0, 1, 0>;
|
||||
|
||||
def: Pat<(i64 (and I64:$Rs, I64:$Rt)), (A2_andp I64:$Rs, I64:$Rt)>;
|
||||
def: Pat<(i64 (or I64:$Rs, I64:$Rt)), (A2_orp I64:$Rs, I64:$Rt)>;
|
||||
def: Pat<(i64 (xor I64:$Rs, I64:$Rt)), (A2_xorp I64:$Rs, I64:$Rt)>;
|
||||
|
||||
// Patfrag to convert the usual comparison patfrags (e.g. setlt) to ones
|
||||
// that reverse the order of the operands.
|
||||
class RevCmp<PatFrag F> : PatFrag<(ops node:$rhs, node:$lhs), F.Fragment>;
|
||||
|
10
test/MC/Hexagon/inst_and64.ll
Normal file
10
test/MC/Hexagon/inst_and64.ll
Normal file
@ -0,0 +1,10 @@
|
||||
;; RUN: llc -mtriple=hexagon-unknown-elf -filetype=obj %s -o - \
|
||||
;; RUN: | llvm-objdump -s - | FileCheck %s
|
||||
|
||||
define i64 @foo (i64 %a, i64 %b)
|
||||
{
|
||||
%1 = and i64 %a, %b
|
||||
ret i64 %1
|
||||
}
|
||||
|
||||
; CHECK: 0000 0042e0d3 00c09f52
|
10
test/MC/Hexagon/inst_or64.ll
Normal file
10
test/MC/Hexagon/inst_or64.ll
Normal file
@ -0,0 +1,10 @@
|
||||
;; RUN: llc -mtriple=hexagon-unknown-elf -filetype=obj %s -o - \
|
||||
;; RUN: | llvm-objdump -s - | FileCheck %s
|
||||
|
||||
define i64 @foo (i64 %a, i64 %b)
|
||||
{
|
||||
%1 = or i64 %a, %b
|
||||
ret i64 %1
|
||||
}
|
||||
|
||||
; CHECK: 0000 4042e0d3 00c09f52
|
10
test/MC/Hexagon/inst_xor64.ll
Normal file
10
test/MC/Hexagon/inst_xor64.ll
Normal file
@ -0,0 +1,10 @@
|
||||
;; RUN: llc -mtriple=hexagon-unknown-elf -filetype=obj %s -o - \
|
||||
;; RUN: | llvm-objdump -s - | FileCheck %s
|
||||
|
||||
define i64 @foo (i64 %a, i64 %b)
|
||||
{
|
||||
%1 = xor i64 %a, %b
|
||||
ret i64 %1
|
||||
}
|
||||
|
||||
; CHECK: 0000 8042e0d3 00c09f52
|
Loading…
x
Reference in New Issue
Block a user