|
1 | 1 | use super::{mask_impl, Mask, MaskElement};
|
2 | 2 |
|
3 |
| -/// Converts masks to and from bitmasks. |
| 3 | +/// Converts masks to and from integer bitmasks. |
4 | 4 | ///
|
5 |
| -/// In a bitmask, each bit represents if the corresponding lane in the mask is set. |
6 |
| -pub trait ToBitMask<BitMask> { |
| 5 | +/// Each bit of the bitmask corresponds to a mask lane, starting with the LSB. |
| 6 | +pub trait ToBitMask { |
| 7 | + /// The integer bitmask type. |
| 8 | + type BitMask; |
| 9 | + |
7 | 10 | /// Converts a mask to a bitmask.
|
8 |
| - fn to_bitmask(self) -> BitMask; |
| 11 | + fn to_bitmask(self) -> Self::BitMask; |
9 | 12 |
|
10 | 13 | /// Converts a bitmask to a mask.
|
11 |
| - fn from_bitmask(bitmask: BitMask) -> Self; |
| 14 | + fn from_bitmask(bitmask: Self::BitMask) -> Self; |
12 | 15 | }
|
13 | 16 |
|
14 |
| -macro_rules! impl_integer_intrinsic { |
15 |
| - { $(unsafe impl ToBitMask<$int:ty> for Mask<_, $lanes:literal>)* } => { |
16 |
| - $( |
17 |
| - impl<T: MaskElement> ToBitMask<$int> for Mask<T, $lanes> { |
18 |
| - fn to_bitmask(self) -> $int { |
19 |
| - unsafe { self.0.to_bitmask_intrinsic() } |
20 |
| - } |
| 17 | +/// Converts masks to and from byte array bitmasks. |
| 18 | +/// |
| 19 | +/// Each bit of the bitmask corresponds to a mask lane, starting with the LSB of the first byte. |
| 20 | +pub trait ToBitMaskArray { |
| 21 | + /// The length of the bitmask array. |
| 22 | + const BYTES: usize; |
21 | 23 |
|
22 |
| - fn from_bitmask(bitmask: $int) -> Self { |
23 |
| - unsafe { Self(mask_impl::Mask::from_bitmask_intrinsic(bitmask)) } |
24 |
| - } |
25 |
| - } |
26 |
| - )* |
27 |
| - } |
28 |
| -} |
| 24 | + /// Converts a mask to a bitmask. |
| 25 | + fn to_bitmask_array(self) -> [u8; Self::BYTES]; |
29 | 26 |
|
30 |
| -impl_integer_intrinsic! { |
31 |
| - unsafe impl ToBitMask<u8> for Mask<_, 8> |
32 |
| - unsafe impl ToBitMask<u16> for Mask<_, 16> |
33 |
| - unsafe impl ToBitMask<u32> for Mask<_, 32> |
34 |
| - unsafe impl ToBitMask<u64> for Mask<_, 64> |
| 27 | + /// Converts a bitmask to a mask. |
| 28 | + fn from_bitmask_array(bitmask: [u8; Self::BYTES]) -> Self; |
35 | 29 | }
|
36 | 30 |
|
37 |
| -macro_rules! impl_integer_via { |
38 |
| - { $(impl ToBitMask<$int:ty, via $via:ty> for Mask<_, $lanes:literal>)* } => { |
| 31 | +macro_rules! impl_integer_intrinsic { |
| 32 | + { $(unsafe impl ToBitMask<BitMask=$int:ty> for Mask<_, $lanes:literal>)* } => { |
39 | 33 | $(
|
40 |
| - impl<T: MaskElement> ToBitMask<$int> for Mask<T, $lanes> { |
| 34 | + impl<T: MaskElement> ToBitMask for Mask<T, $lanes> { |
| 35 | + type BitMask = $int; |
| 36 | + |
41 | 37 | fn to_bitmask(self) -> $int {
|
42 |
| - let bitmask: $via = self.to_bitmask(); |
43 |
| - bitmask as _ |
| 38 | + unsafe { self.0.to_bitmask_integer() } |
44 | 39 | }
|
45 | 40 |
|
46 | 41 | fn from_bitmask(bitmask: $int) -> Self {
|
47 |
| - Self::from_bitmask(bitmask as $via) |
| 42 | + unsafe { Self(mask_impl::Mask::from_bitmask_integer(bitmask)) } |
48 | 43 | }
|
49 | 44 | }
|
50 | 45 | )*
|
51 | 46 | }
|
52 | 47 | }
|
53 | 48 |
|
54 |
| -impl_integer_via! { |
55 |
| - impl ToBitMask<u16, via u8> for Mask<_, 8> |
56 |
| - impl ToBitMask<u32, via u8> for Mask<_, 8> |
57 |
| - impl ToBitMask<u64, via u8> for Mask<_, 8> |
58 |
| - |
59 |
| - impl ToBitMask<u32, via u16> for Mask<_, 16> |
60 |
| - impl ToBitMask<u64, via u16> for Mask<_, 16> |
61 |
| - |
62 |
| - impl ToBitMask<u64, via u32> for Mask<_, 32> |
63 |
| -} |
64 |
| - |
65 |
| -#[cfg(target_pointer_width = "32")] |
66 |
| -impl_integer_via! { |
67 |
| - impl ToBitMask<usize, via u8> for Mask<_, 8> |
68 |
| - impl ToBitMask<usize, via u16> for Mask<_, 16> |
69 |
| - impl ToBitMask<usize, via u32> for Mask<_, 32> |
70 |
| -} |
71 |
| - |
72 |
| -#[cfg(target_pointer_width = "64")] |
73 |
| -impl_integer_via! { |
74 |
| - impl ToBitMask<usize, via u8> for Mask<_, 8> |
75 |
| - impl ToBitMask<usize, via u16> for Mask<_, 16> |
76 |
| - impl ToBitMask<usize, via u32> for Mask<_, 32> |
77 |
| - impl ToBitMask<usize, via u64> for Mask<_, 64> |
| 49 | +impl_integer_intrinsic! { |
| 50 | + unsafe impl ToBitMask<BitMask=u8> for Mask<_, 8> |
| 51 | + unsafe impl ToBitMask<BitMask=u16> for Mask<_, 16> |
| 52 | + unsafe impl ToBitMask<BitMask=u32> for Mask<_, 32> |
| 53 | + unsafe impl ToBitMask<BitMask=u64> for Mask<_, 64> |
78 | 54 | }
|
0 commit comments