about summary refs log tree commit diff
diff options
context:
space:
mode:
authorJubilee Young <workingjubilee@gmail.com>2024-05-19 18:50:42 -0700
committerJubilee Young <workingjubilee@gmail.com>2024-05-19 18:50:42 -0700
commit7a53ba2e764d4e953ec654b73a6222163482db88 (patch)
treea7f7ccb1a04222b255d2ed3e65d70022a4fbc67f
parent8aa7112c82416cfaf0fb63db2467d45fdb0407bc (diff)
downloadrust-7a53ba2e764d4e953ec654b73a6222163482db88.tar.gz
rust-7a53ba2e764d4e953ec654b73a6222163482db88.zip
cg_clif: support simd_ctpop
-rw-r--r--src/intrinsics/simd.rs2
1 files changed, 2 insertions, 0 deletions
diff --git a/src/intrinsics/simd.rs b/src/intrinsics/simd.rs
index 452b5988dab..b17f191ce26 100644
--- a/src/intrinsics/simd.rs
+++ b/src/intrinsics/simd.rs
@@ -348,6 +348,7 @@ pub(super) fn codegen_simd_intrinsic_call<'tcx>(
         | sym::simd_bswap
         | sym::simd_bitreverse
         | sym::simd_ctlz
+        | sym::simd_ctpop
         | sym::simd_cttz => {
             intrinsic_args!(fx, args => (a); intrinsic);
 
@@ -367,6 +368,7 @@ pub(super) fn codegen_simd_intrinsic_call<'tcx>(
                 (ty::Uint(_) | ty::Int(_), sym::simd_bswap) => fx.bcx.ins().bswap(lane),
                 (ty::Uint(_) | ty::Int(_), sym::simd_bitreverse) => fx.bcx.ins().bitrev(lane),
                 (ty::Uint(_) | ty::Int(_), sym::simd_ctlz) => fx.bcx.ins().clz(lane),
+                (ty::Uint(_) | ty::Int(_), sym::simd_ctpop) => fx.bcx.ins().popcnt(lane),
                 (ty::Uint(_) | ty::Int(_), sym::simd_cttz) => fx.bcx.ins().ctz(lane),
 
                 _ => unreachable!(),