From mboxrd@z Thu Jan 1 00:00:00 1970 From: Marcelo Tosatti Subject: Re: [PATCH 09/21] Introduce event-tap. Date: Mon, 29 Nov 2010 23:19:14 -0200 Message-ID: <20101130011914.GA9015@amt.cnet> References: <1290665220-26478-1-git-send-email-tamura.yoshiaki@lab.ntt.co.jp> <1290665220-26478-10-git-send-email-tamura.yoshiaki@lab.ntt.co.jp> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: kvm@vger.kernel.org, qemu-devel@nongnu.org, avi@redhat.com, anthony@codemonkey.ws, aliguori@us.ibm.com, dlaor@redhat.com, ananth@in.ibm.com, psuriset@linux.vnet.ibm.com, vatsa@linux.vnet.ibm.com, stefanha@linux.vnet.ibm.com, ohmura.kei@lab.ntt.co.jp To: Yoshiaki Tamura Return-path: Received: from mx1.redhat.com ([209.132.183.28]:1026 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755993Ab0K3BVF (ORCPT ); Mon, 29 Nov 2010 20:21:05 -0500 Content-Disposition: inline In-Reply-To: <1290665220-26478-10-git-send-email-tamura.yoshiaki@lab.ntt.co.jp> Sender: kvm-owner@vger.kernel.org List-ID: On Thu, Nov 25, 2010 at 03:06:48PM +0900, Yoshiaki Tamura wrote: > event-tap controls when to start FT transaction, and provides proxy > functions to called from net/block devices. While FT transaction, it > queues up net/block requests, and flush them when the transaction gets > completed. > > Signed-off-by: Yoshiaki Tamura > Signed-off-by: OHMURA Kei > +static void event_tap_alloc_blk_req(EventTapBlkReq *blk_req, > + BlockDriverState *bs, BlockRequest *reqs, > + int num_reqs, BlockDriverCompletionFunc *cb, > + void *opaque, bool is_multiwrite) > +{ > + int i; > + > + blk_req->num_reqs = num_reqs; > + blk_req->num_cbs = num_reqs; > + blk_req->device_name = qemu_strdup(bs->device_name); > + blk_req->is_multiwrite = is_multiwrite; > + > + for (i = 0; i < num_reqs; i++) { > + blk_req->reqs[i].sector = reqs[i].sector; > + blk_req->reqs[i].nb_sectors = reqs[i].nb_sectors; > + blk_req->reqs[i].qiov = reqs[i].qiov; > + blk_req->reqs[i].cb = cb; > + blk_req->reqs[i].opaque = opaque; > + blk_req->cb[i] = reqs[i].cb; > + blk_req->opaque[i] = reqs[i].opaque; > + } > +} bdrv_aio_flush should also be logged, so that guest initiated flush is respected on replay.