| |
| ; RUN: clspv-opt -ReplaceOpenCLBuiltin %s -o %t.ll |
| ; RUN: FileCheck %s < %t.ll |
| |
| ; AUTO-GENERATED TEST FILE |
| ; This test was generated by add_sat_test_gen.cpp. |
| ; Please modify the that file and regenerate the tests to make changes. |
| |
| target datalayout = "e-p:32:32-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024" |
| target triple = "spir-unknown-unknown" |
| |
| define <2 x i8> @hadd_uchar2(<2 x i8> %a, <2 x i8> %b) { |
| entry: |
| %call = call <2 x i8> @_Z4haddDv2_hS_(<2 x i8> %a, <2 x i8> %b) |
| ret <2 x i8> %call |
| } |
| |
| declare <2 x i8> @_Z4haddDv2_hS_(<2 x i8>, <2 x i8>) |
| |
| ; CHECK: [[a_shr:%[a-zA_Z0-9_.]+]] = lshr <2 x i8> %a, <i8 1, i8 1> |
| ; CHECK: [[b_shr:%[a-zA-Z0-9_.]+]] = lshr <2 x i8> %b, <i8 1, i8 1> |
| ; CHECK: [[add:%[a-zA-Z0-9_.]+]] = add <2 x i8> [[a_shr]], [[b_shr]] |
| ; CHECK: [[join:%[a-zA-Z0-9_.]+]] = and <2 x i8> %a, %b |
| ; CHECK: [[and:%[a-zA-Z0-9_.]+]] = and <2 x i8> [[join]], <i8 1, i8 1> |
| ; CHECK: [[hadd:%[a-zA-Z0-9_.]+]] = add <2 x i8> [[add]], [[and]] |
| ; CHECK: ret <2 x i8> [[hadd]] |