summaryrefslogtreecommitdiffstats
path: root/library/stdarch/crates/core_arch/src/macros.rs
diff options
context:
space:
mode:
Diffstat (limited to 'library/stdarch/crates/core_arch/src/macros.rs')
-rw-r--r--library/stdarch/crates/core_arch/src/macros.rs190
1 files changed, 190 insertions, 0 deletions
diff --git a/library/stdarch/crates/core_arch/src/macros.rs b/library/stdarch/crates/core_arch/src/macros.rs
new file mode 100644
index 000000000..1e6a3f405
--- /dev/null
+++ b/library/stdarch/crates/core_arch/src/macros.rs
@@ -0,0 +1,190 @@
+//! Utility macros.
+
+// Helper struct used to trigger const eval errors when the const generic immediate value `IMM` is
+// out of `[MIN-MAX]` range.
+pub(crate) struct ValidateConstImm<const IMM: i32, const MIN: i32, const MAX: i32>;
+impl<const IMM: i32, const MIN: i32, const MAX: i32> ValidateConstImm<IMM, MIN, MAX> {
+ pub(crate) const VALID: () = {
+ assert!(IMM >= MIN && IMM <= MAX, "IMM value not in expected range");
+ };
+}
+
+#[allow(unused_macros)]
+macro_rules! static_assert_imm1 {
+ ($imm:ident) => {
+ let _ = $crate::core_arch::macros::ValidateConstImm::<$imm, 0, { (1 << 1) - 1 }>::VALID;
+ };
+}
+
+#[allow(unused_macros)]
+macro_rules! static_assert_imm2 {
+ ($imm:ident) => {
+ let _ = $crate::core_arch::macros::ValidateConstImm::<$imm, 0, { (1 << 2) - 1 }>::VALID;
+ };
+}
+
+#[allow(unused_macros)]
+macro_rules! static_assert_imm3 {
+ ($imm:ident) => {
+ let _ = $crate::core_arch::macros::ValidateConstImm::<$imm, 0, { (1 << 3) - 1 }>::VALID;
+ };
+}
+
+#[allow(unused_macros)]
+macro_rules! static_assert_imm4 {
+ ($imm:ident) => {
+ let _ = $crate::core_arch::macros::ValidateConstImm::<$imm, 0, { (1 << 4) - 1 }>::VALID;
+ };
+}
+
+#[allow(unused_macros)]
+macro_rules! static_assert_imm5 {
+ ($imm:ident) => {
+ let _ = $crate::core_arch::macros::ValidateConstImm::<$imm, 0, { (1 << 5) - 1 }>::VALID;
+ };
+}
+
+#[allow(unused_macros)]
+macro_rules! static_assert_imm6 {
+ ($imm:ident) => {
+ let _ = $crate::core_arch::macros::ValidateConstImm::<$imm, 0, { (1 << 6) - 1 }>::VALID;
+ };
+}
+
+#[allow(unused_macros)]
+macro_rules! static_assert_imm8 {
+ ($imm:ident) => {
+ let _ = $crate::core_arch::macros::ValidateConstImm::<$imm, 0, { (1 << 8) - 1 }>::VALID;
+ };
+}
+
+#[allow(unused_macros)]
+macro_rules! static_assert_imm16 {
+ ($imm:ident) => {
+ let _ = $crate::core_arch::macros::ValidateConstImm::<$imm, 0, { (1 << 16) - 1 }>::VALID;
+ };
+}
+
+#[allow(unused)]
+macro_rules! static_assert {
+ ($imm:ident : $ty:ty where $e:expr) => {{
+ struct Validate<const $imm: $ty>();
+ impl<const $imm: $ty> Validate<$imm> {
+ const VALID: () = {
+ assert!($e, concat!("Assertion failed: ", stringify!($e)));
+ };
+ }
+ let _ = Validate::<$imm>::VALID;
+ }};
+}
+
+#[allow(unused)]
+macro_rules! types {
+ ($(
+ $(#[$doc:meta])*
+ pub struct $name:ident($($fields:tt)*);
+ )*) => ($(
+ $(#[$doc])*
+ #[derive(Copy, Clone, Debug)]
+ #[allow(non_camel_case_types)]
+ #[repr(simd)]
+ #[allow(clippy::missing_inline_in_public_items)]
+ pub struct $name($($fields)*);
+ )*)
+}
+
+#[allow(unused)]
+macro_rules! simd_shuffle2 {
+ ($x:expr, $y:expr, <$(const $imm:ident : $ty:ty),+ $(,)?> $idx:expr $(,)?) => {{
+ struct ConstParam<$(const $imm: $ty),+>;
+ impl<$(const $imm: $ty),+> ConstParam<$($imm),+> {
+ const IDX: [u32; 2] = $idx;
+ }
+
+ simd_shuffle2($x, $y, ConstParam::<$($imm),+>::IDX)
+ }};
+ ($x:expr, $y:expr, $idx:expr $(,)?) => {{
+ const IDX: [u32; 2] = $idx;
+ simd_shuffle2($x, $y, IDX)
+ }};
+}
+
+#[allow(unused_macros)]
+macro_rules! simd_shuffle4 {
+ ($x:expr, $y:expr, <$(const $imm:ident : $ty:ty),+ $(,)?> $idx:expr $(,)?) => {{
+ struct ConstParam<$(const $imm: $ty),+>;
+ impl<$(const $imm: $ty),+> ConstParam<$($imm),+> {
+ const IDX: [u32; 4] = $idx;
+ }
+
+ simd_shuffle4($x, $y, ConstParam::<$($imm),+>::IDX)
+ }};
+ ($x:expr, $y:expr, $idx:expr $(,)?) => {{
+ const IDX: [u32; 4] = $idx;
+ simd_shuffle4($x, $y, IDX)
+ }};
+}
+
+#[allow(unused_macros)]
+macro_rules! simd_shuffle8 {
+ ($x:expr, $y:expr, <$(const $imm:ident : $ty:ty),+ $(,)?> $idx:expr $(,)?) => {{
+ struct ConstParam<$(const $imm: $ty),+>;
+ impl<$(const $imm: $ty),+> ConstParam<$($imm),+> {
+ const IDX: [u32; 8] = $idx;
+ }
+
+ simd_shuffle8($x, $y, ConstParam::<$($imm),+>::IDX)
+ }};
+ ($x:expr, $y:expr, $idx:expr $(,)?) => {{
+ const IDX: [u32; 8] = $idx;
+ simd_shuffle8($x, $y, IDX)
+ }};
+}
+
+#[allow(unused)]
+macro_rules! simd_shuffle16 {
+ ($x:expr, $y:expr, <$(const $imm:ident : $ty:ty),+ $(,)?> $idx:expr $(,)?) => {{
+ struct ConstParam<$(const $imm: $ty),+>;
+ impl<$(const $imm: $ty),+> ConstParam<$($imm),+> {
+ const IDX: [u32; 16] = $idx;
+ }
+
+ simd_shuffle16($x, $y, ConstParam::<$($imm),+>::IDX)
+ }};
+ ($x:expr, $y:expr, $idx:expr $(,)?) => {{
+ const IDX: [u32; 16] = $idx;
+ simd_shuffle16($x, $y, IDX)
+ }};
+}
+
+#[allow(unused_macros)]
+macro_rules! simd_shuffle32 {
+ ($x:expr, $y:expr, <$(const $imm:ident : $ty:ty),+> $(,)? $idx:expr $(,)?) => {{
+ struct ConstParam<$(const $imm: $ty),+>;
+ impl<$(const $imm: $ty),+> ConstParam<$($imm),+> {
+ const IDX: [u32; 32] = $idx;
+ }
+
+ simd_shuffle32($x, $y, ConstParam::<$($imm),+>::IDX)
+ }};
+ ($x:expr, $y:expr, $idx:expr $(,)?) => {{
+ const IDX: [u32; 32] = $idx;
+ simd_shuffle32($x, $y, IDX)
+ }};
+}
+
+#[allow(unused_macros)]
+macro_rules! simd_shuffle64 {
+ ($x:expr, $y:expr, <$(const $imm:ident : $ty:ty),+ $(,)?> $idx:expr $(,)?) => {{
+ struct ConstParam<$(const $imm: $ty),+>;
+ impl<$(const $imm: $ty),+> ConstParam<$($imm),+> {
+ const IDX: [u32; 64] = $idx;
+ }
+
+ simd_shuffle64($x, $y, ConstParam::<$($imm),+>::IDX)
+ }};
+ ($x:expr, $y:expr, $idx:expr $(,)?) => {{
+ const IDX: [u32; 64] = $idx;
+ simd_shuffle64($x, $y, IDX)
+ }};
+}