Bruno Cardoso Lopes | 6a32adc | 2011-07-25 23:05:25 +0000 | [diff] [blame] | 1 | ; RUN: llc < %s -mtriple=x86_64-apple-darwin -mcpu=corei7-avx -mattr=+avx | FileCheck %s |
Bruno Cardoso Lopes | 8c05a85 | 2010-08-12 02:06:36 +0000 | [diff] [blame] | 2 | |
| 3 | @x = common global <8 x float> zeroinitializer, align 32 |
| 4 | @y = common global <4 x double> zeroinitializer, align 32 |
Bruno Cardoso Lopes | b33ea56 | 2011-08-09 03:04:23 +0000 | [diff] [blame] | 5 | @z = common global <4 x float> zeroinitializer, align 16 |
Bruno Cardoso Lopes | 8c05a85 | 2010-08-12 02:06:36 +0000 | [diff] [blame] | 6 | |
Bruno Cardoso Lopes | b33ea56 | 2011-08-09 03:04:23 +0000 | [diff] [blame] | 7 | define void @zero128() nounwind ssp { |
| 8 | entry: |
| 9 | ; CHECK: vxorps |
| 10 | ; CHECK: vmovaps |
| 11 | store <4 x float> zeroinitializer, <4 x float>* @z, align 16 |
| 12 | ret void |
| 13 | } |
| 14 | |
| 15 | define void @zero256() nounwind ssp { |
Bruno Cardoso Lopes | 8c05a85 | 2010-08-12 02:06:36 +0000 | [diff] [blame] | 16 | entry: |
| 17 | ; CHECK: vxorps |
| 18 | ; CHECK: vmovaps |
| 19 | ; CHECK: vmovaps |
| 20 | store <8 x float> zeroinitializer, <8 x float>* @x, align 32 |
| 21 | store <4 x double> zeroinitializer, <4 x double>* @y, align 32 |
| 22 | ret void |
| 23 | } |
Bruno Cardoso Lopes | 863bd9d | 2011-07-25 23:05:32 +0000 | [diff] [blame] | 24 | |
| 25 | ; CHECK: vpcmpeqd |
| 26 | ; CHECK: vinsertf128 $1 |
| 27 | define void @ones([0 x float]* nocapture %RET, [0 x float]* nocapture %aFOO) nounwind { |
| 28 | allocas: |
| 29 | %ptr2vec615 = bitcast [0 x float]* %RET to <8 x float>* |
| 30 | store <8 x float> <float 0xFFFFFFFFE0000000, float 0xFFFFFFFFE0000000, float |
| 31 | 0xFFFFFFFFE0000000, float 0xFFFFFFFFE0000000, float 0xFFFFFFFFE0000000, float |
| 32 | 0xFFFFFFFFE0000000, float 0xFFFFFFFFE0000000, float 0xFFFFFFFFE0000000>, <8 x |
| 33 | float>* %ptr2vec615, align 32 |
| 34 | ret void |
| 35 | } |
Bruno Cardoso Lopes | 531f19f | 2011-08-01 19:51:53 +0000 | [diff] [blame] | 36 | |
| 37 | ; CHECK: vpcmpeqd |
| 38 | ; CHECK: vinsertf128 $1 |
| 39 | define void @ones2([0 x i32]* nocapture %RET, [0 x i32]* nocapture %aFOO) nounwind { |
| 40 | allocas: |
| 41 | %ptr2vec615 = bitcast [0 x i32]* %RET to <8 x i32>* |
| 42 | store <8 x i32> <i32 -1, i32 -1, i32 -1, i32 -1, i32 -1, i32 -1, i32 -1, i32 -1>, <8 x i32>* %ptr2vec615, align 32 |
| 43 | ret void |
| 44 | } |