openpgm: Add Pragmatic General Multicast library

OpenPGM is a library implementing the PGM reliable multicast
network protocol; The famous messaging library ZMQ has an
optional dependency on OpenPGM, with OpenPGM enabled, we can
foster the development of multicast network applications.

Signed-off-by: Ye Holmes <yeholmes@outlook.com>
This commit is contained in:
Ye Holmes
2021-01-03 18:40:03 +08:00
parent c87d337c1b
commit 20f05f8e58
3 changed files with 143 additions and 0 deletions
@@ -0,0 +1,45 @@
From 240634b1afb968a051f8c68696eae2a582a02450 Mon Sep 17 00:00:00 2001
From: Fabrice Fontaine <fontaine.fabrice@gmail.com>
Date: Mon, 31 Aug 2020 20:16:25 +0200
Subject: [PATCH 1/2] Rename openpgm-5.2.pc.in
This will fix the following build failure:
config.status: error: cannot find input file: `openpgm-5.3.pc.in'
Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
---
openpgm/pgm/{openpgm-5.2.pc.in => openpgm-5.3.pc.in} | 0
1 file changed, 0 insertions(+), 0 deletions(-)
rename openpgm/pgm/{openpgm-5.2.pc.in => openpgm-5.3.pc.in} (100%)
--- a/openpgm/pgm/openpgm-5.2.pc.in
+++ /dev/null
@@ -1,12 +0,0 @@
-prefix=@prefix@
-exec_prefix=@exec_prefix@
-libdir=@libdir@
-includedir=@includedir@
-
-Name: OpenPGM
-Description: PGM Protocol Library.
-Version: @PACKAGE_VERSION@
-# packagers may wish to move @LIBS@ to Libs.private for platforms with
-# versions of pkg-config that support static linking.
-Libs: -L${libdir} -lpgm @LIBS@
-Cflags: -I${includedir}/pgm-@VERSION_MAJOR@.@VERSION_MINOR@
--- /dev/null
+++ b/openpgm/pgm/openpgm-5.3.pc.in
@@ -0,0 +1,12 @@
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+libdir=@libdir@
+includedir=@includedir@
+
+Name: OpenPGM
+Description: PGM Protocol Library.
+Version: @PACKAGE_VERSION@
+# packagers may wish to move @LIBS@ to Libs.private for platforms with
+# versions of pkg-config that support static linking.
+Libs: -L${libdir} -lpgm @LIBS@
+Cflags: -I${includedir}/pgm-@VERSION_MAJOR@.@VERSION_MINOR@
@@ -0,0 +1,33 @@
From b7fa865fa6b06d97d424c500fd1c4bc44c096359 Mon Sep 17 00:00:00 2001
From: Fabrice Fontaine <fontaine.fabrice@gmail.com>
Date: Sun, 1 Nov 2020 22:46:18 +0100
Subject: [PATCH 2/2] openpgm/pgm/checksum.c: fix build with 32 bits MMX
Build with i386-pentium-mmx or i686 is broken since version 5-3-128 and
https://github.com/steve-o/openpgm/commit/b276dc15be5d4e6e1143b9de25d09f63f9c85135
because _mm_cvtm64_si64 is undefined resulting in the following build
failure for example on zeromq:
/srv/storage/autobuild/run/instance-3/output-1/host/opt/ext-toolchain/bin/../lib/gcc/i586-buildroot-linux-musl/8.3.0/../../../../i586-buildroot-linux-musl/bin/ld: /srv/storage/autobuild/run/instance-3/output-1/host/i586-buildroot-linux-musl/sysroot/usr/lib32/libpgm-5.3.so.0: undefined reference to `_mm_cvtm64_si64'
So use the fallback if __x86_64__ is not defined
Fixes:
- http://autobuild.buildroot.org/results/01d9be37e8a743307128f53f41785654c9971e1a
Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
---
openpgm/pgm/checksum.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
--- a/openpgm/pgm/checksum.c
+++ b/openpgm/pgm/checksum.c
@@ -948,7 +948,7 @@ do_csumcpy_mmx (
sum = _mm_add_pi32 (sum, lo);
sum = _mm_add_pi32 (sum, hi);
-#if 1
+#if defined(__x86_64__)
*(int64_t*)dst = _mm_cvtm64_si64 (tmp);
#else
((int*)dst)[1] = _mm_cvtsi64_si32 (tmp);