mirror of
https://github.com/samba-team/samba.git
synced 2025-02-25 17:57:42 +03:00
s3: Eliminate sys_select from do_smb_browse() -- untested
This commit is contained in:
parent
89d81b310e
commit
b28a2e519a
@ -23,6 +23,7 @@
|
||||
#ifdef WITH_DNSSD_SUPPORT
|
||||
|
||||
#include <dns_sd.h>
|
||||
#include "system/select.h"
|
||||
|
||||
/* Holds service instances found during DNS browse */
|
||||
struct mdns_smbsrv_result
|
||||
@ -155,7 +156,6 @@ int do_smb_browse(void)
|
||||
int mdnsfd;
|
||||
int fdsetsz;
|
||||
int ret;
|
||||
fd_set *fdset = NULL;
|
||||
struct mdns_browse_state bstate;
|
||||
struct mdns_smbsrv_result *resptr;
|
||||
struct timeval tv;
|
||||
@ -177,24 +177,14 @@ int do_smb_browse(void)
|
||||
|
||||
mdnsfd = DNSServiceRefSockFD(mdns_conn_sdref);
|
||||
for (;;) {
|
||||
if (fdset != NULL) {
|
||||
TALLOC_FREE(fdset);
|
||||
}
|
||||
int revents;
|
||||
|
||||
fdsetsz = howmany(mdnsfd + 1, NFDBITS) * sizeof(fd_mask);
|
||||
fdset = TALLOC_ZERO(ctx, fdsetsz);
|
||||
FD_SET(mdnsfd, fdset);
|
||||
|
||||
tv.tv_sec = 1;
|
||||
tv.tv_usec = 0;
|
||||
|
||||
/* Wait until response received from mDNS daemon */
|
||||
ret = sys_select(mdnsfd + 1, fdset, NULL, NULL, &tv);
|
||||
ret = poll_one_fd(mdnsfd, POLLIN|POLLHUP, &revents, 1000);
|
||||
if (ret <= 0 && errno != EINTR) {
|
||||
break;
|
||||
}
|
||||
|
||||
if (FD_ISSET(mdnsfd, fdset)) {
|
||||
if (revents & (POLLIN|POLLHUP|POLLERR)) {
|
||||
/* Invoke callback function */
|
||||
if (DNSServiceProcessResult(mdns_conn_sdref)) {
|
||||
break;
|
||||
|
Loading…
x
Reference in New Issue
Block a user