[Sheepdog] [PATCH 2/3] sheep: handle CPG_EVENT_REQUEST even if CPG_EVENT_DELIVER exists
Yibin Shen
kkbaal at gmail.com
Tue Sep 13 13:54:04 CEST 2011
if a CPG_EVENT_CONCHG event occured in the time window between a
CPG_EVENT_DELIVER & CPG_EVENT_REQUEST event pair(for example, a vdi lookup
operation followed by a vdi meta object read operation)
cluster will hang forever for the meta object read event be blocked.
Yibin Shen
On Fri, Sep 2, 2011 at 12:37 AM, MORITA Kazutaka <
morita.kazutaka at lab.ntt.co.jp> wrote:
> This patch prevents a CPG_EVENT_DELIVER event from blocking VM I/Os.
>
> Signed-off-by: MORITA Kazutaka <morita.kazutaka at lab.ntt.co.jp>
> ---
> sheep/group.c | 4 +++-
> 1 files changed, 3 insertions(+), 1 deletions(-)
>
> diff --git a/sheep/group.c b/sheep/group.c
> index 6690125..ab253a6 100644
> --- a/sheep/group.c
> +++ b/sheep/group.c
> @@ -1487,7 +1487,9 @@ do_retry:
> list_for_each_entry_safe(cevent, n, &sys->cpg_event_siblings,
> cpg_event_list) {
> struct request *req = container_of(cevent, struct request,
> cev);
>
> - if (cevent->ctype != CPG_EVENT_REQUEST)
> + if (cevent->ctype == CPG_EVENT_DELIVER)
> + continue;
> + if (cevent->ctype == CPG_EVENT_CONCHG)
> break;
>
> list_del(&cevent->cpg_event_list);
> --
> 1.7.2.5
>
> --
> sheepdog mailing list
> sheepdog at lists.wpkg.org
> http://lists.wpkg.org/mailman/listinfo/sheepdog
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.wpkg.org/pipermail/sheepdog/attachments/20110913/0840a7ca/attachment-0003.html>
More information about the sheepdog
mailing list