From 2e05a8c74210689557d326b4741ba028f4c63759 Mon Sep 17 00:00:00 2001 From: Thierry FOURNIER Date: Mon, 24 Nov 2014 14:49:56 +0100 Subject: [PATCH] MEDIUM: task: call session analyzers if the task is woken by a message. When a task used to receive a message from another one, its analysers were not called if there was no I/O activity. --- src/session.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/session.c b/src/session.c index ad659635d..31a5182c1 100644 --- a/src/session.c +++ b/src/session.c @@ -1939,7 +1939,8 @@ struct task *process_session(struct task *t) if (((s->req->flags & ~rqf_last) & CF_MASK_ANALYSER) || ((s->req->flags ^ rqf_last) & CF_MASK_STATIC) || s->si[0].state != rq_prod_last || - s->si[1].state != rq_cons_last) { + s->si[1].state != rq_cons_last || + s->task->state & TASK_WOKEN_MSG) { unsigned int flags = s->req->flags; if (s->req->prod->state >= SI_ST_EST) { @@ -2097,7 +2098,8 @@ struct task *process_session(struct task *t) if (((s->rep->flags & ~rpf_last) & CF_MASK_ANALYSER) || (s->rep->flags ^ rpf_last) & CF_MASK_STATIC || s->si[0].state != rp_cons_last || - s->si[1].state != rp_prod_last) { + s->si[1].state != rp_prod_last || + s->task->state & TASK_WOKEN_MSG) { unsigned int flags = s->rep->flags; if ((s->rep->flags & CF_MASK_ANALYSER) &&