blob: 7dc6eb87f6b5a19dd863af43dab005a17cf242ed [file] [log] [blame]
Jan Veselyaf62cf42014-10-17 14:45:25 +00001; RUN: llc -march=r600 -mcpu=cypress -verify-machineinstrs < %s | FileCheck -check-prefix=EG -check-prefix=FUNC %s
2
3
4; FUNC-LABEL: {{^}}sext_in_reg_i1_i32_add:
5
6; EG: MEM_{{.*}} STORE_{{.*}} [[RES:T[0-9]+\.[XYZW]]], [[ADDR:T[0-9]+.[XYZW]]]
7; EG: SUB_INT {{[* ]*}}[[RES]]
8; EG-NOT: BFE
9define void @sext_in_reg_i1_i32_add(i32 addrspace(1)* %out, i1 %a, i32 %b) {
10 %sext = sext i1 %a to i32
11 %res = add i32 %b, %sext
12 store i32 %res, i32 addrspace(1)* %out
13 ret void
14}
15
16; FUNC-LABEL: {{^}}sext_in_reg_i1_i32_sub:
17
18; EG: MEM_{{.*}} STORE_{{.*}} [[RES:T[0-9]+\.[XYZW]]], [[ADDR:T[0-9]+.[XYZW]]]
19; EG: ADD_INT {{[* ]*}}[[RES]]
20; EG-NOT: BFE
21define void @sext_in_reg_i1_i32_sub(i32 addrspace(1)* %out, i1 %a, i32 %b) {
22 %sext = sext i1 %a to i32
23 %res = sub i32 %b, %sext
24 store i32 %res, i32 addrspace(1)* %out
25 ret void
26}