223 lines
5.5 KiB
LLVM
223 lines
5.5 KiB
LLVM
; RUN: llc -O1 < %s -march=mips64 -mcpu=octeon | FileCheck %s -check-prefixes=ALL,OCTEON
|
|
; RUN: llc -O1 < %s -march=mips64 -mcpu=mips64 | FileCheck %s -check-prefixes=ALL,MIPS64
|
|
; RUN: llc -O1 < %s -march=mips64 -mcpu=octeon -relocation-model=pic | FileCheck %s -check-prefixes=ALL,OCTEON-PIC
|
|
|
|
define i64 @addi64(i64 %a, i64 %b) nounwind {
|
|
entry:
|
|
; ALL-LABEL: addi64:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: baddu $2, $4, $5
|
|
; MIPS64: daddu $[[T0:[0-9]+]], $4, $5
|
|
; MIPS64: jr $ra
|
|
; MIPS64: andi $2, $[[T0]], 255
|
|
%add = add i64 %a, %b
|
|
%and = and i64 %add, 255
|
|
ret i64 %and
|
|
}
|
|
|
|
define i64 @mul(i64 %a, i64 %b) nounwind {
|
|
entry:
|
|
; ALL-LABEL: mul:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: dmul $2, $4, $5
|
|
; MIPS64: dmult $4, $5
|
|
; MIPS64: jr $ra
|
|
; MIPS64: mflo $2
|
|
%res = mul i64 %a, %b
|
|
ret i64 %res
|
|
}
|
|
|
|
define i64 @cmpeq(i64 %a, i64 %b) nounwind {
|
|
entry:
|
|
; ALL-LABEL: cmpeq:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: seq $2, $4, $5
|
|
; MIPS64: xor $[[T0:[0-9]+]], $4, $5
|
|
; MIPS64: sltiu $[[T1:[0-9]+]], $[[T0]], 1
|
|
; MIPS64: dsll $[[T2:[0-9]+]], $[[T1]], 32
|
|
; MIPS64: jr $ra
|
|
; MIPS64: dsrl $2, $[[T2]], 32
|
|
%res = icmp eq i64 %a, %b
|
|
%res2 = zext i1 %res to i64
|
|
ret i64 %res2
|
|
}
|
|
|
|
define i64 @cmpeqi(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: cmpeqi:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: seqi $2, $4, 42
|
|
; MIPS64: daddiu $[[T0:[0-9]+]], $zero, 42
|
|
; MIPS64: xor $[[T1:[0-9]+]], $4, $[[T0]]
|
|
; MIPS64: sltiu $[[T2:[0-9]+]], $[[T1]], 1
|
|
; MIPS64: dsll $[[T3:[0-9]+]], $[[T2]], 32
|
|
; MIPS64: jr $ra
|
|
; MIPS64: dsrl $2, $[[T3]], 32
|
|
%res = icmp eq i64 %a, 42
|
|
%res2 = zext i1 %res to i64
|
|
ret i64 %res2
|
|
}
|
|
|
|
define i64 @cmpne(i64 %a, i64 %b) nounwind {
|
|
entry:
|
|
; ALL-LABEL: cmpne:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: sne $2, $4, $5
|
|
; MIPS64: xor $[[T0:[0-9]+]], $4, $5
|
|
; MIPS64: sltu $[[T1:[0-9]+]], $zero, $[[T0]]
|
|
; MIPS64: dsll $[[T2:[0-9]+]], $[[T1]], 32
|
|
; MIPS64: jr $ra
|
|
; MIPS64: dsrl $2, $[[T2]], 32
|
|
%res = icmp ne i64 %a, %b
|
|
%res2 = zext i1 %res to i64
|
|
ret i64 %res2
|
|
}
|
|
|
|
define i64 @cmpnei(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: cmpnei:
|
|
; OCTEON: jr $ra
|
|
; OCTEON: snei $2, $4, 42
|
|
; MIPS64: daddiu $[[T0:[0-9]+]], $zero, 42
|
|
; MIPS64: xor $[[T1:[0-9]+]], $4, $[[T0]]
|
|
; MIPS64: sltu $[[T2:[0-9]+]], $zero, $[[T1]]
|
|
; MIPS64: dsll $[[T3:[0-9]+]], $[[T2]], 32
|
|
; MIPS64: jr $ra
|
|
; MIPS64: dsrl $2, $[[T3]], 32
|
|
%res = icmp ne i64 %a, 42
|
|
%res2 = zext i1 %res to i64
|
|
ret i64 %res2
|
|
}
|
|
|
|
define i64 @bbit1(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: bbit1:
|
|
; OCTEON: bbit1 $4, 3, [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
; OCTEON-PIC-NOT: b {{[[:space:]].*}}
|
|
; OCTEON-NOT: j {{[[:space:]].*}}
|
|
; MIPS64: andi $[[T0:[0-9]+]], $4, 8
|
|
; MIPS64: bnez $[[T0]], [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
%bit = and i64 %a, 8
|
|
%res = icmp eq i64 %bit, 0
|
|
br i1 %res, label %endif, label %if
|
|
if:
|
|
ret i64 48
|
|
|
|
endif:
|
|
ret i64 12
|
|
}
|
|
|
|
define i64 @bbit132(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: bbit132:
|
|
; OCTEON: bbit132 $4, 3, [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
; OCTEON-PIC-NOT: b {{[[:space:]].*}}
|
|
; OCTEON-NOT: j {{[[:space:]].*}}
|
|
; MIPS64: daddiu $[[T0:[0-9]+]], $zero, 1
|
|
; MIPS64: dsll $[[T1:[0-9]+]], $[[T0]], 35
|
|
; MIPS64: and $[[T2:[0-9]+]], $4, $[[T1]]
|
|
; MIPS64: bnez $[[T2]], [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
%bit = and i64 %a, 34359738368
|
|
%res = icmp eq i64 %bit, 0
|
|
br i1 %res, label %endif, label %if
|
|
if:
|
|
ret i64 48
|
|
|
|
endif:
|
|
ret i64 12
|
|
}
|
|
|
|
define i64 @bbit0(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: bbit0:
|
|
; OCTEON: bbit0 $4, 3, [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
; OCTEON-PIC-NOT: b {{[[:space:]].*}}
|
|
; OCTEON-NOT: j {{[[:space:]].*}}
|
|
; MIPS64: andi $[[T0:[0-9]+]], $4, 8
|
|
; MIPS64: beqz $[[T0]], [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
%bit = and i64 %a, 8
|
|
%res = icmp ne i64 %bit, 0
|
|
br i1 %res, label %endif, label %if
|
|
if:
|
|
ret i64 48
|
|
|
|
endif:
|
|
ret i64 12
|
|
}
|
|
|
|
define i64 @bbit032(i64 %a) nounwind {
|
|
entry:
|
|
; ALL-LABEL: bbit032:
|
|
; OCTEON: bbit032 $4, 3, [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
; OCTEON-PIC-NOT: b {{[[:space:]].*}}
|
|
; OCTEON-NOT: j {{[[:space:]].*}}
|
|
; MIPS64: daddiu $[[T0:[0-9]+]], $zero, 1
|
|
; MIPS64: dsll $[[T1:[0-9]+]], $[[T0]], 35
|
|
; MIPS64: and $[[T2:[0-9]+]], $4, $[[T1]]
|
|
; MIPS64: beqz $[[T2]], [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
%bit = and i64 %a, 34359738368
|
|
%res = icmp ne i64 %bit, 0
|
|
br i1 %res, label %endif, label %if
|
|
if:
|
|
ret i64 48
|
|
|
|
endif:
|
|
ret i64 12
|
|
}
|
|
|
|
; extern void foo(void);
|
|
; long long var = 7;
|
|
; void bbit0i32 () {
|
|
; if ((var & 0x2)) {
|
|
; foo();
|
|
; }
|
|
; }
|
|
;
|
|
; void bbit1i32() {
|
|
; if (!(var & 0x2)) {
|
|
; foo();
|
|
; }
|
|
; }
|
|
|
|
@var = local_unnamed_addr global i64 7, align 8
|
|
|
|
define void @bbit0i32() local_unnamed_addr {
|
|
entry:
|
|
; ALL-LABEL: bbit0i32:
|
|
; OCTEON: bbit0 $1, 1, [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
; OCTEON-PIC-NOT: b {{[[:space:]].*}}
|
|
; OCTEON-NOT: j {{[[:space:]].*}}
|
|
%0 = load i64, i64* @var, align 8
|
|
%and = and i64 %0, 2
|
|
%tobool = icmp eq i64 %and, 0
|
|
br i1 %tobool, label %if.end, label %if.then
|
|
|
|
if.then: ; preds = %entry
|
|
tail call void @foo() #2
|
|
br label %if.end
|
|
|
|
if.end: ; preds = %entry, %if.then
|
|
ret void
|
|
}
|
|
|
|
declare void @foo() local_unnamed_addr
|
|
|
|
define void @bbit1i32() local_unnamed_addr {
|
|
entry:
|
|
; ALL-LABEL: bbit1i32:
|
|
; OCTEON: bbit1 $1, 1, [[BB0:(\$|\.L)BB[0-9_]+]]
|
|
; OCTEON-PIC-NOT: b {{[[:space:]].*}}
|
|
; OCTEON-NOT: j {{[[:space:]].*}}
|
|
%0 = load i64, i64* @var, align 8
|
|
%and = and i64 %0, 2
|
|
%tobool = icmp eq i64 %and, 0
|
|
br i1 %tobool, label %if.then, label %if.end
|
|
|
|
if.then: ; preds = %entry
|
|
tail call void @foo() #2
|
|
br label %if.end
|
|
|
|
if.end: ; preds = %entry, %if.then
|
|
ret void
|
|
}
|