From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:58752) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1UKQu4-00077P-Mp for qemu-devel@nongnu.org; Tue, 26 Mar 2013 06:14:55 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1UKQtz-0002Bx-0a for qemu-devel@nongnu.org; Tue, 26 Mar 2013 06:14:52 -0400 Received: from mx1.redhat.com ([209.132.183.28]:47496) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1UKQty-0002Bb-PV for qemu-devel@nongnu.org; Tue, 26 Mar 2013 06:14:46 -0400 Message-ID: <515174ED.9020407@redhat.com> Date: Tue, 26 Mar 2013 11:14:05 +0100 From: Paolo Bonzini MIME-Version: 1.0 References: <1364291919-19563-1-git-send-email-pl@kamp.de> <1364291919-19563-3-git-send-email-pl@kamp.de> In-Reply-To: <1364291919-19563-3-git-send-email-pl@kamp.de> Content-Type: text/plain; charset=ISO-8859-15 Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCHv5 02/10] add a zero splat vector to qemu-common.h List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Peter Lieven Cc: Orit Wasserman , Stefan Hajnoczi , qemu-devel@nongnu.org, quintela@redhat.com Il 26/03/2013 10:58, Peter Lieven ha scritto: > Signed-off-by: Peter Lieven > --- > include/qemu-common.h | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/include/qemu-common.h b/include/qemu-common.h > index d7ad3a7..9022646 100644 > --- a/include/qemu-common.h > +++ b/include/qemu-common.h > @@ -453,6 +453,7 @@ void hexdump(const char *buf, FILE *fp, const char *prefix, size_t size); > #include > #define VECTYPE vector unsigned char > #define SPLAT(p) vec_splat(vec_ld(0, p), 0) > +#define ZERO_SPLAT vec_splat(vec_ld(0, 0), 0) > #define ALL_EQ(v1, v2) vec_all_eq(v1, v2) > /* altivec.h may redefine the bool macro as vector type. > * Reset it to POSIX semantics. */ > @@ -462,10 +463,12 @@ void hexdump(const char *buf, FILE *fp, const char *prefix, size_t size); > #include > #define VECTYPE __m128i > #define SPLAT(p) _mm_set1_epi8(*(p)) > +#define ZERO_SPLAT _mm_setzero_si128() > #define ALL_EQ(v1, v2) (_mm_movemask_epi8(_mm_cmpeq_epi8(v1, v2)) == 0xFFFF) > #else > #define VECTYPE unsigned long > #define SPLAT(p) (*(p) * (~0UL / 255)) > +#define ZERO_SPLAT 0x0UL > #define ALL_EQ(v1, v2) ((v1) == (v2)) > #endif C trivia of the day: this can be written simply as (VECTYPE) {0} Yes, it works even with unsigned long. :) It is a C99 compound literal. Paolo