git: d9f5e35feca9 - main - security/suricata: Unbreak build with Rust 1.53.0

Tobias Kortkamp tobik at FreeBSD.org
Sat Jun 19 15:15:15 UTC 2021


The branch main has been updated by tobik:

URL: https://cgit.FreeBSD.org/ports/commit/?id=d9f5e35feca9ae3e28edfe511e3ffa58810e7f2c

commit d9f5e35feca9ae3e28edfe511e3ffa58810e7f2c
Author:     Tobias Kortkamp <tobik at FreeBSD.org>
AuthorDate: 2021-06-19 12:29:36 +0000
Commit:     Tobias Kortkamp <tobik at FreeBSD.org>
CommitDate: 2021-06-19 15:13:19 +0000

    security/suricata: Unbreak build with Rust 1.53.0
    
    error[E0308]: mismatched types
      --> rust/vendor/lexical-core/src/atof/algorithm/bhcomp.rs:62:24
       |
    62 |     let bytes = bits / Limb::BITS;
       |                        ^^^^^^^^^^ expected `usize`, found `u32`
    
    error[E0277]: cannot divide `usize` by `u32`
    
    http://package23.nyi.freebsd.org/data/114i386-default-foo/2021-06-18_08h49m22s/logs/errors/suricata-6.0.2_2.log
    
    PR:             256653
---
 security/suricata/Makefile                         |   5 +
 ...endor_lexical-core_src_atof_algorithm_bhcomp.rs |  11 ++
 ...ndor_lexical-core_src_atof_algorithm_bigcomp.rs |  39 ++++
 ..._vendor_lexical-core_src_atof_algorithm_math.rs | 211 +++++++++++++++++++++
 4 files changed, 266 insertions(+)

diff --git a/security/suricata/Makefile b/security/suricata/Makefile
index e5dcf9c2aeca..e047f1fb6838 100644
--- a/security/suricata/Makefile
+++ b/security/suricata/Makefile
@@ -108,6 +108,11 @@ TESTS_CONFIGURE_ENABLE=		unittests
 pre-patch:
 	@${CP} ${FILESDIR}/ax_check_compile_flag.m4 ${WRKSRC}/m4
 
+post-patch:
+# Disable vendor checksums
+	@${REINPLACE_CMD} 's,"files":{[^}]*},"files":{},' \
+		${WRKSRC}/rust/vendor/*/.cargo-checksum.json
+
 post-patch-PYTHON-on:
 	@${REINPLACE_CMD} -e "/AC_PATH_PROGS.*HAVE_PYTHON/ s/python[^,]*,/${PYTHON_VERSION},/g" \
 		${WRKSRC}/configure.ac
diff --git a/security/suricata/files/patch-rust_vendor_lexical-core_src_atof_algorithm_bhcomp.rs b/security/suricata/files/patch-rust_vendor_lexical-core_src_atof_algorithm_bhcomp.rs
new file mode 100644
index 000000000000..5ab5c0f66d7b
--- /dev/null
+++ b/security/suricata/files/patch-rust_vendor_lexical-core_src_atof_algorithm_bhcomp.rs
@@ -0,0 +1,11 @@
+--- rust/vendor/lexical-core/src/atof/algorithm/bhcomp.rs.orig	2021-06-19 12:41:29 UTC
++++ rust/vendor/lexical-core/src/atof/algorithm/bhcomp.rs
+@@ -59,7 +59,7 @@ pub(super) fn parse_mantissa<'a, Data>(data: Data, rad
+     let small_powers = Bigint::small_powers(radix);
+     let count = data.mantissa_digits();
+     let bits = count / integral_binary_factor(radix).as_usize();
+-    let bytes = bits / Limb::BITS;
++    let bytes = bits / <Limb as Integer>::BITS;
+ 
+     // Main loop
+     let step = small_powers.len() - 2;
diff --git a/security/suricata/files/patch-rust_vendor_lexical-core_src_atof_algorithm_bigcomp.rs b/security/suricata/files/patch-rust_vendor_lexical-core_src_atof_algorithm_bigcomp.rs
new file mode 100644
index 000000000000..585f9630bbaa
--- /dev/null
+++ b/security/suricata/files/patch-rust_vendor_lexical-core_src_atof_algorithm_bigcomp.rs
@@ -0,0 +1,39 @@
+error[E0308]: mismatched types
+   --> src/atof/algorithm/bigcomp.rs:242:55
+    |
+242 |     let nlz = den.leading_zeros().wrapping_sub(wlz) & (u32::BITS - 1);
+    |                                                       ^^^^^^^^^^^^^^^ expected `usize`, found `u32`
+
+error[E0277]: no implementation for `usize & u32`
+
+https://github.com/Alexhuszagh/rust-lexical/commit/05f2cf96b080a81e2bee1f30ae389dc4f9cb6d00
+
+--- rust/vendor/lexical-core/src/atof/algorithm/bigcomp.rs.orig	2021-03-01 16:15:39 UTC
++++ rust/vendor/lexical-core/src/atof/algorithm/bigcomp.rs
+@@ -154,7 +154,7 @@ pub(super) fn make_ratio<F: Float>(radix: u32, sci_exp
+     // Scale the denominator so it has the number of bits
+     // in the radix as the number of leading zeros.
+     let wlz = integral_binary_factor(radix).as_usize();
+-    let nlz = den.leading_zeros().wrapping_sub(wlz) & (u32::BITS - 1);
++    let nlz = den.leading_zeros().wrapping_sub(wlz) & (<u32 as Integer>::BITS - 1);
+     small::ishl_bits(den.data_mut(), nlz);
+     den.exp -= nlz.as_i32();
+ 
+@@ -172,7 +172,7 @@ pub(super) fn make_ratio<F: Float>(radix: u32, sci_exp
+         // denominator will be normalized.
+         // We need to add one to the quotient,since we're calculating the
+         // ceiling of the divmod.
+-        let (q, r) = shift.ceil_divmod(Limb::BITS);
++        let (q, r) = shift.ceil_divmod(<Limb as Integer>::BITS);
+         // Since we're using a power from the denominator to the
+         // numerator, we to invert r, not add u32::BITS.
+         let r = -r;
+@@ -180,7 +180,7 @@ pub(super) fn make_ratio<F: Float>(radix: u32, sci_exp
+         num.exp -= r;
+         if !q.is_zero() {
+             den.pad_zero_digits(q);
+-            den.exp -= Limb::BITS.as_i32() * q.as_i32();
++            den.exp -= <Limb as Integer>::BITS.as_i32() * q.as_i32();
+         }
+     }
+ 
diff --git a/security/suricata/files/patch-rust_vendor_lexical-core_src_atof_algorithm_math.rs b/security/suricata/files/patch-rust_vendor_lexical-core_src_atof_algorithm_math.rs
new file mode 100644
index 000000000000..d402b44e44a5
--- /dev/null
+++ b/security/suricata/files/patch-rust_vendor_lexical-core_src_atof_algorithm_math.rs
@@ -0,0 +1,211 @@
+--- rust/vendor/lexical-core/src/atof/algorithm/math.rs.orig	2021-03-01 16:15:39 UTC
++++ rust/vendor/lexical-core/src/atof/algorithm/math.rs
+@@ -956,7 +956,7 @@ pub fn mul(x: Limb, y: Limb, carry: Limb)
+     // the following is always true:
+     // `Wide::max_value() - (Narrow::max_value() * Narrow::max_value()) >= Narrow::max_value()`
+     let z: Wide = as_wide(x) * as_wide(y) + as_wide(carry);
+-    (as_limb(z), as_limb(z >> Limb::BITS))
++    (as_limb(z), as_limb(z >> <Limb as Integer>::BITS))
+ }}
+ 
+ /// Multiply two small integers (with carry) (and return if overflow happens).
+@@ -979,7 +979,7 @@ pub fn div(x: Limb, y: Limb, rem: Limb)
+     -> (Limb, Limb)
+ {
+     // Cannot overflow, as long as wide is 2x as wide.
+-    let x = as_wide(x) | (as_wide(rem) << Limb::BITS);
++    let x = as_wide(x) | (as_wide(rem) << <Limb as Integer>::BITS);
+     let y = as_wide(y);
+     (as_limb(x / y), as_limb(x % y))
+ }}
+@@ -1046,7 +1046,7 @@ perftools_inline!{
+ pub fn trailing_zeros(x: &[Limb]) -> usize {
+     // Get the index of the last non-zero value
+     let index = trailing_zero_limbs(x);
+-    let mut count = index.saturating_mul(Limb::BITS);
++    let mut count = index.saturating_mul(<Limb as Integer>::BITS);
+     if let Some(value) = x.get(index) {
+         count = count.saturating_add(value.trailing_zeros().as_usize());
+     }
+@@ -1061,7 +1061,7 @@ pub fn bit_length(x: &[Limb]) -> usize {
+     // Avoid overflowing, calculate via total number of bits
+     // minus leading zero bits.
+     let nlz = leading_zeros(x);
+-    Limb::BITS.checked_mul(x.len())
++    <Limb as Integer>::BITS.checked_mul(x.len())
+         .map(|v| v - nlz)
+         .unwrap_or(usize::max_value())
+ }}
+@@ -1080,14 +1080,14 @@ pub fn limb_length(x: &[Limb]) -> usize {
+ ///
+ /// Returns the truncated bits.
+ ///
+-/// Assumes `n < Limb::BITS`, IE, internally shifting bits.
++/// Assumes `n < <Limb as Integer>::BITS`, IE, internally shifting bits.
+ perftools_inline!{
+ pub fn ishr_bits<T>(x: &mut T, n: usize)
+     -> Limb
+     where T: CloneableVecLike<Limb>
+ {
+-    // Need to shift by the number of `bits % Limb::BITS`.
+-    let bits = Limb::BITS;
++    // Need to shift by the number of `bits % <Limb as Integer>::BITS`.
++    let bits = <Limb as Integer>::BITS;
+     debug_assert!(n < bits && n != 0);
+ 
+     // Internally, for each item, we shift left by n, and add the previous
+@@ -1134,9 +1134,9 @@ pub fn ishr<T>(x: &mut T, n: usize)
+     -> bool
+     where T: CloneableVecLike<Limb>
+ {
+-    let bits = Limb::BITS;
+-    // Need to pad with zeros for the number of `bits / Limb::BITS`,
+-    // and shift-left with carry for `bits % Limb::BITS`.
++    let bits = <Limb as Integer>::BITS;
++    // Need to pad with zeros for the number of `bits / <Limb as Integer>::BITS`,
++    // and shift-left with carry for `bits % <Limb as Integer>::BITS`.
+     let rem = n % bits;
+     let div = n / bits;
+     let is_zero = match div.is_zero() {
+@@ -1187,13 +1187,13 @@ pub fn shr<T>(x: &[Limb], n: usize)
+ 
+ /// Shift-left bits inside a buffer.
+ ///
+-/// Assumes `n < Limb::BITS`, IE, internally shifting bits.
++/// Assumes `n < <Limb as Integer>::BITS`, IE, internally shifting bits.
+ perftools_inline!{
+ pub fn ishl_bits<T>(x: &mut T, n: usize)
+     where T: CloneableVecLike<Limb>
+ {
+-    // Need to shift by the number of `bits % Limb::BITS)`.
+-    let bits = Limb::BITS;
++    // Need to shift by the number of `bits % <Limb as Integer>::BITS)`.
++    let bits = <Limb as Integer>::BITS;
+     debug_assert!(n < bits);
+     if n.is_zero() {
+         return;
+@@ -1223,7 +1223,7 @@ pub fn ishl_bits<T>(x: &mut T, n: usize)
+ 
+ /// Shift-left bits inside a buffer.
+ ///
+-/// Assumes `n < Limb::BITS`, IE, internally shifting bits.
++/// Assumes `n < <Limb as Integer>::BITS`, IE, internally shifting bits.
+ perftools_inline!{
+ pub fn shl_bits<T>(x: &[Limb], n: usize)
+     -> T
+@@ -1253,9 +1253,9 @@ perftools_inline!{
+ pub fn ishl<T>(x: &mut T, n: usize)
+     where T: CloneableVecLike<Limb>
+ {
+-    let bits = Limb::BITS;
+-    // Need to pad with zeros for the number of `bits / Limb::BITS`,
+-    // and shift-left with carry for `bits % Limb::BITS`.
++    let bits = <Limb as Integer>::BITS;
++    // Need to pad with zeros for the number of `bits / <Limb as Integer>::BITS`,
++    // and shift-left with carry for `bits % <Limb as Integer>::BITS`.
+     let rem = n % bits;
+     let div = n / bits;
+     ishl_bits(x, rem);
+@@ -1912,7 +1912,7 @@ pub fn mul<T>(x: &[Limb], y: &[Limb])
+ // DIVISION
+ 
+ /// Constants for algorithm D.
+-const ALGORITHM_D_B: Wide = 1 << Limb::BITS;
++const ALGORITHM_D_B: Wide = 1 << <Limb as Integer>::BITS;
+ const ALGORITHM_D_M: Wide = ALGORITHM_D_B - 1;
+ 
+ /// Calculate qhat (an estimate for the quotient).
+@@ -1932,7 +1932,7 @@ fn calculate_qhat(x: &[Limb], y: &[Limb], j: usize)
+     //  rhat = (x[j+n]*B + x[j+n-1]) - qhat*y[n-1];
+     let x_jn = as_wide(x[j+n]);
+     let x_jn1 = as_wide(x[j+n-1]);
+-    let num = (x_jn << Limb::BITS) + x_jn1;
++    let num = (x_jn << <Limb as Integer>::BITS) + x_jn1;
+     let den = as_wide(y[n-1]);
+     let mut qhat = num / den;
+     let mut rhat = num - qhat * den;
+@@ -1949,7 +1949,7 @@ fn calculate_qhat(x: &[Limb], y: &[Limb], j: usize)
+     let y_n2 = as_wide(y[n-2]);
+     let y_n1 = as_wide(y[n-1]);
+     // This only happens when the leading bit of qhat is set.
+-    while qhat >= ALGORITHM_D_B || qhat * y_n2 > (rhat << Limb::BITS) + x_jn2 {
++    while qhat >= ALGORITHM_D_B || qhat * y_n2 > (rhat << <Limb as Integer>::BITS) + x_jn2 {
+         qhat -= 1;
+         rhat += y_n1;
+         if rhat >= ALGORITHM_D_B {
+@@ -1989,7 +1989,7 @@ fn multiply_and_subtract<T>(x: &mut T, y: &T, qhat: Wi
+         let p = qhat * y_i;
+         t = x_ij.wrapping_sub(k).wrapping_sub(as_signed_wide(p & ALGORITHM_D_M));
+         x[i+j] = as_limb(t);
+-        k = as_signed_wide(p >> Limb::BITS) - (t >> Limb::BITS);
++        k = as_signed_wide(p >> <Limb as Integer>::BITS) - (t >> <Limb as Integer>::BITS);
+     }
+     t = as_signed_wide(x[j+n]) - k;
+     x[j+n] = as_limb(t);
+@@ -2045,7 +2045,7 @@ fn add_back<T>(x: &mut T, y: &T, mut t: SignedWide, j:
+         for i in 0..n {
+             t = as_signed_wide(as_wide(x[i+j]) + as_wide(y[i])) + k;
+             x[i+j] = as_limb(t);
+-            k = t >> Limb::BITS;
++            k = t >> <Limb as Integer>::BITS;
+         }
+         let x_jn = as_signed_wide(x[j+n]) + k;
+         x[j+n] = as_limb(x_jn);
+@@ -2068,7 +2068,7 @@ fn calculate_remainder<T>(x: &[Limb], y: &[Limb], s: u
+     let n = y.len();
+     let mut r = T::default();
+     r.reserve_exact(n);
+-    let rs = Limb::BITS - s;
++    let rs = <Limb as Integer>::BITS - s;
+     for i in 0..n-1 {
+         let xi = as_wide(x[i]) >> s;
+         let xi1 = as_wide(x[i+1]) << rs;
+@@ -2205,9 +2205,9 @@ pub fn quorem<T>(x: &mut T, y: &T)
+         let mut carry: Wide = 0;
+         for j in 0..m {
+             let p = as_wide(y[j]) * as_wide(q) + carry;
+-            carry = p >> Limb::BITS;
++            carry = p >> <Limb as Integer>::BITS;
+             let t = as_wide(x[j]).wrapping_sub(p & mask).wrapping_sub(borrow);
+-            borrow = (t >> Limb::BITS) & 1;
++            borrow = (t >> <Limb as Integer>::BITS) & 1;
+             x[j] = as_limb(t);
+         }
+         small::normalize(x);
+@@ -2220,9 +2220,9 @@ pub fn quorem<T>(x: &mut T, y: &T)
+         let mut carry: Wide = 0;
+         for j in 0..m {
+             let p = as_wide(y[j]) + carry;
+-            carry = p >> Limb::BITS;
++            carry = p >> <Limb as Integer>::BITS;
+             let t = as_wide(x[j]).wrapping_sub(p & mask).wrapping_sub(borrow);
+-            borrow = (t >> Limb::BITS) & 1;
++            borrow = (t >> <Limb as Integer>::BITS) & 1;
+             x[j] = as_limb(t);
+         }
+         small::normalize(x);
+@@ -3137,18 +3137,18 @@ mod tests {
+     fn leading_zeros_test() {
+         assert_eq!(Bigint::new().leading_zeros(), 0);
+ 
+-        assert_eq!(Bigint::from_u16(0xFF).leading_zeros(), Limb::BITS-8);
+-        assert_eq!(Bigint::from_u32(0xFF).leading_zeros(), Limb::BITS-8);
++        assert_eq!(Bigint::from_u16(0xFF).leading_zeros(), <Limb as Integer>::BITS-8);
++        assert_eq!(Bigint::from_u32(0xFF).leading_zeros(), <Limb as Integer>::BITS-8);
+         assert_eq!(Bigint::from_u64(0xFF00000000).leading_zeros(), 24);
+         assert_eq!(Bigint::from_u128(0xFF000000000000000000000000).leading_zeros(), 24);
+ 
+-        assert_eq!(Bigint::from_u16(0xF).leading_zeros(), Limb::BITS-4);
+-        assert_eq!(Bigint::from_u32(0xF).leading_zeros(), Limb::BITS-4);
++        assert_eq!(Bigint::from_u16(0xF).leading_zeros(), <Limb as Integer>::BITS-4);
++        assert_eq!(Bigint::from_u32(0xF).leading_zeros(), <Limb as Integer>::BITS-4);
+         assert_eq!(Bigint::from_u64(0xF00000000).leading_zeros(), 28);
+         assert_eq!(Bigint::from_u128(0xF000000000000000000000000).leading_zeros(), 28);
+ 
+-        assert_eq!(Bigint::from_u16(0xF0).leading_zeros(), Limb::BITS-8);
+-        assert_eq!(Bigint::from_u32(0xF0).leading_zeros(), Limb::BITS-8);
++        assert_eq!(Bigint::from_u16(0xF0).leading_zeros(), <Limb as Integer>::BITS-8);
++        assert_eq!(Bigint::from_u32(0xF0).leading_zeros(), <Limb as Integer>::BITS-8);
+         assert_eq!(Bigint::from_u64(0xF000000000).leading_zeros(), 24);
+         assert_eq!(Bigint::from_u128(0xF0000000000000000000000000).leading_zeros(), 24);
+     }


More information about the dev-commits-ports-all mailing list