From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([140.186.70.92]:55380) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1QdgVa-0005B6-R1 for qemu-devel@nongnu.org; Mon, 04 Jul 2011 06:36:07 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1QdgVZ-0004qe-Dl for qemu-devel@nongnu.org; Mon, 04 Jul 2011 06:36:06 -0400 Received: from mx1.redhat.com ([209.132.183.28]:1529) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1QdgVY-0004qQ-Ti for qemu-devel@nongnu.org; Mon, 04 Jul 2011 06:36:05 -0400 Message-ID: <4E11983E.4040608@redhat.com> Date: Mon, 04 Jul 2011 12:38:54 +0200 From: Kevin Wolf MIME-Version: 1.0 References: <1309705612-27079-1-git-send-email-famcool@gmail.com> <1309705612-27079-4-git-send-email-famcool@gmail.com> In-Reply-To: <1309705612-27079-4-git-send-email-famcool@gmail.com> Content-Type: text/plain; charset=ISO-8859-15 Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCH v7 03/12] VMDK: probe for monolithicFlat images List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Fam Zheng Cc: stefanha@gmail.com, qemu-devel@nongnu.org, hch@lst.de Am 03.07.2011 17:06, schrieb Fam Zheng: > Probe as the same behavior as VMware does. > Recognize image as monolithicFlat descriptor file when the file is text > and the first effective line (not '#' leaded comment or space line) is > either 'version=1' or 'version=2'. No space or upper case charactors > accepted. > > Signed-off-by: Fam Zheng > --- > block/vmdk.c | 44 ++++++++++++++++++++++++++++++++++++++++++-- > 1 files changed, 42 insertions(+), 2 deletions(-) > > diff --git a/block/vmdk.c b/block/vmdk.c > index 03a4619..05a58db 100644 > --- a/block/vmdk.c > +++ b/block/vmdk.c > @@ -103,10 +103,50 @@ static int vmdk_probe(const uint8_t *buf, int buf_size, const char *filename) > return 0; > magic = be32_to_cpu(*(uint32_t *)buf); > if (magic == VMDK3_MAGIC || > - magic == VMDK4_MAGIC) > + magic == VMDK4_MAGIC) { > return 100; > - else > + } else { > + const char *p = (const char *)buf; > + const char *end = p + buf_size; > + while (p < end) { > + if (*p == '#') { > + /* skip comment line */ > + while (p < end && *p != '\n') { > + p++; > + } > + p++; > + continue; > + } > + if (*p == ' ') { > + while (p < end && *p == ' ') { > + p++; > + } > + /* skip '\r' if windows line endings used. */ > + if (p < end && *p == '\r') { > + p++; > + } > + /* only accept blank lines before 'version=' line */ > + if (p == end || *p != '\n') { > + return 0; > + } > + p++; > + continue; > + } > + if (end - p >= strlen("version=X\n")) { > + if (strncmp("version=1\n", p, strlen("version=1\n")) == 0 || > + strncmp("version=2\n", p, strlen("version=2\n")) == 0) { > + return 100; > + } > + } > + if (end - p >= strlen("version=X\r\n")) { > + if (strncmp("version=1\r\n", p, strlen("version=1\r\n")) == 0 || > + strncmp("version=2\r\n", p, strlen("version=2\r\n")) == 0) { > + return 100; > + } > + } I think you may want to insert something right here. :-) This code (actually v6, but it doesn't seem to have changed) gives my an endless loop in vmdk_probe when trying to open a qcow2 image. So "something" might be p++ or probably just return 0; Kevin > + } > return 0; > + } > } > > #define CHECK_CID 1