diff mbox series

[meta-python,v2] python3-m2crypto: upgrade 0.46.2 -> 0.47.0

Message ID 20260302055650.1478-1-wangmy@fujitsu.com
State Under Review
Headers show
Series [meta-python,v2] python3-m2crypto: upgrade 0.46.2 -> 0.47.0 | expand

Commit Message

Mingyu Wang (Fujitsu) March 2, 2026, 5:56 a.m. UTC
From: Wang Mingyu <wangmy@fujitsu.com>

0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch
0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch
removed since they're included in 0.47.0

Signed-off-by: Wang Mingyu <wangmy@fujitsu.com>
---
 ...-time_t-on-32-bit-systems-in-test_is.patch | 40 -----------
 ...ct-packing-on-32-bit-with-_TIME_BITS.patch | 72 -------------------
 ...o_0.46.2.bb => python3-m2crypto_0.47.0.bb} |  8 +--
 3 files changed, 2 insertions(+), 118 deletions(-)
 delete mode 100644 meta-python/recipes-devtools/python/python3-m2crypto/0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch
 delete mode 100644 meta-python/recipes-devtools/python/python3-m2crypto/0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch
 rename meta-python/recipes-devtools/python/{python3-m2crypto_0.46.2.bb => python3-m2crypto_0.47.0.bb} (84%)

Comments

Khem Raj March 2, 2026, 3:30 p.m. UTC | #1
fails to build now using clang

| INFO:mkpath:creating build/temp.linux-aarch64-cpython-314/src/SWIG
| INFO:spawn:aarch64-yoe-linux-clang -mcpu=cortex-a57+crc
--dyld-prefix=/usr -fstack-protector-strong -O2 -D_FORTIFY_SOURCE=2
-Wformat -Wformat-security -Werror=format-security -fstack-protector-strong
-O2 -D_FORTIFY_SOURCE=2 -Wformat -Wformat-security -Werror=format-security
--sysroot=/srv/build/yoe/build/tmp/work/cortexa57-yoe-linux/python3-m2crypto/0.47.0/recipe-sysroot
-O2 -g
-ffile-prefix-map=/srv/build/yoe/build/tmp/work/cortexa57-yoe-linux/python3-m2crypto/0.47.0/sources/m2crypto-0.47.0=/usr/src/debug/python3-m2crypto/0.47.0
-ffile-prefix-map=/srv/build/yoe/build/tmp/work/cortexa57-yoe-linux/python3-m2crypto/0.47.0/sources/m2crypto-0.47.0=/usr/src/debug/python3-m2crypto/0.47.0
-ffile-prefix-map=/srv/build/yoe/build/tmp/work/cortexa57-yoe-linux/python3-m2crypto/0.47.0/recipe-sysroot=
-ffile-prefix-map=/srv/build/yoe/build/tmp/work/cortexa57-yoe-linux/python3-m2crypto/0.47.0/recipe-sysroot-native=
-pipe -fPIC
-I/srv/build/yoe/build/tmp/work/cortexa57-yoe-linux/python3-m2crypto/0.47.0/recipe-sysroot/usr/include/python3.14
-I/srv/build/yoe/build/tmp/work/cortexa57-yoe-linux/python3-m2crypto/0.47.0/sources/m2crypto-0.47.0/src/SWIG
-c src/SWIG/_m2crypto_wrap.c -o
build/temp.linux-aarch64-cpython-314/src/SWIG/_m2crypto_wrap.o -DTHREADING
-Wno-deprecated-declarations
| src/SWIG/_m2crypto_wrap.c:4455:1: error: unknown type name
'PRAGMA_IGNORE_UNUSED_LABEL'
|  4455 | PRAGMA_IGNORE_UNUSED_LABEL
|       | ^
| src/SWIG/_m2crypto_wrap.c:4456:30: error: expected ';' after top level
declarator
|  4456 | PRAGMA_WARN_STRICT_PROTOTYPES
|       |                              ^
|       |                              ;
| 2 errors generated.

On Sun, Mar 1, 2026 at 9:57 PM wangmy via lists.openembedded.org <wangmy=
fujitsu.com@lists.openembedded.org> wrote:

> From: Wang Mingyu <wangmy@fujitsu.com>
>
> 0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch
> 0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch
> removed since they're included in 0.47.0
>
> Signed-off-by: Wang Mingyu <wangmy@fujitsu.com>
> ---
>  ...-time_t-on-32-bit-systems-in-test_is.patch | 40 -----------
>  ...ct-packing-on-32-bit-with-_TIME_BITS.patch | 72 -------------------
>  ...o_0.46.2.bb => python3-m2crypto_0.47.0.bb} |  8 +--
>  3 files changed, 2 insertions(+), 118 deletions(-)
>  delete mode 100644
> meta-python/recipes-devtools/python/python3-m2crypto/0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch
>  delete mode 100644
> meta-python/recipes-devtools/python/python3-m2crypto/0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch
>  rename meta-python/recipes-devtools/python/{python3-m2crypto_0.46.2.bb
> => python3-m2crypto_0.47.0.bb} (84%)
>
> diff --git
> a/meta-python/recipes-devtools/python/python3-m2crypto/0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch
> b/meta-python/recipes-devtools/python/python3-m2crypto/0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch
> deleted file mode 100644
> index d49950074f..0000000000
> ---
> a/meta-python/recipes-devtools/python/python3-m2crypto/0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch
> +++ /dev/null
> @@ -1,40 +0,0 @@
> -From d123b4ddce99c44f2c290fb3d6cc887de98778e6 Mon Sep 17 00:00:00 2001
> -From: Haixiao Yan <haixiao.yan.cn@windriver.com>
> -Date: Wed, 22 Oct 2025 15:23:56 +0800
> -Subject: [PATCH 1/2] fix: allow 64-bit time_t on 32-bit systems in
> - test_is32bit
> -
> -Some modern 32-bit Linux systems (e.g. with glibc >= 2.34 or musl time64
> ABI)
> -use 64-bit time_t by default when _TIME_BITS=64 is enabled. The original
> test
> -assumed time_t was always 32-bit on 32-bit architectures, which is no
> longer
> -true.
> -
> -Relax the check to accept both 32-bit and 64-bit time_t values:
> -
> -    self.assertIn(bit32, (32, 64))
> -
> -This makes the test compatible with both legacy and time64 ABIs.
> -
> -Upstream-Status: Backport [
> https://gitlab.com/m2crypto/m2crypto/-/commit/818c3dfda6ea]
> -
> -Signed-off-by: Haixiao Yan <haixiao.yan.cn@windriver.com>
> ----
> - tests/test_util.py | 2 +-
> - 1 file changed, 1 insertion(+), 1 deletion(-)
> -
> -diff --git a/tests/test_util.py b/tests/test_util.py
> -index e925d03b090c..233fb7a099d9 100644
> ---- a/tests/test_util.py
> -+++ b/tests/test_util.py
> -@@ -26,7 +26,7 @@ class UtilTestCase(unittest.TestCase):
> -                 not in ["true", "1", "yes"]
> -             )
> -         ):
> --            self.assertEqual(bit32, 32)
> -+            self.assertIn(bit32, (32, 64))
> -         else:
> -             self.assertNotEqual(bit32, 32)
> -         self.assertIsInstance(bit32, int)
> ---
> -2.34.1
> -
> diff --git
> a/meta-python/recipes-devtools/python/python3-m2crypto/0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch
> b/meta-python/recipes-devtools/python/python3-m2crypto/0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch
> deleted file mode 100644
> index c36afa5cc0..0000000000
> ---
> a/meta-python/recipes-devtools/python/python3-m2crypto/0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch
> +++ /dev/null
> @@ -1,72 +0,0 @@
> -From b5dbfca23986429853ccb15a38cc526d9df0dd40 Mon Sep 17 00:00:00 2001
> -From: Haixiao Yan <haixiao.yan.cn@windriver.com>
> -Date: Wed, 22 Oct 2025 15:23:57 +0800
> -Subject: [PATCH 2/2] fix: correct struct packing on 32-bit with
> _TIME_BITS=64
> -
> -On 32-bit platforms with glibc time64 ABI, time_t is 64-bit wide while
> -`long` remains 32-bit. This causes struct timeval to use two 64-bit fields
> -(tv_sec, tv_usec). The previous code incorrectly packed timeout as "ll",
> -leading to EINVAL in setsockopt(SO_RCVTIMEO).
> -
> -Use "qq" instead when m2.time_t_bits() == 64 to match the actual ABI.
> -
> -Fixes: https://todo.sr.ht/~mcepl/m2crypto/374
> -
> -Upstream-Status: Backport [
> https://gitlab.com/m2crypto/m2crypto/-/commit/473de659f78e]
> -
> -Signed-off-by: Haixiao Yan <haixiao.yan.cn@windriver.com>
> ----
> - src/M2Crypto/SSL/timeout.py | 24 ++++++++++++++++++++----
> - 1 file changed, 20 insertions(+), 4 deletions(-)
> -
> -diff --git a/src/M2Crypto/SSL/timeout.py b/src/M2Crypto/SSL/timeout.py
> -index b45f38b1cbdb..5ba52283b6f8 100644
> ---- a/src/M2Crypto/SSL/timeout.py
> -+++ b/src/M2Crypto/SSL/timeout.py
> -@@ -33,10 +33,14 @@ class timeout(object):
> -             millisec = int(self.sec * 1000 + round(float(self.microsec)
> / 1000))
> -             binstr = struct.pack("l", millisec)
> -         else:
> --            if m2.time_t_bits() == 32:
> -+            bits = m2.time_t_bits()
> -+            if bits == 32:
> -                 binstr = struct.pack("ii", self.sec, self.microsec)
> -+            elif bits == 64:
> -+                # handle both 64-bit and 32-bit+TIME_BITS=64
> -+                binstr = struct.pack("qq", self.sec, self.microsec)
> -             else:
> --                binstr = struct.pack("ll", self.sec, self.microsec)
> -+                raise ValueError(f"Unsupported time_t_bits: {bits}")
> -         return binstr
> -
> -
> -@@ -48,7 +52,13 @@ def struct_to_timeout(binstr: bytes) -> timeout:
> -         sec = int(millisec / 1000)
> -         microsec = (millisec % 1000) * 1000
> -     else:
> --        (sec, microsec) = struct.unpack("ll", binstr)
> -+        bits = m2.time_t_bits()
> -+        if bits == 32:
> -+            (sec, microsec) = struct.unpack("ii", binstr)
> -+        elif bits == 64:
> -+            (sec, microsec) = struct.unpack("qq", binstr)
> -+        else:
> -+            raise ValueError(f"Unsupported time_t_bits: {bits}")
> -     return timeout(sec, microsec)
> -
> -
> -@@ -56,4 +66,10 @@ def struct_size() -> int:
> -     if sys.platform == "win32":
> -         return struct.calcsize("l")
> -     else:
> --        return struct.calcsize("ll")
> -+        bits = m2.time_t_bits()
> -+        if bits == 32:
> -+            return struct.calcsize("ii")
> -+        elif bits == 64:
> -+            return struct.calcsize("qq")
> -+        else:
> -+            raise ValueError(f"Unsupported time_t_bits: {bits}")
> ---
> -2.34.1
> -
> diff --git a/meta-python/recipes-devtools/python/
> python3-m2crypto_0.46.2.bb b/meta-python/recipes-devtools/python/
> python3-m2crypto_0.47.0.bb
> similarity index 84%
> rename from meta-python/recipes-devtools/python/python3-m2crypto_0.46.2.bb
> rename to meta-python/recipes-devtools/python/python3-m2crypto_0.47.0.bb
> index abe79671d2..ba7bd9b8e3 100644
> --- a/meta-python/recipes-devtools/python/python3-m2crypto_0.46.2.bb
> +++ b/meta-python/recipes-devtools/python/python3-m2crypto_0.47.0.bb
> @@ -4,13 +4,9 @@ HOMEPAGE = "https://gitlab.com/m2crypto/m2crypto"
>  LICENSE = "BSD-2-Clause"
>  LIC_FILES_CHKSUM =
> "file://LICENSES/BSD-2-Clause.txt;md5=8099b0e569f862ece05740aef06c82a2"
>
> -SRC_URI[sha256sum] =
> "13c2fa89562f7b8af40cc74b55f490be5e2ab8ccfb739f11c16d3ce6221a61ba"
> +SRC_URI[sha256sum] =
> "9256300be1e0412be802aa1f827e0ce7f94deb1099b8ccdcfd9867a7f0f975bf"
>
> -SRC_URI += " \
> -          file://0001-setup.py-Make-the-cmd-available.patch \
> -
> file://0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch \
> -
> file://0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch \
> -"
> +SRC_URI += "file://0001-setup.py-Make-the-cmd-available.patch"
>
>  CVE_STATUS[CVE-2009-0127] = "disputed: upstream claims there is no bug"
>  CVE_STATUS[CVE-2020-25657] = "fixed-version: the used version (0.46.2)
> contains the fix already"
> --
> 2.43.0
>
>
> -=-=-=-=-=-=-=-=-=-=-=-
> Links: You receive all messages sent to this group.
> View/Reply Online (#124799):
> https://lists.openembedded.org/g/openembedded-devel/message/124799
> Mute This Topic: https://lists.openembedded.org/mt/118089528/1997914
> Group Owner: openembedded-devel+owner@lists.openembedded.org
> Unsubscribe: https://lists.openembedded.org/g/openembedded-devel/unsub [
> raj.khem@gmail.com]
> -=-=-=-=-=-=-=-=-=-=-=-
>
>
diff mbox series

Patch

diff --git a/meta-python/recipes-devtools/python/python3-m2crypto/0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch b/meta-python/recipes-devtools/python/python3-m2crypto/0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch
deleted file mode 100644
index d49950074f..0000000000
--- a/meta-python/recipes-devtools/python/python3-m2crypto/0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch
+++ /dev/null
@@ -1,40 +0,0 @@ 
-From d123b4ddce99c44f2c290fb3d6cc887de98778e6 Mon Sep 17 00:00:00 2001
-From: Haixiao Yan <haixiao.yan.cn@windriver.com>
-Date: Wed, 22 Oct 2025 15:23:56 +0800
-Subject: [PATCH 1/2] fix: allow 64-bit time_t on 32-bit systems in
- test_is32bit
-
-Some modern 32-bit Linux systems (e.g. with glibc >= 2.34 or musl time64 ABI)
-use 64-bit time_t by default when _TIME_BITS=64 is enabled. The original test
-assumed time_t was always 32-bit on 32-bit architectures, which is no longer
-true.
-
-Relax the check to accept both 32-bit and 64-bit time_t values:
-
-    self.assertIn(bit32, (32, 64))
-
-This makes the test compatible with both legacy and time64 ABIs.
-
-Upstream-Status: Backport [https://gitlab.com/m2crypto/m2crypto/-/commit/818c3dfda6ea]
-
-Signed-off-by: Haixiao Yan <haixiao.yan.cn@windriver.com>
----
- tests/test_util.py | 2 +-
- 1 file changed, 1 insertion(+), 1 deletion(-)
-
-diff --git a/tests/test_util.py b/tests/test_util.py
-index e925d03b090c..233fb7a099d9 100644
---- a/tests/test_util.py
-+++ b/tests/test_util.py
-@@ -26,7 +26,7 @@ class UtilTestCase(unittest.TestCase):
-                 not in ["true", "1", "yes"]
-             )
-         ):
--            self.assertEqual(bit32, 32)
-+            self.assertIn(bit32, (32, 64))
-         else:
-             self.assertNotEqual(bit32, 32)
-         self.assertIsInstance(bit32, int)
--- 
-2.34.1
-
diff --git a/meta-python/recipes-devtools/python/python3-m2crypto/0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch b/meta-python/recipes-devtools/python/python3-m2crypto/0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch
deleted file mode 100644
index c36afa5cc0..0000000000
--- a/meta-python/recipes-devtools/python/python3-m2crypto/0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch
+++ /dev/null
@@ -1,72 +0,0 @@ 
-From b5dbfca23986429853ccb15a38cc526d9df0dd40 Mon Sep 17 00:00:00 2001
-From: Haixiao Yan <haixiao.yan.cn@windriver.com>
-Date: Wed, 22 Oct 2025 15:23:57 +0800
-Subject: [PATCH 2/2] fix: correct struct packing on 32-bit with _TIME_BITS=64
-
-On 32-bit platforms with glibc time64 ABI, time_t is 64-bit wide while
-`long` remains 32-bit. This causes struct timeval to use two 64-bit fields
-(tv_sec, tv_usec). The previous code incorrectly packed timeout as "ll",
-leading to EINVAL in setsockopt(SO_RCVTIMEO).
-
-Use "qq" instead when m2.time_t_bits() == 64 to match the actual ABI.
-
-Fixes: https://todo.sr.ht/~mcepl/m2crypto/374
-
-Upstream-Status: Backport [https://gitlab.com/m2crypto/m2crypto/-/commit/473de659f78e]
-
-Signed-off-by: Haixiao Yan <haixiao.yan.cn@windriver.com>
----
- src/M2Crypto/SSL/timeout.py | 24 ++++++++++++++++++++----
- 1 file changed, 20 insertions(+), 4 deletions(-)
-
-diff --git a/src/M2Crypto/SSL/timeout.py b/src/M2Crypto/SSL/timeout.py
-index b45f38b1cbdb..5ba52283b6f8 100644
---- a/src/M2Crypto/SSL/timeout.py
-+++ b/src/M2Crypto/SSL/timeout.py
-@@ -33,10 +33,14 @@ class timeout(object):
-             millisec = int(self.sec * 1000 + round(float(self.microsec) / 1000))
-             binstr = struct.pack("l", millisec)
-         else:
--            if m2.time_t_bits() == 32:
-+            bits = m2.time_t_bits()
-+            if bits == 32:
-                 binstr = struct.pack("ii", self.sec, self.microsec)
-+            elif bits == 64:
-+                # handle both 64-bit and 32-bit+TIME_BITS=64
-+                binstr = struct.pack("qq", self.sec, self.microsec)
-             else:
--                binstr = struct.pack("ll", self.sec, self.microsec)
-+                raise ValueError(f"Unsupported time_t_bits: {bits}")
-         return binstr
- 
- 
-@@ -48,7 +52,13 @@ def struct_to_timeout(binstr: bytes) -> timeout:
-         sec = int(millisec / 1000)
-         microsec = (millisec % 1000) * 1000
-     else:
--        (sec, microsec) = struct.unpack("ll", binstr)
-+        bits = m2.time_t_bits()
-+        if bits == 32:
-+            (sec, microsec) = struct.unpack("ii", binstr)
-+        elif bits == 64:
-+            (sec, microsec) = struct.unpack("qq", binstr)
-+        else:
-+            raise ValueError(f"Unsupported time_t_bits: {bits}")
-     return timeout(sec, microsec)
- 
- 
-@@ -56,4 +66,10 @@ def struct_size() -> int:
-     if sys.platform == "win32":
-         return struct.calcsize("l")
-     else:
--        return struct.calcsize("ll")
-+        bits = m2.time_t_bits()
-+        if bits == 32:
-+            return struct.calcsize("ii")
-+        elif bits == 64:
-+            return struct.calcsize("qq")
-+        else:
-+            raise ValueError(f"Unsupported time_t_bits: {bits}")
--- 
-2.34.1
-
diff --git a/meta-python/recipes-devtools/python/python3-m2crypto_0.46.2.bb b/meta-python/recipes-devtools/python/python3-m2crypto_0.47.0.bb
similarity index 84%
rename from meta-python/recipes-devtools/python/python3-m2crypto_0.46.2.bb
rename to meta-python/recipes-devtools/python/python3-m2crypto_0.47.0.bb
index abe79671d2..ba7bd9b8e3 100644
--- a/meta-python/recipes-devtools/python/python3-m2crypto_0.46.2.bb
+++ b/meta-python/recipes-devtools/python/python3-m2crypto_0.47.0.bb
@@ -4,13 +4,9 @@  HOMEPAGE = "https://gitlab.com/m2crypto/m2crypto"
 LICENSE = "BSD-2-Clause"
 LIC_FILES_CHKSUM = "file://LICENSES/BSD-2-Clause.txt;md5=8099b0e569f862ece05740aef06c82a2"
 
-SRC_URI[sha256sum] = "13c2fa89562f7b8af40cc74b55f490be5e2ab8ccfb739f11c16d3ce6221a61ba"
+SRC_URI[sha256sum] = "9256300be1e0412be802aa1f827e0ce7f94deb1099b8ccdcfd9867a7f0f975bf"
 
-SRC_URI += " \
-          file://0001-setup.py-Make-the-cmd-available.patch \
-          file://0001-fix-allow-64-bit-time_t-on-32-bit-systems-in-test_is.patch \
-          file://0002-fix-correct-struct-packing-on-32-bit-with-_TIME_BITS.patch \
-"
+SRC_URI += "file://0001-setup.py-Make-the-cmd-available.patch"
 
 CVE_STATUS[CVE-2009-0127] = "disputed: upstream claims there is no bug"
 CVE_STATUS[CVE-2020-25657] = "fixed-version: the used version (0.46.2) contains the fix already"