Jan Vesely | af62cf4 | 2014-10-17 14:45:25 +0000 | [diff] [blame] | 1 | ; 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 |
| 9 | define 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 |
| 21 | define 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 | } |