forked from OSchip/llvm-project
273 lines
5.5 KiB
LLVM
273 lines
5.5 KiB
LLVM
; RUN: llc -march=arc < %s | FileCheck %s
|
|
|
|
; CHECK-LABEL: add_r
|
|
; CHECK: add %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @add_r(i32 %a, i32 %b) nounwind {
|
|
entry:
|
|
%v = add i32 %a, %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: add_u6
|
|
; CHECK: add %r0, %r0, 15
|
|
define i32 @add_u6(i32 %a) nounwind {
|
|
%v = add i32 %a, 15
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: add_limm
|
|
; CHECK: add %r0, %r0, 12345
|
|
define i32 @add_limm(i32 %a) nounwind {
|
|
%v = add i32 %a, 12345
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: mpy_r
|
|
; CHECK: mpy %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @mpy_r(i32 %a, i32 %b) nounwind {
|
|
entry:
|
|
%v = mul i32 %a, %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: mpy_u6
|
|
; CHECK: mpy %r0, %r0, 10
|
|
define i32 @mpy_u6(i32 %a) nounwind {
|
|
%v = mul i32 %a, 10
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: mpy_limm
|
|
; CHECK: mpy %r0, %r0, 12345
|
|
define i32 @mpy_limm(i32 %a) nounwind {
|
|
%v = mul i32 %a, 12345
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: max_r
|
|
; CHECK: max %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @max_r(i32 %a, i32 %b) nounwind {
|
|
%i = icmp sgt i32 %a, %b
|
|
%v = select i1 %i, i32 %a, i32 %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: max_u6
|
|
; CHECK: max %r0, %r0, 12
|
|
define i32 @max_u6(i32 %a) nounwind {
|
|
%i = icmp sgt i32 %a, 12
|
|
%v = select i1 %i, i32 %a, i32 12
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: max_limm
|
|
; CHECK: max %r0, %r0, 2345
|
|
define i32 @max_limm(i32 %a) nounwind {
|
|
%i = icmp sgt i32 %a, 2345
|
|
%v = select i1 %i, i32 %a, i32 2345
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: min_r
|
|
; CHECK: min %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @min_r(i32 %a, i32 %b) nounwind {
|
|
%i = icmp slt i32 %a, %b
|
|
%v = select i1 %i, i32 %a, i32 %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: min_u6
|
|
; CHECK: min %r0, %r0, 20
|
|
define i32 @min_u6(i32 %a) nounwind {
|
|
%i = icmp slt i32 %a, 20
|
|
%v = select i1 %i, i32 %a, i32 20
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: min_limm
|
|
; CHECK: min %r0, %r0, 2040
|
|
define i32 @min_limm(i32 %a) nounwind {
|
|
%i = icmp slt i32 %a, 2040
|
|
%v = select i1 %i, i32 %a, i32 2040
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: and_r
|
|
; CHECK: and %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @and_r(i32 %a, i32 %b) nounwind {
|
|
%v = and i32 %a, %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: and_u6
|
|
; CHECK: and %r0, %r0, 7
|
|
define i32 @and_u6(i32 %a) nounwind {
|
|
%v = and i32 %a, 7
|
|
ret i32 %v
|
|
}
|
|
|
|
; 0xfffff == 1048575
|
|
; CHECK-LABEL: and_limm
|
|
; CHECK: and %r0, %r0, 1048575
|
|
define i32 @and_limm(i32 %a) nounwind {
|
|
%v = and i32 %a, 1048575
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: or_r
|
|
; CHECK: or %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @or_r(i32 %a, i32 %b) nounwind {
|
|
%v = or i32 %a, %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: or_u6
|
|
; CHECK: or %r0, %r0, 7
|
|
define i32 @or_u6(i32 %a) nounwind {
|
|
%v = or i32 %a, 7
|
|
ret i32 %v
|
|
}
|
|
|
|
; 0xf0f0f == 986895
|
|
; CHECK-LABEL: or_limm
|
|
define i32 @or_limm(i32 %a) nounwind {
|
|
%v = or i32 %a, 986895
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: xor_r
|
|
; CHECK: xor %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @xor_r(i32 %a, i32 %b) nounwind {
|
|
%v = xor i32 %a, %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: xor_u6
|
|
; CHECK: xor %r0, %r0, 3
|
|
define i32 @xor_u6(i32 %a) nounwind {
|
|
%v = xor i32 %a, 3
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: xor_limm
|
|
; CHECK: xor %r0, %r0, 986895
|
|
define i32 @xor_limm(i32 %a) nounwind {
|
|
%v = xor i32 %a, 986895
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: asl_r
|
|
; CHECK: asl %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @asl_r(i32 %a, i32 %b) nounwind {
|
|
%v = shl i32 %a, %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: asl_u6
|
|
; CHECK: asl %r0, %r0, 4
|
|
define i32 @asl_u6(i32 %a) nounwind {
|
|
%v = shl i32 %a, 4
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: lsr_r
|
|
; CHECK: lsr %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @lsr_r(i32 %a, i32 %b) nounwind {
|
|
%v = lshr i32 %a, %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: lsr_u6
|
|
; CHECK: lsr %r0, %r0, 6
|
|
define i32 @lsr_u6(i32 %a) nounwind {
|
|
%v = lshr i32 %a, 6
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: asr_r
|
|
; CHECK: asr %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @asr_r(i32 %a, i32 %b) nounwind {
|
|
%v = ashr i32 %a, %b
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: asr_u6
|
|
; CHECK: asr %r0, %r0, 8
|
|
define i32 @asr_u6(i32 %a) nounwind {
|
|
%v = ashr i32 %a, 8
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: ror_r
|
|
; CHECK: ror %r0, %r{{[01]}}, %r{{[01]}}
|
|
define i32 @ror_r(i32 %a, i32 %b) nounwind {
|
|
%v1 = lshr i32 %a, %b
|
|
%ls = sub i32 32, %b
|
|
%v2 = shl i32 %a, %ls
|
|
%v = or i32 %v1, %v2
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: ror_u6
|
|
; CHECK: ror %r0, %r0, 10
|
|
define i32 @ror_u6(i32 %a) nounwind {
|
|
%v1 = lshr i32 %a, 10
|
|
%v2 = shl i32 %a, 22
|
|
%v = or i32 %v1, %v2
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: sexh_r
|
|
; CHECK: sexh %r0, %r0
|
|
define i32 @sexh_r(i32 %a) nounwind {
|
|
%v1 = shl i32 %a, 16
|
|
%v = ashr i32 %v1, 16
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: sexb_r
|
|
; CHECK: sexb %r0, %r0
|
|
define i32 @sexb_r(i32 %a) nounwind {
|
|
%v1 = shl i32 %a, 24
|
|
%v = ashr i32 %v1, 24
|
|
ret i32 %v
|
|
}
|
|
|
|
; CHECK-LABEL: mulu64
|
|
; CHECK-DAG: mpy %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
|
|
; CHECK-DAG: mpymu %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
|
|
define i64 @mulu64(i32 %a, i32 %b) nounwind {
|
|
%a64 = zext i32 %a to i64
|
|
%b64 = zext i32 %b to i64
|
|
%v = mul i64 %a64, %b64
|
|
ret i64 %v
|
|
}
|
|
|
|
; CHECK-LABEL: muls64
|
|
; CHECK-DAG: mpy %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
|
|
; CHECK-DAG: mpym %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
|
|
define i64 @muls64(i32 %a, i32 %b) nounwind {
|
|
%a64 = sext i32 %a to i64
|
|
%b64 = sext i32 %b to i64
|
|
%v = mul i64 %a64, %b64
|
|
ret i64 %v
|
|
}
|
|
|
|
; CHECK-LABEL: long_long_add
|
|
; CHECK: add.f %r0, %r0, %r2
|
|
; CHECK-NEXT: adc.f %r1, %r1, %r3
|
|
define i64 @long_long_add(i64 inreg %a, i64 inreg %b) #0 {
|
|
entry:
|
|
%add = add nsw i64 %a, %b
|
|
ret i64 %add
|
|
}
|
|
|
|
; CHECK-LABEL: long_long_sub
|
|
; CHECK: sub.f %r0, %r0, %r2
|
|
; CHECK-NEXT: sbc.f %r1, %r1, %r3
|
|
define i64 @long_long_sub(i64 inreg %a, i64 inreg %b) #0 {
|
|
entry:
|
|
%sub = sub nsw i64 %a, %b
|
|
ret i64 %sub
|
|
}
|