#llvm #workaround #bad #boolean #codegen #arm #32-bit

nightly any_all_workaround

Workaround for bad LLVM codegen for boolean reductions on 32-bit ARM

1 unstable release

0.1.0 Apr 9, 2024

#971 in Programming languages

Download history 85/week @ 2024-07-20 122/week @ 2024-07-27 73/week @ 2024-08-03 144/week @ 2024-08-10 103/week @ 2024-08-17 234/week @ 2024-08-24 103/week @ 2024-08-31 92/week @ 2024-09-07 110/week @ 2024-09-14 142/week @ 2024-09-21 119/week @ 2024-09-28 104/week @ 2024-10-05 538/week @ 2024-10-12 178/week @ 2024-10-19 365/week @ 2024-10-26 88/week @ 2024-11-02

1,175 downloads per month
Used in 3 crates (via encoding_rs)

MIT/Apache

7KB
91 lines

any_all_workaround

This is a workaround for bad codegen (Rust bug, LLVM bug) for the any() and all() reductions for NEON-backed SIMD vectors on 32-bit ARM. On other platforms these delegate to any() and all() in core::simd.

The plan is to abandon this crate once the LLVM bug is fixed or core::simd works around the LLVM bug.

The code is forked from the packed_simd crate.

This crate requires Nightly Rust as it depends on the portable_simd feature.

License

MIT OR Apache-2.0, since that's how packed_simd is licensed.

Dependencies

~4KB