| Matt Arsenault | 59b09ab | 2015-01-15 19:39:42 +0000 | [diff] [blame] | 1 | ; RUN: llc -march=amdgcn -mcpu=SI -verify-machineinstrs < %s | FileCheck -check-prefix=SI -check-prefix=FUNC %s | 
| Niels Ole Salscheider | 719fbc9 | 2013-08-08 16:06:15 +0000 | [diff] [blame] | 2 |  | 
| Matt Arsenault | 59b09ab | 2015-01-15 19:39:42 +0000 | [diff] [blame] | 3 | ; FUNC-LABEL: {{^}}fptrunc_f64_to_f32: | 
|  | 4 | ; SI: v_cvt_f32_f64_e32 {{v[0-9]+}}, {{s\[[0-9]+:[0-9]+\]}} | 
|  | 5 | define void @fptrunc_f64_to_f32(float addrspace(1)* %out, double %in) { | 
| Niels Ole Salscheider | 719fbc9 | 2013-08-08 16:06:15 +0000 | [diff] [blame] | 6 | %result = fptrunc double %in to float | 
|  | 7 | store float %result, float addrspace(1)* %out | 
|  | 8 | ret void | 
|  | 9 | } | 
| Matt Arsenault | 59b09ab | 2015-01-15 19:39:42 +0000 | [diff] [blame] | 10 |  | 
|  | 11 | ; FUNC-LABEL: {{^}}fptrunc_v2f64_to_v2f32: | 
|  | 12 | ; SI: v_cvt_f32_f64_e32 | 
|  | 13 | ; SI: v_cvt_f32_f64_e32 | 
|  | 14 | define void @fptrunc_v2f64_to_v2f32(<2 x float> addrspace(1)* %out, <2 x double> %in) { | 
|  | 15 | %result = fptrunc <2 x double> %in to <2 x float> | 
|  | 16 | store <2 x float> %result, <2 x float> addrspace(1)* %out | 
|  | 17 | ret void | 
|  | 18 | } | 
|  | 19 |  | 
|  | 20 | ; FUNC-LABEL: {{^}}fptrunc_v4f64_to_v4f32: | 
|  | 21 | ; SI: v_cvt_f32_f64_e32 | 
|  | 22 | ; SI: v_cvt_f32_f64_e32 | 
|  | 23 | ; SI: v_cvt_f32_f64_e32 | 
|  | 24 | ; SI: v_cvt_f32_f64_e32 | 
|  | 25 | define void @fptrunc_v4f64_to_v4f32(<4 x float> addrspace(1)* %out, <4 x double> %in) { | 
|  | 26 | %result = fptrunc <4 x double> %in to <4 x float> | 
|  | 27 | store <4 x float> %result, <4 x float> addrspace(1)* %out | 
|  | 28 | ret void | 
|  | 29 | } | 
|  | 30 |  | 
|  | 31 | ; FUNC-LABEL: {{^}}fptrunc_v8f64_to_v8f32: | 
|  | 32 | ; SI: v_cvt_f32_f64_e32 | 
|  | 33 | ; SI: v_cvt_f32_f64_e32 | 
|  | 34 | ; SI: v_cvt_f32_f64_e32 | 
|  | 35 | ; SI: v_cvt_f32_f64_e32 | 
|  | 36 | ; SI: v_cvt_f32_f64_e32 | 
|  | 37 | ; SI: v_cvt_f32_f64_e32 | 
|  | 38 | ; SI: v_cvt_f32_f64_e32 | 
|  | 39 | ; SI: v_cvt_f32_f64_e32 | 
|  | 40 | define void @fptrunc_v8f64_to_v8f32(<8 x float> addrspace(1)* %out, <8 x double> %in) { | 
|  | 41 | %result = fptrunc <8 x double> %in to <8 x float> | 
|  | 42 | store <8 x float> %result, <8 x float> addrspace(1)* %out | 
|  | 43 | ret void | 
|  | 44 | } |