mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2025-01-02 18:22:04 +00:00
MINOR: poller: centralize poll return handling
When returning from the polling syscall, all pollers have a certain dance to follow, made of wall clock updates, thread harmless updates, idle time management and sleeping mask updates. Let's have a centralized function to deal with all of this boring stuff: fd_leaving_poll(), and make all the pollers use it.
This commit is contained in:
parent
bdcd32598f
commit
058b2c1015
@ -79,6 +79,7 @@ ssize_t fd_write_frag_line(int fd, size_t maxlen, const struct ist pfx[], size_t
|
||||
void my_closefrom(int start);
|
||||
|
||||
int compute_poll_timeout(int next);
|
||||
void fd_leaving_poll(int wait_time, int status);
|
||||
|
||||
/* disable the specified poller */
|
||||
void disable_poller(const char *poller_name);
|
||||
|
@ -208,13 +208,7 @@ static void _do_poll(struct poller *p, int exp, int wake)
|
||||
break;
|
||||
} while (1);
|
||||
|
||||
clock_leaving_poll(wait_time, status);
|
||||
|
||||
thread_harmless_end();
|
||||
thread_idle_end();
|
||||
|
||||
if (sleeping_thread_mask & tid_bit)
|
||||
_HA_ATOMIC_AND(&sleeping_thread_mask, ~tid_bit);
|
||||
fd_leaving_poll(wait_time, status);
|
||||
|
||||
/* process polled events */
|
||||
|
||||
|
@ -202,13 +202,7 @@ static void _do_poll(struct poller *p, int exp, int wake)
|
||||
break;
|
||||
} while(1);
|
||||
|
||||
clock_leaving_poll(wait_time, nevlist);
|
||||
|
||||
thread_harmless_end();
|
||||
thread_idle_end();
|
||||
|
||||
if (sleeping_thread_mask & tid_bit)
|
||||
_HA_ATOMIC_AND(&sleeping_thread_mask, ~tid_bit);
|
||||
fd_leaving_poll(wait_time, nevlist);
|
||||
|
||||
if (nevlist > 0)
|
||||
activity[tid].poll_io++;
|
||||
|
@ -174,13 +174,7 @@ static void _do_poll(struct poller *p, int exp, int wake)
|
||||
break;
|
||||
} while (1);
|
||||
|
||||
clock_leaving_poll(wait_time, status);
|
||||
|
||||
thread_harmless_end();
|
||||
thread_idle_end();
|
||||
|
||||
if (sleeping_thread_mask & tid_bit)
|
||||
_HA_ATOMIC_AND(&sleeping_thread_mask, ~tid_bit);
|
||||
fd_leaving_poll(wait_time, status);
|
||||
|
||||
for (count = 0; count < status; count++) {
|
||||
unsigned int n = 0;
|
||||
|
@ -205,13 +205,8 @@ static void _do_poll(struct poller *p, int exp, int wake)
|
||||
clock_entering_poll();
|
||||
status = poll(poll_events, nbfd, wait_time);
|
||||
clock_update_date(wait_time, status);
|
||||
clock_leaving_poll(wait_time, status);
|
||||
|
||||
thread_harmless_end();
|
||||
thread_idle_end();
|
||||
|
||||
if (sleeping_thread_mask & tid_bit)
|
||||
_HA_ATOMIC_AND(&sleeping_thread_mask, ~tid_bit);
|
||||
fd_leaving_poll(wait_time, status);
|
||||
|
||||
if (status > 0)
|
||||
activity[tid].poll_io++;
|
||||
|
@ -180,13 +180,7 @@ static void _do_poll(struct poller *p, int exp, int wake)
|
||||
NULL,
|
||||
&delta);
|
||||
clock_update_date(delta_ms, status);
|
||||
clock_leaving_poll(delta_ms, status);
|
||||
|
||||
thread_harmless_end();
|
||||
thread_idle_end();
|
||||
|
||||
if (sleeping_thread_mask & tid_bit)
|
||||
_HA_ATOMIC_AND(&sleeping_thread_mask, ~tid_bit);
|
||||
fd_leaving_poll(delta_ms, status);
|
||||
|
||||
if (status <= 0)
|
||||
return;
|
||||
|
15
src/fd.c
15
src/fd.c
@ -759,6 +759,21 @@ int compute_poll_timeout(int next)
|
||||
return wait_time;
|
||||
}
|
||||
|
||||
/* Handle the return of the poller, which consists in calculating the idle
|
||||
* time, saving a few clocks, marking the thread harmful again etc. All that
|
||||
* is some boring stuff that all pollers have to do anyway.
|
||||
*/
|
||||
void fd_leaving_poll(int wait_time, int status)
|
||||
{
|
||||
clock_leaving_poll(wait_time, status);
|
||||
|
||||
thread_harmless_end();
|
||||
thread_idle_end();
|
||||
|
||||
if (sleeping_thread_mask & tid_bit)
|
||||
_HA_ATOMIC_AND(&sleeping_thread_mask, ~tid_bit);
|
||||
}
|
||||
|
||||
/* disable the specified poller */
|
||||
void disable_poller(const char *poller_name)
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user