diff --git a/src/etc/platform-intrinsics/x86/avx.json b/src/etc/platform-intrinsics/x86/avx.json index 08524fbd6dd8..05a4721aed83 100644 --- a/src/etc/platform-intrinsics/x86/avx.json +++ b/src/etc/platform-intrinsics/x86/avx.json @@ -8,6 +8,13 @@ "ret": "f(32-64)", "args": ["0", "0"] }, + { + "intrinsic": "256_blendv_{0.data_type}", + "width": [256], + "llvm": "blendv.{0.data_type}.256", + "ret": "f(32-64)", + "args": ["0", "0", "0"] + }, { "intrinsic": "256_broadcast_{0.data_type}", "width": [256], @@ -15,6 +22,13 @@ "ret": "f(32-64)", "args": ["s8SPc"] }, + { + "intrinsic": "256_cmp_{0.data_type}", + "width": [256], + "llvm": "cmp.{1.data_type}.256", + "ret": "f(32-64)", + "args": ["0", "0", "s8S"] + }, { "intrinsic": "256_cvtepi32_pd", "width": [256], diff --git a/src/librustc_platform_intrinsics/x86.rs b/src/librustc_platform_intrinsics/x86.rs index d8aaf151267f..c5d3e414c7ca 100644 --- a/src/librustc_platform_intrinsics/x86.rs +++ b/src/librustc_platform_intrinsics/x86.rs @@ -498,6 +498,16 @@ pub fn find<'tcx>(_tcx: &TyCtxt<'tcx>, name: &str) -> Option { output: v(f(64), 4), definition: Named("llvm.x86.avx.addsub.pd.256") }, + "256_blendv_ps" => Intrinsic { + inputs: vec![v(f(32), 8), v(f(32), 8), v(f(32), 8)], + output: v(f(32), 8), + definition: Named("llvm.x86.avx.blendv.ps.256") + }, + "256_blendv_pd" => Intrinsic { + inputs: vec![v(f(64), 4), v(f(64), 4), v(f(64), 4)], + output: v(f(64), 4), + definition: Named("llvm.x86.avx.blendv.pd.256") + }, "256_broadcast_ps" => Intrinsic { inputs: vec![p(true, i(8), None)], output: v(f(32), 8), @@ -508,6 +518,16 @@ pub fn find<'tcx>(_tcx: &TyCtxt<'tcx>, name: &str) -> Option { output: v(f(64), 4), definition: Named("llvm.x86.avx.vbroadcastf128.pd.256") }, + "256_cmp_ps" => Intrinsic { + inputs: vec![v(f(32), 8), v(f(32), 8), i(8)], + output: v(f(32), 8), + definition: Named("llvm.x86.avx.cmp.ps.256") + }, + "256_cmp_pd" => Intrinsic { + inputs: vec![v(f(64), 4), v(f(64), 4), i(8)], + output: v(f(64), 4), + definition: Named("llvm.x86.avx.cmp.pd.256") + }, "256_cvtepi32_pd" => Intrinsic { inputs: vec![v(i(32), 4)], output: v(f(64), 4),