Commit 0cc74835 authored by Damjan Jovanovic's avatar Damjan Jovanovic Committed by Alexandre Julliard

icmp: Changed select to poll.

parent b56953f4
...@@ -61,6 +61,9 @@ ...@@ -61,6 +61,9 @@
#ifdef HAVE_ARPA_INET_H #ifdef HAVE_ARPA_INET_H
# include <arpa/inet.h> # include <arpa/inet.h>
#endif #endif
#ifdef HAVE_SYS_POLL_H
# include <sys/poll.h>
#endif
#include "windef.h" #include "windef.h"
#include "winbase.h" #include "winbase.h"
...@@ -209,8 +212,7 @@ DWORD WINAPI IcmpSendEcho( ...@@ -209,8 +212,7 @@ DWORD WINAPI IcmpSendEcho(
char* endbuf; char* endbuf;
int ip_header_len; int ip_header_len;
int maxlen; int maxlen;
fd_set fdr; struct pollfd fdr;
struct timeval timeout;
DWORD send_time,recv_time; DWORD send_time,recv_time;
struct sockaddr_in addr; struct sockaddr_in addr;
unsigned int addrlen; unsigned int addrlen;
...@@ -291,10 +293,8 @@ DWORD WINAPI IcmpSendEcho( ...@@ -291,10 +293,8 @@ DWORD WINAPI IcmpSendEcho(
/* Get ready for receiving the reply /* Get ready for receiving the reply
* Do it before we send the request to minimize the risk of introducing delays * Do it before we send the request to minimize the risk of introducing delays
*/ */
FD_ZERO(&fdr); fdr.fd = icp->sid;
FD_SET(icp->sid,&fdr); fdr.events = POLLIN;
timeout.tv_sec=Timeout/1000;
timeout.tv_usec=(Timeout % 1000)*1000;
addrlen=sizeof(addr); addrlen=sizeof(addr);
ier=ReplyBuffer; ier=ReplyBuffer;
ip_header=(struct ip *) ((char *) ReplyBuffer+sizeof(ICMP_ECHO_REPLY)); ip_header=(struct ip *) ((char *) ReplyBuffer+sizeof(ICMP_ECHO_REPLY));
...@@ -338,7 +338,7 @@ DWORD WINAPI IcmpSendEcho( ...@@ -338,7 +338,7 @@ DWORD WINAPI IcmpSendEcho(
/* Get the reply */ /* Get the reply */
ip_header_len=0; /* because gcc was complaining */ ip_header_len=0; /* because gcc was complaining */
while ((res=select(icp->sid+1,&fdr,NULL,NULL,&timeout))>0) { while ((res=poll(&fdr,1,Timeout))>0) {
recv_time = GetTickCount(); recv_time = GetTickCount();
res=recvfrom(icp->sid, (char*)ip_header, maxlen, 0, (struct sockaddr*)&addr,&addrlen); res=recvfrom(icp->sid, (char*)ip_header, maxlen, 0, (struct sockaddr*)&addr,&addrlen);
TRACE("received %d bytes from %s\n",res, inet_ntoa(addr.sin_addr)); TRACE("received %d bytes from %s\n",res, inet_ntoa(addr.sin_addr));
...@@ -433,10 +433,8 @@ DWORD WINAPI IcmpSendEcho( ...@@ -433,10 +433,8 @@ DWORD WINAPI IcmpSendEcho(
* Decrease the timeout so that we don't enter an endless loop even * Decrease the timeout so that we don't enter an endless loop even
* if we get flooded with ICMP packets that are not for us. * if we get flooded with ICMP packets that are not for us.
*/ */
int t = Timeout - (recv_time - send_time); Timeout -= (recv_time - send_time);
if (t < 0) t = 0; if (Timeout < 0) Timeout = 0;
timeout.tv_sec = t / 1000;
timeout.tv_usec = (t % 1000) * 1000;
continue; continue;
} else { } else {
/* This is a reply to our packet */ /* This is a reply to our packet */
...@@ -467,11 +465,8 @@ DWORD WINAPI IcmpSendEcho( ...@@ -467,11 +465,8 @@ DWORD WINAPI IcmpSendEcho(
maxlen=endbuf-(char*)ip_header; maxlen=endbuf-(char*)ip_header;
/* Check out whether there is more but don't wait this time */ /* Check out whether there is more but don't wait this time */
timeout.tv_sec=0; Timeout=0;
timeout.tv_usec=0;
} }
FD_ZERO(&fdr);
FD_SET(icp->sid,&fdr);
} }
res=ier-(ICMP_ECHO_REPLY*)ReplyBuffer; res=ier-(ICMP_ECHO_REPLY*)ReplyBuffer;
if (res==0) if (res==0)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment