Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755024Ab0AUUtf (ORCPT ); Thu, 21 Jan 2010 15:49:35 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753423Ab0AUUtd (ORCPT ); Thu, 21 Jan 2010 15:49:33 -0500 Received: from nlpi157.sbcis.sbc.com ([207.115.36.171]:36277 "EHLO nlpi157.prodigy.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752613Ab0AUUtc (ORCPT ); Thu, 21 Jan 2010 15:49:32 -0500 Date: Thu, 21 Jan 2010 14:48:24 -0600 (CST) From: Christoph Lameter X-X-Sender: cl@router.home To: Yinghai Lu cc: Ingo Molnar , Thomas Gleixner , "H. Peter Anvin" , Andrew Morton , Jesse Barnes , Linus Torvalds , linux-kernel@vger.kernel.org, linux-pci@vger.kernel.org Subject: Re: [PATCH 22/36] move round_up/down to kernel.h In-Reply-To: <1264055303-15123-23-git-send-email-yinghai@kernel.org> Message-ID: References: <1264055303-15123-1-git-send-email-yinghai@kernel.org> <1264055303-15123-23-git-send-email-yinghai@kernel.org> User-Agent: Alpine 2.00 (DEB 1167 2008-08-23) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1066 Lines: 27 On Wed, 20 Jan 2010, Yinghai Lu wrote: > + * This looks more complex than it should be. But we need to > + * get the type for the ~ right in round_down (it needs to be > + * as wide as the result!), and we want to evaluate the macro > + * arguments just once each. > + */ > +#define __round_mask(x,y) ((__typeof__(x))((y)-1)) > +#define round_up(x,y) ((((x)-1) | __round_mask(x,y))+1) > +#define round_down(x,y) ((x) & ~__round_mask(x,y)) > + > #define FIELD_SIZEOF(t, f) (sizeof(((t*)0)->f)) > #define DIV_ROUND_UP(n,d) (((n) + (d) - 1) / (d)) > #define roundup(x, y) ((((x) + ((y) - 1)) / (y)) * (y)) So we are back to the earlier version. Two functions doing the same thing. round_up and roundup. If they are different(are they really used that way?) then they should have names that emphasize the difference. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/