Mercurial > hg > Members > tobaru > cbc > CbC_llvm
view test/CodeGen/X86/pmovsx-inreg.ll @ 33:e4204d083e25
LLVM 3.5
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Thu, 12 Dec 2013 14:32:10 +0900 |
parents | 95c75e76d11b |
children | afa8332a0e37 |
line wrap: on
line source
; RUN: llc < %s -march=x86-64 -mcpu=penryn | FileCheck -check-prefix=SSE41 %s ; RUN: llc < %s -march=x86-64 -mcpu=corei7-avx | FileCheck -check-prefix=AVX1 %s ; RUN: llc < %s -march=x86-64 -mcpu=core-avx2 | FileCheck -check-prefix=AVX2 %s ; PR14887 ; These tests inject a store into the chain to test the inreg versions of pmovsx define void @test1(<2 x i8>* %in, <2 x i64>* %out) nounwind { %wide.load35 = load <2 x i8>* %in, align 1 %sext = sext <2 x i8> %wide.load35 to <2 x i64> store <2 x i64> zeroinitializer, <2 x i64>* undef, align 8 store <2 x i64> %sext, <2 x i64>* %out, align 8 ret void ; SSE41-LABEL: test1: ; SSE41: pmovsxbq ; AVX1-LABEL: test1: ; AVX1: vpmovsxbq ; AVX2-LABEL: test1: ; AVX2: vpmovsxbq } define void @test2(<4 x i8>* %in, <4 x i64>* %out) nounwind { %wide.load35 = load <4 x i8>* %in, align 1 %sext = sext <4 x i8> %wide.load35 to <4 x i64> store <4 x i64> zeroinitializer, <4 x i64>* undef, align 8 store <4 x i64> %sext, <4 x i64>* %out, align 8 ret void ; AVX2-LABEL: test2: ; AVX2: vpmovsxbq } define void @test3(<4 x i8>* %in, <4 x i32>* %out) nounwind { %wide.load35 = load <4 x i8>* %in, align 1 %sext = sext <4 x i8> %wide.load35 to <4 x i32> store <4 x i32> zeroinitializer, <4 x i32>* undef, align 8 store <4 x i32> %sext, <4 x i32>* %out, align 8 ret void ; SSE41-LABEL: test3: ; SSE41: pmovsxbd ; AVX1-LABEL: test3: ; AVX1: vpmovsxbd ; AVX2-LABEL: test3: ; AVX2: vpmovsxbd } define void @test4(<8 x i8>* %in, <8 x i32>* %out) nounwind { %wide.load35 = load <8 x i8>* %in, align 1 %sext = sext <8 x i8> %wide.load35 to <8 x i32> store <8 x i32> zeroinitializer, <8 x i32>* undef, align 8 store <8 x i32> %sext, <8 x i32>* %out, align 8 ret void ; AVX2-LABEL: test4: ; AVX2: vpmovsxbd } define void @test5(<8 x i8>* %in, <8 x i16>* %out) nounwind { %wide.load35 = load <8 x i8>* %in, align 1 %sext = sext <8 x i8> %wide.load35 to <8 x i16> store <8 x i16> zeroinitializer, <8 x i16>* undef, align 8 store <8 x i16> %sext, <8 x i16>* %out, align 8 ret void ; SSE41-LABEL: test5: ; SSE41: pmovsxbw ; AVX1-LABEL: test5: ; AVX1: vpmovsxbw ; AVX2-LABEL: test5: ; AVX2: vpmovsxbw } define void @test6(<16 x i8>* %in, <16 x i16>* %out) nounwind { %wide.load35 = load <16 x i8>* %in, align 1 %sext = sext <16 x i8> %wide.load35 to <16 x i16> store <16 x i16> zeroinitializer, <16 x i16>* undef, align 8 store <16 x i16> %sext, <16 x i16>* %out, align 8 ret void ; AVX2-LABEL: test6: ; AVX2: vpmovsxbw } define void @test7(<2 x i16>* %in, <2 x i64>* %out) nounwind { %wide.load35 = load <2 x i16>* %in, align 1 %sext = sext <2 x i16> %wide.load35 to <2 x i64> store <2 x i64> zeroinitializer, <2 x i64>* undef, align 8 store <2 x i64> %sext, <2 x i64>* %out, align 8 ret void ; SSE41-LABEL: test7: ; SSE41: pmovsxwq ; AVX1-LABEL: test7: ; AVX1: vpmovsxwq ; AVX2-LABEL: test7: ; AVX2: vpmovsxwq } define void @test8(<4 x i16>* %in, <4 x i64>* %out) nounwind { %wide.load35 = load <4 x i16>* %in, align 1 %sext = sext <4 x i16> %wide.load35 to <4 x i64> store <4 x i64> zeroinitializer, <4 x i64>* undef, align 8 store <4 x i64> %sext, <4 x i64>* %out, align 8 ret void ; AVX2-LABEL: test8: ; AVX2: vpmovsxwq } define void @test9(<4 x i16>* %in, <4 x i32>* %out) nounwind { %wide.load35 = load <4 x i16>* %in, align 1 %sext = sext <4 x i16> %wide.load35 to <4 x i32> store <4 x i32> zeroinitializer, <4 x i32>* undef, align 8 store <4 x i32> %sext, <4 x i32>* %out, align 8 ret void ; SSE41-LABEL: test9: ; SSE41: pmovsxwd ; AVX1-LABEL: test9: ; AVX1: vpmovsxwd ; AVX2-LABEL: test9: ; AVX2: vpmovsxwd } define void @test10(<8 x i16>* %in, <8 x i32>* %out) nounwind { %wide.load35 = load <8 x i16>* %in, align 1 %sext = sext <8 x i16> %wide.load35 to <8 x i32> store <8 x i32> zeroinitializer, <8 x i32>* undef, align 8 store <8 x i32> %sext, <8 x i32>* %out, align 8 ret void ; AVX2-LABEL: test10: ; AVX2: vpmovsxwd } define void @test11(<2 x i32>* %in, <2 x i64>* %out) nounwind { %wide.load35 = load <2 x i32>* %in, align 1 %sext = sext <2 x i32> %wide.load35 to <2 x i64> store <2 x i64> zeroinitializer, <2 x i64>* undef, align 8 store <2 x i64> %sext, <2 x i64>* %out, align 8 ret void ; SSE41-LABEL: test11: ; SSE41: pmovsxdq ; AVX1-LABEL: test11: ; AVX1: vpmovsxdq ; AVX2-LABEL: test11: ; AVX2: vpmovsxdq } define void @test12(<4 x i32>* %in, <4 x i64>* %out) nounwind { %wide.load35 = load <4 x i32>* %in, align 1 %sext = sext <4 x i32> %wide.load35 to <4 x i64> store <4 x i64> zeroinitializer, <4 x i64>* undef, align 8 store <4 x i64> %sext, <4 x i64>* %out, align 8 ret void ; AVX2-LABEL: test12: ; AVX2: vpmovsxdq }