From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757669AbXJCMMY (ORCPT ); Wed, 3 Oct 2007 08:12:24 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1755499AbXJCMMP (ORCPT ); Wed, 3 Oct 2007 08:12:15 -0400 Received: from ftp.linux-mips.org ([194.74.144.162]:38176 "EHLO ftp.linux-mips.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755253AbXJCMMO (ORCPT ); Wed, 3 Oct 2007 08:12:14 -0400 Date: Wed, 3 Oct 2007 13:12:11 +0100 From: Ralf Baechle To: Heiko Carstens Cc: Kyle McMartin , linux-arch@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [COMPAT] Add compat_merge64 helper Message-ID: <20071003121211.GA14628@linux-mips.org> References: <1191018832-18069-1-git-send-email-kyle@mcmartin.ca> <20070929094852.GA7715@osiris.boeblingen.de.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20070929094852.GA7715@osiris.boeblingen.de.ibm.com> User-Agent: Mutt/1.5.14 (2007-02-12) Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Sep 29, 2007 at 11:48:52AM +0200, Heiko Carstens wrote: > > +static inline u64 compat_merge64(u32 left, u32 right) > > +{ > > +#if defined(__BIG_ENDIAN) > > + return ((u64)left << 32) | right; > > +#else /* defined (__LITTLE_ENDIAN) */ > > Could you change that to an #elif please and #error out if none is defined? > Should safe us from subtle bugs caused by missing includes. This funny macro gets away without any extra headers or #ifdef messiness: #define merge_64(r1,r2) \ ({ \ union { \ int __words[2]; \ long long __dword; \ } __u = { \ .__words = { (r1), (r2) } \ }; \ \ __u.__dword; \ }) Thanks to gcc doing bogus sign and zero extensions it compiles into slightly larger code for MIPS but that may not be an issue on other architectures. Ralf