Performance optimization for big select timeouts (#10, Andrey Bondarenko), Fix restart of select call after interrupt signal (#8, Boian Bonev)

pull/10/merge
David Schweikert 13 years ago
parent 293a632056
commit 74066a00ea

@ -1,3 +1,7 @@
Unreleased
* Performance optimization for big select timeouts (#10, Andrey Bondarenko)
* Fix restart of select call after interrupt signal (#8, Boian Bonev)
Thu Apr 26 2012 Thu Apr 26 2012
David Schweikert <david@schweikert.ch> David Schweikert <david@schweikert.ch>
- Revision v3.1 - Revision v3.1

@ -2587,13 +2587,13 @@ void u_sleep( int u_sec )
struct timeval to; struct timeval to;
fd_set readset, writeset; fd_set readset, writeset;
select_again:
to.tv_sec = u_sec / 1000000; to.tv_sec = u_sec / 1000000;
to.tv_usec = u_sec - ( to.tv_sec * 1000000 ); to.tv_usec = u_sec - ( to.tv_sec * 1000000 );
FD_ZERO( &readset ); FD_ZERO( &readset );
FD_ZERO( &writeset ); FD_ZERO( &writeset );
select_again:
nfound = select( 0, &readset, &writeset, NULL, &to ); nfound = select( 0, &readset, &writeset, NULL, &to );
if(nfound < 0) { if(nfound < 0) {
if(errno == EINTR) { if(errno == EINTR) {
@ -2635,18 +2635,20 @@ int recvfrom_wto( int s, char *buf, int len, FPING_SOCKADDR *saddr, long timo )
struct timeval to; struct timeval to;
fd_set readset, writeset; fd_set readset, writeset;
select_again:
if(timo < 100000) {
to.tv_sec = 0; to.tv_sec = 0;
to.tv_usec = timo * 10; to.tv_usec = timo * 10;
while (to.tv_usec > 1000000) { }
to.tv_sec++; else {
to.tv_usec -= 1000000; to.tv_sec = timo / 100000 ;
to.tv_usec = (timo % 100000) * 10 ;
} }
FD_ZERO( &readset ); FD_ZERO( &readset );
FD_ZERO( &writeset ); FD_ZERO( &writeset );
FD_SET( s, &readset ); FD_SET( s, &readset );
select_again:
nfound = select( s + 1, &readset, &writeset, NULL, &to ); nfound = select( s + 1, &readset, &writeset, NULL, &to );
if(nfound < 0) { if(nfound < 0) {
if(errno == EINTR) { if(errno == EINTR) {

Loading…
Cancel
Save