FreeBSD Bugzilla – Attachment 150910 Details for
Bug 192511
lang/python27: Fix build with LibreSSL
Home
|
New
|
Browse
|
Search
|
[?]
|
Reports
|
Help
|
New Account
|
Log In
Remember
[x]
|
Forgot Password
Login:
[x]
[patch]
Single patch for this PR for the source tree
patch-PR192511 (text/plain), 6.24 KB, created by
Bernard Spil
on 2014-12-23 14:44:04 UTC
(
hide
)
Description:
Single patch for this PR for the source tree
Filename:
MIME Type:
Creator:
Bernard Spil
Created:
2014-12-23 14:44:04 UTC
Size:
6.24 KB
patch
obsolete
>--- configure.ac.orig 2014-12-10 17:00:00.000000000 +0100 >+++ configure.ac 2014-12-23 15:17:50.570562412 +0100 >@@ -2222,6 +2222,13 @@ > AC_CHECK_LIB(dl, dlopen) # Dynamic linking for SunOS/Solaris and SYSV > AC_CHECK_LIB(dld, shl_load) # Dynamic linking for HP-UX > >+### Fix build with LibreSSL (does not have RAND_egd) >+### PR192511, http://bugs.python.org/issue21356 >+AC_CHECK_LIB(crypto, RAND_egd, >+ AC_DEFINE(HAVE_RAND_EGD, 1, >+ [Define if the libcrypto has RAND_egd])) >+### End PR192511 >+ > # only check for sem_init if thread support is requested > if test "$with_threads" = "yes" -o -z "$with_threads"; then > AC_SEARCH_LIBS(sem_init, pthread rt posix4) # 'Real Time' functions on Solaris >--- configure.orig 2014-12-23 15:23:19.427528991 +0100 >+++ configure 2014-12-23 15:23:24.595528316 +0100 >@@ -8542,6 +8542,52 @@ > fi > # Dynamic linking for HP-UX > >+### Fix build with LibreSSL (does not have RAND_egd) >+### PR192511, http://bugs.python.org/issue21356 >+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for RAND_egd in -lcrypto" >&5 >+$as_echo_n "checking for RAND_egd in -lcrypto... " >&6; } >+if ${ac_cv_lib_crypto_RAND_egd+:} false; then : >+ $as_echo_n "(cached) " >&6 >+else >+ ac_check_lib_save_LIBS=$LIBS >+LIBS="-lcrypto $LIBS" >+cat confdefs.h - <<_ACEOF >conftest.$ac_ext >+/* end confdefs.h. */ >+ >+/* Override any GCC internal prototype to avoid an error. >+ Use char because int might match the return type of a GCC >+ builtin and then its argument prototype would still apply. */ >+#ifdef __cplusplus >+extern "C" >+#endif >+char RAND_egd (); >+int >+main () >+{ >+return RAND_egd (); >+ ; >+ return 0; >+} >+_ACEOF >+if ac_fn_c_try_link "$LINENO"; then : >+ ac_cv_lib_crypto_RAND_egd=yes >+else >+ ac_cv_lib_crypto_RAND_egd=no >+fi >+rm -f core conftest.err conftest.$ac_objext \ >+ conftest$ac_exeext conftest.$ac_ext >+LIBS=$ac_check_lib_save_LIBS >+fi >+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_RAND_egd" >&5 >+$as_echo "$ac_cv_lib_crypto_RAND_egd" >&6; } >+if test "x$ac_cv_lib_crypto_RAND_egd" = xyes; then : >+ >+$as_echo "#define HAVE_RAND_EGD 1" >>confdefs.h >+ >+fi >+ >+### End PR192511 >+ > # only check for sem_init if thread support is requested > if test "$with_threads" = "yes" -o -z "$with_threads"; then > { $as_echo "$as_me:${as_lineno-$LINENO}: checking for library containing sem_init" >&5 >--- pyconfig.h.in.orig 2014-12-10 17:00:01.000000000 +0100 >+++ pyconfig.h.in 2014-12-23 15:28:07.683511124 +0100 >@@ -544,6 +544,12 @@ > /* Define to 1 if you have the `putenv' function. */ > #undef HAVE_PUTENV > >+/* ### Fix build with LibreSSL (does not have RAND_egd) >+ ### PR192511, http://bugs.python.org/issue21356 */ >+/* Define if the libcrypto has RAND_egd */ >+#undef HAVE_RAND_EGD >+ >+/* ### End PR192511 */ > /* Define to 1 if you have the `readlink' function. */ > #undef HAVE_READLINK > >--- Lib/test/test_ssl.py.orig 2014-12-10 16:59:47.000000000 +0100 >+++ Lib/test/test_ssl.py 2014-12-23 15:29:03.671507169 +0100 >@@ -169,8 +169,12 @@ > sys.stdout.write("\n RAND_status is %d (%s)\n" > % (v, (v and "sufficient randomness") or > "insufficient randomness")) >- self.assertRaises(TypeError, ssl.RAND_egd, 1) >- self.assertRaises(TypeError, ssl.RAND_egd, 'foo', 1) >+### Fix build with LibreSSL (does not have RAND_egd) >+### PR192511, http://bugs.python.org/issue21356 >+ if hasattr(ssl, 'RAND_egd'): >+ self.assertRaises(TypeError, ssl.RAND_egd, 1) >+ self.assertRaises(TypeError, ssl.RAND_egd, 'foo', 1) >+### End PR192511 > ssl.RAND_add("this is a random string", 75.0) > > def test_parse_cert(self): >--- Lib/ssl.py.orig 2014-12-10 16:59:40.000000000 +0100 >+++ Lib/ssl.py 2014-12-23 15:30:57.679498759 +0100 >@@ -106,7 +106,15 @@ > from _ssl import (VERIFY_DEFAULT, VERIFY_CRL_CHECK_LEAF, VERIFY_CRL_CHECK_CHAIN, > VERIFY_X509_STRICT) > from _ssl import txt2obj as _txt2obj, nid2obj as _nid2obj >-from _ssl import RAND_status, RAND_egd, RAND_add >+### Fix build with LibreSSL (does not have RAND_egd) >+### PR192511, http://bugs.python.org/issue21356 >+from _ssl import RAND_status, RAND_add >+try: >+ from _ssl import RAND_egd >+except ImportError: >+ # LibreSSL does not provide RAND_egd >+ pass >+### End PR192511 > > def _import_symbols(prefix): > for n in dir(_ssl): >--- Lib/socket.py.orig 2014-12-10 16:59:40.000000000 +0100 >+++ Lib/socket.py 2014-12-23 15:32:00.314494931 +0100 >@@ -67,7 +67,6 @@ > from _ssl import SSLError as sslerror > from _ssl import \ > RAND_add, \ >- RAND_egd, \ > RAND_status, \ > SSL_ERROR_ZERO_RETURN, \ > SSL_ERROR_WANT_READ, \ >@@ -78,6 +77,14 @@ > SSL_ERROR_WANT_CONNECT, \ > SSL_ERROR_EOF, \ > SSL_ERROR_INVALID_ERROR_CODE >+### Fix build with LibreSSL (does not have RAND_egd) >+### PR192511, http://bugs.python.org/issue21356 >+ try: >+ from _ssl import RAND_egd >+ # LibreSSL does not provide RAND_egd >+ except ImportError: >+ pass >+### End PR192511 > > import os, sys, warnings > >--- Modules/_ssl.c.orig 2014-12-10 16:59:53.000000000 +0100 >+++ Modules/_ssl.c 2014-12-23 15:34:26.287482502 +0100 >@@ -3301,6 +3301,9 @@ > It is necessary to seed the PRNG with RAND_add() on some platforms before\n\ > using the ssl() function."); > >+/* ### Fix build with LibreSSL (does not have RAND_egd) >+ ### PR192511, http://bugs.python.org/issue21356 */ >+#ifdef HAVE_RAND_EGD > static PyObject * > PySSL_RAND_egd(PyObject *self, PyObject *arg) > { >@@ -3326,6 +3329,8 @@ > Queries the entropy gather daemon (EGD) on the socket named by 'path'.\n\ > Returns number of bytes read. Raises SSLError if connection to EGD\n\ > fails or if it does not provide enough data to seed PRNG."); >+#endif /* HAVE_RAND_EGD */ >+/* ### End PR192511 */ > > #endif /* HAVE_OPENSSL_RAND */ > >@@ -3720,8 +3725,13 @@ > #ifdef HAVE_OPENSSL_RAND > {"RAND_add", PySSL_RAND_add, METH_VARARGS, > PySSL_RAND_add_doc}, >+/* ### Fix build with LibreSSL (does not have RAND_egd) >+ ### PR192511, http://bugs.python.org/issue21356 */ >+#ifdef HAVE_RAND_EGD > {"RAND_egd", PySSL_RAND_egd, METH_VARARGS, > PySSL_RAND_egd_doc}, >+#endif /* HAVE_RAND_EGD */ >+/* ### End PR192551 */ > {"RAND_status", (PyCFunction)PySSL_RAND_status, METH_NOARGS, > PySSL_RAND_status_doc}, > #endif
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Diff
View Attachment As Raw
Actions:
View
|
Diff
Attachments on
bug 192511
:
145517
|
149952
|
149974
|
149975
|
149976
|
149998
|
149999
|
150000
|
150909
|
150910
|
150944
|
151207
|
151208
|
153781
|
153782
|
153783
|
153820
|
153828
|
154266
|
154280
|
154281
|
154282
|
154283
|
154342
|
154344
|
154345
|
155432
|
157097
|
157316