- Replace gsoap-02-typepuns.diff with better version from SF
- Add gsoap-allocator.diff to please UBSAN OBS-URL: https://build.opensuse.org/package/show/devel:libraries:c_c++/gsoap?expand=0&rev=43
This commit is contained in:
parent
4402d71339
commit
041d5dff91
@ -1,31 +1,86 @@
|
|||||||
From: Jan Engelhardt <jengelh@medozas.de>
|
References: https://sourceforge.net/p/gsoap2/patches/124/attachment/gsoap-aliasing.patch
|
||||||
Date: 2011-07-01 17:19:00 +0200
|
|
||||||
|
|
||||||
src: fix invocation of undefined behavior
|
diff -ur gsoap-2.8.orig/gsoap/plugin/wsaapi.c gsoap-2.8/gsoap/plugin/wsaapi.c
|
||||||
|
--- gsoap-2.8.orig/gsoap/plugin/wsaapi.c 2015-04-14 08:46:30.000000000 +0200
|
||||||
The int type may have a stricter alignment than buf, and as such,
|
+++ gsoap-2.8/gsoap/plugin/wsaapi.c 2015-05-05 09:19:27.985619710 +0200
|
||||||
using *(int *)buf is prone to undefined behavior, usually manifesting
|
@@ -599,7 +599,7 @@
|
||||||
themselves in SIGBUS.
|
k += 0x7FFFFFFF;
|
||||||
|
r2 = k;
|
||||||
---
|
k &= 0x8FFFFFFF;
|
||||||
gsoap/stdsoap2.c | 4 +++-
|
- r2 += *(int*)soap->buf;
|
||||||
1 file changed, 3 insertions(+), 1 deletion(-)
|
+ r2 += soap->buf[0] << 24 + soap->buf[1] << 16 + soap->buf[2] << 8 + soap->buf[3];
|
||||||
|
#endif
|
||||||
Index: gsoap-2.8.21/gsoap/stdsoap2.c
|
r3 = soap_random;
|
||||||
===================================================================
|
r4 = soap_random;
|
||||||
--- gsoap-2.8.21.orig/gsoap/stdsoap2.c
|
diff -ur gsoap-2.8.orig/gsoap/samples/calc_vs2005/calc_vs2005/stdsoap2.cpp gsoap-2.8/gsoap/samples/calc_vs2005/calc_vs2005/stdsoap2.cpp
|
||||||
+++ gsoap-2.8.21/gsoap/stdsoap2.c
|
--- gsoap-2.8.orig/gsoap/samples/calc_vs2005/calc_vs2005/stdsoap2.cpp 2015-04-14 08:46:34.000000000 +0200
|
||||||
@@ -3073,10 +3073,12 @@ int
|
+++ gsoap-2.8/gsoap/samples/calc_vs2005/calc_vs2005/stdsoap2.cpp 2015-05-05 09:01:31.633153838 +0200
|
||||||
|
@@ -3105,11 +3105,11 @@
|
||||||
|
int
|
||||||
SOAP_FMAC2
|
SOAP_FMAC2
|
||||||
soap_rand()
|
soap_rand()
|
||||||
{ unsigned char buf[4];
|
-{ unsigned char buf[4];
|
||||||
+ int r;
|
+{ int buf;
|
||||||
if (!soap_ssl_init_done)
|
if (!soap_ssl_init_done)
|
||||||
soap_ssl_init();
|
soap_ssl_init();
|
||||||
RAND_pseudo_bytes(buf, 4);
|
- RAND_pseudo_bytes(buf, 4);
|
||||||
- return *(int*)buf;
|
- return *(int*)buf;
|
||||||
+ memcpy(&r, buf, sizeof(r));
|
+ RAND_pseudo_bytes((unsigned char*)&buf, sizeof(int));
|
||||||
+ return r;
|
+ return buf;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
diff -ur gsoap-2.8.orig/gsoap/stdsoap2.c gsoap-2.8/gsoap/stdsoap2.c
|
||||||
|
--- gsoap-2.8.orig/gsoap/stdsoap2.c 2015-04-14 08:46:36.000000000 +0200
|
||||||
|
+++ gsoap-2.8/gsoap/stdsoap2.c 2015-05-05 09:01:31.633153838 +0200
|
||||||
|
@@ -3105,11 +3105,11 @@
|
||||||
|
int
|
||||||
|
SOAP_FMAC2
|
||||||
|
soap_rand()
|
||||||
|
-{ unsigned char buf[4];
|
||||||
|
+{ int buf;
|
||||||
|
if (!soap_ssl_init_done)
|
||||||
|
soap_ssl_init();
|
||||||
|
- RAND_pseudo_bytes(buf, 4);
|
||||||
|
- return *(int*)buf;
|
||||||
|
+ RAND_pseudo_bytes((unsigned char*)&buf, sizeof(int));
|
||||||
|
+ return buf;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
diff -ur gsoap-2.8.orig/gsoap/stdsoap2.cpp gsoap-2.8/gsoap/stdsoap2.cpp
|
||||||
|
--- gsoap-2.8.orig/gsoap/stdsoap2.cpp 2015-04-14 08:46:36.000000000 +0200
|
||||||
|
+++ gsoap-2.8/gsoap/stdsoap2.cpp 2015-05-05 09:01:31.633153838 +0200
|
||||||
|
@@ -3105,11 +3105,11 @@
|
||||||
|
int
|
||||||
|
SOAP_FMAC2
|
||||||
|
soap_rand()
|
||||||
|
-{ unsigned char buf[4];
|
||||||
|
+{ int buf;
|
||||||
|
if (!soap_ssl_init_done)
|
||||||
|
soap_ssl_init();
|
||||||
|
- RAND_pseudo_bytes(buf, 4);
|
||||||
|
- return *(int*)buf;
|
||||||
|
+ RAND_pseudo_bytes((unsigned char*)&buf, sizeof(int));
|
||||||
|
+ return buf;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
diff -ur gsoap-2.8.orig/gsoap/VisualStudio2005/wsdl2h/wsdl2h/stdsoap2.cpp gsoap-2.8/gsoap/VisualStudio2005/wsdl2h/wsdl2h/stdsoap2.cpp
|
||||||
|
--- gsoap-2.8.orig/gsoap/VisualStudio2005/wsdl2h/wsdl2h/stdsoap2.cpp 2015-04-14 08:46:36.000000000 +0200
|
||||||
|
+++ gsoap-2.8/gsoap/VisualStudio2005/wsdl2h/wsdl2h/stdsoap2.cpp 2015-05-05 09:01:31.633153838 +0200
|
||||||
|
@@ -3105,11 +3105,11 @@
|
||||||
|
int
|
||||||
|
SOAP_FMAC2
|
||||||
|
soap_rand()
|
||||||
|
-{ unsigned char buf[4];
|
||||||
|
+{ int buf;
|
||||||
|
if (!soap_ssl_init_done)
|
||||||
|
soap_ssl_init();
|
||||||
|
- RAND_pseudo_bytes(buf, 4);
|
||||||
|
- return *(int*)buf;
|
||||||
|
+ RAND_pseudo_bytes((unsigned char*)&buf, sizeof(int));
|
||||||
|
+ return buf;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
39
gsoap-allocator.diff
Normal file
39
gsoap-allocator.diff
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
---
|
||||||
|
gsoap/stdsoap2.cpp | 17 +++++++++++++++--
|
||||||
|
1 file changed, 15 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
Index: gsoap-2.8.22/gsoap/stdsoap2.cpp
|
||||||
|
===================================================================
|
||||||
|
--- gsoap-2.8.22.orig/gsoap/stdsoap2.cpp
|
||||||
|
+++ gsoap-2.8.22/gsoap/stdsoap2.cpp
|
||||||
|
@@ -7256,7 +7256,13 @@ SOAP_FMAC1
|
||||||
|
struct soap*
|
||||||
|
SOAP_FMAC2
|
||||||
|
soap_versioning(soap_new)(soap_mode imode, soap_mode omode)
|
||||||
|
-{ struct soap *soap = (struct soap*)malloc(sizeof(struct soap));
|
||||||
|
+{
|
||||||
|
+#ifdef __cplusplus
|
||||||
|
+ struct soap *soap = new struct soap;
|
||||||
|
+#else
|
||||||
|
+ struct soap *soap = malloc(sizeof(struct soap));
|
||||||
|
+ soap->dummy = NULL;
|
||||||
|
+#endif
|
||||||
|
if (soap)
|
||||||
|
soap_versioning(soap_init)(soap, imode, omode);
|
||||||
|
return soap;
|
||||||
|
@@ -8983,7 +8989,14 @@ SOAP_FMAC1
|
||||||
|
struct soap*
|
||||||
|
SOAP_FMAC2
|
||||||
|
soap_copy(const struct soap *soap)
|
||||||
|
-{ return soap_copy_context((struct soap*)malloc(sizeof(struct soap)), soap);
|
||||||
|
+{
|
||||||
|
+#ifdef __cplusplus
|
||||||
|
+ return soap_copy_context(new struct soap, soap);
|
||||||
|
+#else
|
||||||
|
+ struct soap *s = malloc(sizeof(struct soap));
|
||||||
|
+ s->dummy = NULL;
|
||||||
|
+ return soap_copy_context(s, soap);
|
||||||
|
+#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Jun 2 11:19:46 UTC 2015 - jengelh@inai.de
|
||||||
|
|
||||||
|
- Replace gsoap-02-typepuns.diff with better version from SF
|
||||||
|
- Add gsoap-allocator.diff to please UBSAN
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Thu May 28 17:31:39 UTC 2015 - jengelh@inai.de
|
Thu May 28 17:31:39 UTC 2015 - jengelh@inai.de
|
||||||
|
|
||||||
|
@ -32,6 +32,7 @@ Patch13: gsoap-automake1_13.diff
|
|||||||
Patch1: gsoap-01-sharedlibs.diff
|
Patch1: gsoap-01-sharedlibs.diff
|
||||||
Patch2: gsoap-02-typepuns.diff
|
Patch2: gsoap-02-typepuns.diff
|
||||||
Patch3: gsoap-mindeflateratio.diff
|
Patch3: gsoap-mindeflateratio.diff
|
||||||
|
Patch4: gsoap-allocator.diff
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
BuildRequires: autoconf
|
BuildRequires: autoconf
|
||||||
BuildRequires: automake
|
BuildRequires: automake
|
||||||
@ -92,7 +93,7 @@ symlinks for libgsoap.
|
|||||||
%prep
|
%prep
|
||||||
%setup -q
|
%setup -q
|
||||||
cmp gsoap/stdsoap2.cpp gsoap/stdsoap2.c
|
cmp gsoap/stdsoap2.cpp gsoap/stdsoap2.c
|
||||||
%patch -P 13 -P 1 -P 2 -P 3 -p1
|
%patch -P 13 -P 1 -P 2 -P 3 -P 4 -p1
|
||||||
cp gsoap/stdsoap2.cpp gsoap/stdsoap2.c
|
cp gsoap/stdsoap2.cpp gsoap/stdsoap2.c
|
||||||
|
|
||||||
%build
|
%build
|
||||||
|
Loading…
Reference in New Issue
Block a user