[curl] curl_global_init() now accepts the CURL_GLOBAL_ACK_EINTR flag (#919127)

Kamil Dudka kdudka at fedoraproject.org
Tue Mar 12 10:40:49 UTC 2013


commit 8dc39146993cf57bbad31aecd6bb84df8235b813
Author: Kamil Dudka <kdudka at redhat.com>
Date:   Tue Mar 12 11:36:55 2013 +0100

    curl_global_init() now accepts the CURL_GLOBAL_ACK_EINTR flag (#919127)

 0004-curl-7.29.0-57ccdfa8.patch |  143 +++++++++++++++++++++++++++++++++++++++
 curl.spec                       |    5 ++
 2 files changed, 148 insertions(+), 0 deletions(-)
---
diff --git a/0004-curl-7.29.0-57ccdfa8.patch b/0004-curl-7.29.0-57ccdfa8.patch
new file mode 100644
index 0000000..1448d64
--- /dev/null
+++ b/0004-curl-7.29.0-57ccdfa8.patch
@@ -0,0 +1,143 @@
+From 37a515d9933a3160a8a868d5a697a42b28f6d792 Mon Sep 17 00:00:00 2001
+From: Zdenek Pavlas <zpavlas at redhat.com>
+Date: Mon, 11 Mar 2013 14:57:07 +0100
+Subject: [PATCH 2/2] curl_global_init: accept the CURL_GLOBAL_ACK_EINTR flag
+
+The flag can be used in pycurl-based applications where using the multi
+interface would not be acceptable because of the performance lost caused
+by implementing the select() loop in python.
+
+Bug: http://curl.haxx.se/bug/view.cgi?id=1168
+Downstream Bug: https://bugzilla.redhat.com/919127
+
+[upstream commit 57ccdfa8d2bb6275388223f4676cd623ebd01697]
+---
+ docs/libcurl/curl_global_init.3  |    4 ++++
+ docs/libcurl/symbols-in-versions |    1 +
+ include/curl/curl.h              |    1 +
+ lib/easy.c                       |    2 ++
+ lib/select.c                     |   17 ++---------------
+ lib/select.h                     |    6 ++++++
+ 6 files changed, 16 insertions(+), 15 deletions(-)
+
+diff --git a/docs/libcurl/curl_global_init.3 b/docs/libcurl/curl_global_init.3
+index d91e1bd..6a08383 100644
+--- a/docs/libcurl/curl_global_init.3
++++ b/docs/libcurl/curl_global_init.3
+@@ -70,6 +70,10 @@ Initialise nothing extra. This sets no bit.
+ .B CURL_GLOBAL_DEFAULT
+ A sensible default. It will init both SSL and Win32. Right now, this equals
+ the functionality of the \fBCURL_GLOBAL_ALL\fP mask.
++.TP
++.B CURL_GLOBAL_ACK_EINTR
++When this flag is set, curl will acknowledge EINTR condition when connecting
++or when waiting for data.  Otherwise, curl waits until full timeout elapses.
+ .SH RETURN VALUE
+ If this function returns non-zero, something went wrong and you cannot use the
+ other curl functions.
+diff --git a/docs/libcurl/symbols-in-versions b/docs/libcurl/symbols-in-versions
+index 1de1ace..37b5e27 100644
+--- a/docs/libcurl/symbols-in-versions
++++ b/docs/libcurl/symbols-in-versions
+@@ -614,6 +614,7 @@ CURL_GLOBAL_DEFAULT             7.8
+ CURL_GLOBAL_NOTHING             7.8
+ CURL_GLOBAL_SSL                 7.8
+ CURL_GLOBAL_WIN32               7.8.1
++CURL_GLOBAL_ACK_EINTR           7.30.0
+ CURL_HTTP_VERSION_1_0           7.9.1
+ CURL_HTTP_VERSION_1_1           7.9.1
+ CURL_HTTP_VERSION_NONE          7.9.1
+diff --git a/include/curl/curl.h b/include/curl/curl.h
+index 5b39a24..80e4cf5 100644
+--- a/include/curl/curl.h
++++ b/include/curl/curl.h
+@@ -2023,6 +2023,7 @@ typedef enum {
+ #define CURL_GLOBAL_ALL (CURL_GLOBAL_SSL|CURL_GLOBAL_WIN32)
+ #define CURL_GLOBAL_NOTHING 0
+ #define CURL_GLOBAL_DEFAULT CURL_GLOBAL_ALL
++#define CURL_GLOBAL_ACK_EINTR (1<<2)
+ 
+ 
+ /*****************************************************************************
+diff --git a/lib/easy.c b/lib/easy.c
+index 2e747bb..2739598 100644
+--- a/lib/easy.c
++++ b/lib/easy.c
+@@ -262,6 +262,8 @@ CURLcode curl_global_init(long flags)
+   }
+ #endif
+ 
++  Curl_ack_eintr = flags & CURL_GLOBAL_ACK_EINTR;
++
+   init_flags  = flags;
+ 
+   /* Preset pseudo-random number sequence. */
+diff --git a/lib/select.c b/lib/select.c
+index d13e122..db7fb6d 100644
+--- a/lib/select.c
++++ b/lib/select.c
+@@ -50,11 +50,8 @@
+ 
+ #define elapsed_ms  (int)curlx_tvdiff(curlx_tvnow(), initial_tv)
+ 
+-#ifdef CURL_ACKNOWLEDGE_EINTR
+-#define error_not_EINTR (1)
+-#else
+-#define error_not_EINTR (error != EINTR)
+-#endif
++int Curl_ack_eintr = 0;
++#define error_not_EINTR (Curl_ack_eintr || error != EINTR)
+ 
+ /*
+  * Internal function used for waiting a specific amount of ms
+@@ -67,10 +64,6 @@
+  * Timeout resolution, accuracy, as well as maximum supported
+  * value is system dependent, neither factor is a citical issue
+  * for the intended use of this function in the library.
+- * On non-DOS and non-Winsock platforms, when compiled with
+- * CURL_ACKNOWLEDGE_EINTR defined, EINTR condition is honored
+- * and function might exit early without awaiting full timeout,
+- * otherwise EINTR will be ignored and full timeout will elapse.
+  *
+  * Return values:
+  *   -1 = system call error, invalid timeout value, or interrupted
+@@ -133,9 +126,6 @@ int Curl_wait_ms(int timeout_ms)
+  * A negative timeout value makes this function wait indefinitely,
+  * unles no valid file descriptor is given, when this happens the
+  * negative timeout is ignored and the function times out immediately.
+- * When compiled with CURL_ACKNOWLEDGE_EINTR defined, EINTR condition
+- * is honored and function might exit early without awaiting timeout,
+- * otherwise EINTR will be ignored.
+  *
+  * Return values:
+  *   -1 = system call error or fd >= FD_SETSIZE
+@@ -351,9 +341,6 @@ int Curl_socket_check(curl_socket_t readfd0, /* two sockets to read from */
+  * A negative timeout value makes this function wait indefinitely,
+  * unles no valid file descriptor is given, when this happens the
+  * negative timeout is ignored and the function times out immediately.
+- * When compiled with CURL_ACKNOWLEDGE_EINTR defined, EINTR condition
+- * is honored and function might exit early without awaiting timeout,
+- * otherwise EINTR will be ignored.
+  *
+  * Return values:
+  *   -1 = system call error or fd >= FD_SETSIZE
+diff --git a/lib/select.h b/lib/select.h
+index 00789bb..c00afe1 100644
+--- a/lib/select.h
++++ b/lib/select.h
+@@ -81,6 +81,12 @@ int Curl_socket_check(curl_socket_t readfd, curl_socket_t readfd2,
+ 
+ int Curl_poll(struct pollfd ufds[], unsigned int nfds, int timeout_ms);
+ 
++/* On non-DOS and non-Winsock platforms, when Curl_ack_eintr is set,
++ * EINTR condition is honored and function might exit early without
++ * awaiting full timeout.  Otherwise EINTR will be ignored and full
++ * timeout will elapse. */
++extern int Curl_ack_eintr;
++
+ int Curl_wait_ms(int timeout_ms);
+ 
+ #ifdef TPF
+-- 
+1.7.1
+
diff --git a/curl.spec b/curl.spec
index ee1a65b..845fb45 100644
--- a/curl.spec
+++ b/curl.spec
@@ -16,6 +16,9 @@ Patch2: 0002-curl-7.29.0-9d0af301.patch
 # do not ignore poll() failures other than EINTR
 Patch3: 0003-curl-7.29.0-491e026c.patch
 
+# curl_global_init() now accepts the CURL_GLOBAL_ACK_EINTR flag
+Patch4: 0004-curl-7.29.0-57ccdfa8.patch
+
 # patch making libcurl multilib ready
 Patch101: 0101-curl-7.29.0-multilib.patch
 
@@ -112,6 +115,7 @@ documentation of the library, too.
 %patch1 -p1
 %patch2 -p1
 %patch3 -p1
+%patch4 -p1
 
 # Fedora patches
 %patch101 -p1
@@ -231,6 +235,7 @@ rm -rf $RPM_BUILD_ROOT
 %changelog
 * Tue Mar 12 2013 Kamil Dudka <kdudka at redhat.com> 7.29.0-4
 - do not ignore poll() failures other than EINTR (#919127)
+- curl_global_init() now accepts the CURL_GLOBAL_ACK_EINTR flag (#919127)
 
 * Wed Mar 06 2013 Kamil Dudka <kdudka at redhat.com> 7.29.0-3
 - switch SSL socket into non-blocking mode after handshake


More information about the scm-commits mailing list