fix Solaris /dev/poll
This commit is contained in:
parent
65adb024f5
commit
a4cf7a8a8b
@ -47,6 +47,7 @@ void io_dontwantread(int64 d) {
|
||||
x.fd=d;
|
||||
x.events=0;
|
||||
if (e->wantwrite) x.events|=POLLOUT;
|
||||
if (!x.events) x.events=POLLREMOVE;
|
||||
write(io_master,&x,sizeof(x));
|
||||
}
|
||||
#endif
|
||||
|
@ -47,6 +47,7 @@ void io_dontwantwrite(int64 d) {
|
||||
x.fd=d;
|
||||
x.events=0;
|
||||
if (e->wantread) x.events|=POLLIN;
|
||||
if (!x.events) x.events=POLLREMOVE;
|
||||
write(io_master,&x,sizeof(x));
|
||||
}
|
||||
#endif
|
||||
|
@ -103,13 +103,17 @@ int64 io_waituntil2(int64 milliseconds) {
|
||||
}
|
||||
if (!e->canread && (y[n].revents&POLLIN)) {
|
||||
e->canread=1;
|
||||
e->next_read=first_readable;
|
||||
first_readable=y[n].fd;
|
||||
if (e->next_read==-1) {
|
||||
e->next_read=first_readable;
|
||||
first_readable=y[n].fd;
|
||||
}
|
||||
}
|
||||
if (!e->canwrite && (y[n].revents&POLLOUT)) {
|
||||
e->canwrite=1;
|
||||
e->next_write=first_writeable;
|
||||
first_writeable=y[i].fd;
|
||||
if (e->next_write==-1) {
|
||||
e->next_write=first_writeable;
|
||||
first_writeable=y[i].fd;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user