Merge pull request #126 from plieven/async_avoid_busy_wait
iscsi_which_events: do not set POLLOUT if context is corked
This commit is contained in:
@@ -383,8 +383,10 @@ iscsi_which_events(struct iscsi_context *iscsi)
|
|||||||
{
|
{
|
||||||
int events = iscsi->is_connected ? POLLIN : POLLOUT;
|
int events = iscsi->is_connected ? POLLIN : POLLOUT;
|
||||||
|
|
||||||
if (iscsi->outqueue_current != NULL || (iscsi->outqueue != NULL && iscsi_serial32_compare(iscsi->outqueue->cmdsn, iscsi->maxcmdsn) <= 0)) {
|
if (iscsi->outqueue_current != NULL ||
|
||||||
events |= POLLOUT;
|
(iscsi->outqueue != NULL && !iscsi->is_corked &&
|
||||||
|
iscsi_serial32_compare(iscsi->outqueue->cmdsn, iscsi->maxcmdsn) <= 0)) {
|
||||||
|
events |= POLLOUT;
|
||||||
}
|
}
|
||||||
return events;
|
return events;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user