From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:38478) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1VXvAa-0004hL-Uc for qemu-devel@nongnu.org; Sun, 20 Oct 2013 11:44:02 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1VXvAU-0003fv-Ux for qemu-devel@nongnu.org; Sun, 20 Oct 2013 11:43:56 -0400 Received: from ssl.dlhnet.de ([91.198.192.8]:40544 helo=ssl.dlh.net) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1VXvAU-0003f8-Oi for qemu-devel@nongnu.org; Sun, 20 Oct 2013 11:43:50 -0400 From: Peter Lieven Date: Sun, 20 Oct 2013 17:43:01 +0200 Message-Id: <1382283791-11181-8-git-send-email-pl@kamp.de> In-Reply-To: <1382283791-11181-1-git-send-email-pl@kamp.de> References: <1382283791-11181-1-git-send-email-pl@kamp.de> Subject: [Qemu-devel] [PATCHv5 07/17] block: add BlockLimits structure to BlockDriverState List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: Kevin Wolf , Stefan Hajnoczi , Peter Lieven , ronniesahlberg@gmail.com, pbonzini@redhat.com this patch adds BlockLimits which introduces discard and write_zeroes limits and alignment information to the BlockDriverState. Signed-off-by: Peter Lieven --- include/block/block_int.h | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/include/block/block_int.h b/include/block/block_int.h index 9bbaa29..33be247 100644 --- a/include/block/block_int.h +++ b/include/block/block_int.h @@ -227,6 +227,20 @@ struct BlockDriver { QLIST_ENTRY(BlockDriver) list; }; +typedef struct BlockLimits { + /* maximum number of sectors that can be discarded at once */ + int max_discard; + + /* optimal alignment for discard requests in sectors */ + int64_t discard_alignment; + + /* maximum number of sectors that can zeroized at once */ + int max_write_zeroes; + + /* optimal alignment for write zeroes requests in sectors */ + int64_t write_zeroes_alignment; +} BlockLimits; + /* * Note: the function bdrv_append() copies and swaps contents of * BlockDriverStates, so if you add new fields to this struct, please @@ -280,6 +294,9 @@ struct BlockDriverState { uint64_t total_time_ns[BDRV_MAX_IOTYPE]; uint64_t wr_highest_sector; + /* I/O Limits */ + BlockLimits bl; + /* Whether the disk can expand beyond total_sectors */ int growable; -- 1.7.9.5