Mercurial > hg > CbC > CbC_llvm
comparison test/CodeGen/R600/mad_int24.ll @ 77:54457678186b LLVM3.6
LLVM 3.6
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Mon, 08 Sep 2014 22:06:00 +0900 |
parents | 95c75e76d11b |
children | 60c9769439b8 |
comparison
equal
deleted
inserted
replaced
34:e874dbf0ad9d | 77:54457678186b |
---|---|
1 ; RUN: llc < %s -march=r600 -mcpu=redwood | FileCheck %s --check-prefix=EG-CHECK | 1 ; RUN: llc < %s -march=r600 -mcpu=redwood | FileCheck %s --check-prefix=EG --check-prefix=FUNC |
2 ; RUN: llc < %s -march=r600 -mcpu=cayman | FileCheck %s --check-prefix=CM-CHECK | 2 ; RUN: llc < %s -march=r600 -mcpu=cayman | FileCheck %s --check-prefix=CM --check-prefix=FUNC |
3 ; RUN: llc < %s -march=r600 -mcpu=SI -verify-machineinstrs | FileCheck %s --check-prefix=SI-CHECK | 3 ; RUN: llc < %s -march=r600 -mcpu=SI -verify-machineinstrs | FileCheck %s --check-prefix=SI --check-prefix=FUNC |
4 | 4 |
5 ; EG-CHECK: @i32_mad24 | 5 ; FUNC-LABEL: @i32_mad24 |
6 ; Signed 24-bit multiply is not supported on pre-Cayman GPUs. | 6 ; Signed 24-bit multiply is not supported on pre-Cayman GPUs. |
7 ; EG-CHECK: MULLO_INT | 7 ; EG: MULLO_INT |
8 ; CM-CHECK: MULADD_INT24 {{[ *]*}}T{{[0-9].[XYZW]}}, KC0[2].Z, KC0[2].W, KC0[3].X | 8 ; Make sure we aren't masking the inputs. |
9 ; SI-CHECK: V_MAD_I32_I24 | 9 ; CM-NOT: AND |
10 ; CM: MULADD_INT24 | |
11 ; SI-NOT: AND | |
12 ; SI: V_MAD_I32_I24 | |
10 define void @i32_mad24(i32 addrspace(1)* %out, i32 %a, i32 %b, i32 %c) { | 13 define void @i32_mad24(i32 addrspace(1)* %out, i32 %a, i32 %b, i32 %c) { |
11 entry: | 14 entry: |
12 %0 = shl i32 %a, 8 | 15 %0 = shl i32 %a, 8 |
13 %a_24 = ashr i32 %0, 8 | 16 %a_24 = ashr i32 %0, 8 |
14 %1 = shl i32 %b, 8 | 17 %1 = shl i32 %b, 8 |