cURL

curl's project page on SourceForge.net

Sponsors:
Haxx

cURL > Mailing List > Monthly Index > Single Mail

curl-tracker Archives

[curl:feature-requests] #77 Support user's network reactors in edge-triggered mode

From: Daniel Stenberg <bagder_at_users.sf.net>
Date: Thu, 03 Apr 2014 11:05:55 +0000

- **status**: open --> pending
- **assigned_to**: Daniel Stenberg
- **Comment**:

libcurl already works as alternative (1) or should be. Edge-triggered is what most event libraries do and libcurl has been used fine by many different ones.

---
** [feature-requests:#77] Support user's network reactors in edge-triggered mode**
**Status:** pending
**Created:** Wed Apr 02, 2014 07:36 AM UTC by Constantin Baranov
**Last Updated:** Wed Apr 02, 2014 07:36 AM UTC
**Owner:** Daniel Stenberg
An edge-triggered reactor like epoll with EPOLLET flag enabled supposes that at every iteration user (I/O handler) has to drain/fill all buffers to be able to receive next event on the same socket. If you're notified that a socket is writable, you keep writing to it until you get EAGAIN, same for reading.
curl_multi_socket_action() performs single iteration around given socket. To fit in the above mentioned model either one modification is needed:
* curl_multi_socket_action() shall perform as much I/O on given socket as possible without blocking. Easier to implement, but may lead to a starvation of other sockets in the same multi set.
* curl_multi_socket_action() shall return special value (CURLM_CALL_MULTI_PERFORM? or return the 'remaining' (not completely drained) events mask) if it hasn't received EAGAIN yet and thus could be called again without waiting.
The later approach seems better to me, but most likely will require many changes in multi implementation and, even worse, in some protocol implementation like SSL.
---
Sent from sourceforge.net because curl-tracker@cool.haxx.se is subscribed to https://sourceforge.net/p/curl/feature-requests/
To unsubscribe from further messages, a project admin can change settings at https://sourceforge.net/p/curl/admin/feature-requests/options.  Or, if this is a mailing list, you can unsubscribe from the mailing list.
Received on 2014-04-03

These mail archives are generated by hypermail.

donate! Page updated March 21, 2014.
web site info

File upload with ASP.NET