From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([140.186.70.92]:32928) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Rq1LQ-0001xW-Br for qemu-devel@nongnu.org; Wed, 25 Jan 2012 06:49:00 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1Rq1LK-00056w-AE for qemu-devel@nongnu.org; Wed, 25 Jan 2012 06:48:52 -0500 Received: from mx1.redhat.com ([209.132.183.28]:39745) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Rq1LK-00056s-3Y for qemu-devel@nongnu.org; Wed, 25 Jan 2012 06:48:46 -0500 Message-ID: <4F1FEC18.5040804@redhat.com> Date: Wed, 25 Jan 2012 13:48:40 +0200 From: Avi Kivity MIME-Version: 1.0 References: <1327490809-21393-1-git-send-email-owasserm@redhat.com> <1327490809-21393-3-git-send-email-owasserm@redhat.com> In-Reply-To: <1327490809-21393-3-git-send-email-owasserm@redhat.com> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCH v6 02/11] Add uleb encoding/decoding functions List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Orit Wasserman Cc: blauwirbel@gmail.com, stefanha@gmail.com, qemu-devel@nongnu.org, quintela@redhat.com On 01/25/2012 01:26 PM, Orit Wasserman wrote: > Implement Unsigned Little Endian Base 128. > > > +/* ULEB128 */ > +int uleb128_encode_small(uint8_t *out, uint32_t n); > +int uleb128_decode_small(const uint8 *in, uint32_t *n); > + > #endif > diff --git a/savevm.c b/savevm.c > index 80be1ff..304db31 100644 > --- a/savevm.c > +++ b/savevm.c > @@ -2297,3 +2297,29 @@ void vmstate_register_ram_global(MemoryRegion *mr) > { > vmstate_register_ram(mr, NULL); > } > + > +/* ULEB128 */ > +int uleb128_encode_small(uint8_t *out, uint32_t n) > +{ assert(n <= 0x3fff); > + if (n < 0x80) { > + *out++ = n; > + return 1; > + } else { > + *out++ = (n & 0x7f) | 0x80; > + *out++ = n >> 7; return 2? > + } > + return 0; > +} > + > +int uleb128_decode_small(const uint8 *in, uint32_t *n) > +{ > + if (!(*in & 0x80)) { > + *n = *in++; > + return 1; > + } else { > + *n = *in++ & 0x7f; assert(!(*in & 0x80)); > + *n |= *in++ << 7; > + return 0; return 2? > + } > +} > + -- error compiling committee.c: too many arguments to function