From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757336Ab0EAT3u (ORCPT ); Sat, 1 May 2010 15:29:50 -0400 Received: from mail.openrapids.net ([64.15.138.104]:58422 "EHLO blackscsi.openrapids.net" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1757063Ab0EAT3t (ORCPT ); Sat, 1 May 2010 15:29:49 -0400 Date: Sat, 1 May 2010 15:29:46 -0400 From: Mathieu Desnoyers To: Imre Deak , Russell King - ARM Linux , "linux-arm-kernel@lists.infradead.org" , Jamie Lokier , "rostedt@goodmis.org" , "mingo@elte.hu" , "linux-kernel@vger.kernel.org" , Andrew Morton , Alexander Shishkin Subject: Re: [PATCH] create generic alignment api (v5) Message-ID: <20100501192946.GA16987@Krystal> References: <20100501191411.GA16794@Krystal> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20100501191411.GA16794@Krystal> X-Editor: vi X-Info: http://www.efficios.com X-Operating-System: Linux/2.6.26-2-686 (i686) X-Uptime: 15:27:51 up 98 days, 22:05, 6 users, load average: 0.08, 0.02, 0.01 User-Agent: Mutt/1.5.18 (2008-05-17) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org * Mathieu Desnoyers (mathieu.desnoyers@efficios.com) wrote: > Rather than re-doing the "alignment on a type size" trick all over again at > different levels, import the "ltt_align" from LTTng into kernel.h and make this > available to everyone. Renaming to: Please disregard this post and see (v6) posted by Alexander Shishkin, which moves the alignment code to a new align.h. Thanks, Mathieui > > - object_align() > - object_align_floor() > - offset_align() > - offset_align_floor() > > Changelog since v4: > - add missing ( ) around parameters within object_align() and > object_align_floor(). > - More coding style cleanups to ALIGN() (checkpatch.pl is happy now). > > Changelog since v3: > - optimize object_align*() so fewer instructions are needed for alignment of > addresses known dynamically. Use the (already existing) "ALIGN()", and create > the "ALIGN_FLOOR()" macro. > - While we are there, let's clean up the ALIGN() macros wrt coding style. e.g. > missing parenthesis around the first use of the "x" parameter in ALIGN(). > > Changelog since v2: > - Fix object_align*(): should use object size alignment, not pointer alignment. > > Changelog since v1: > - Align on the object natural alignment > (rather than min(arch word alignment, natural alignment)) > > The advantage of separating the API in "object alignment" and "offset alignment" > is that it gives more freedom to play with offset alignment. Very useful to > implement a tracer ring-buffer alignment. (hint hint) > > Typical users will use "object alignment", but infrastructures like tracers > which need to perform alignment of statically known base+offsets will typically > use "offset alignment", because it allows to align with respect to a base rather > than to pass an absolute address. > > We use "sizeof(object)" rather than "__alignof__()" object because alignof > returns "recommended" object alignment for the architecture, which can be > sub-optimal on some architectures. By ensuring alignment on the object size, we > are sure to make the right choice. > > Signed-off-by: Mathieu Desnoyers > Acked-by: Alexander Shishkin > CC: Andrew Morton > CC: mingo@elte.hu > CC: Russell King - ARM Linux > CC: linux-arm-kernel@lists.infradead.org > CC: Imre Deak > CC: Jamie Lokier > CC: rostedt@goodmis.org > --- > include/linux/kernel.h | 45 +++++++++++++++++++++++++++++++++++++++++---- > 1 file changed, 41 insertions(+), 4 deletions(-) > > Index: linux-2.6-lttng/include/linux/kernel.h > =================================================================== > --- linux-2.6-lttng.orig/include/linux/kernel.h 2010-03-27 20:46:07.000000000 -0400 > +++ linux-2.6-lttng/include/linux/kernel.h 2010-03-28 20:06:27.000000000 -0400 > @@ -37,10 +37,47 @@ extern const char linux_proc_banner[]; > > #define STACK_MAGIC 0xdeadbeef > > -#define ALIGN(x,a) __ALIGN_MASK(x,(typeof(x))(a)-1) > -#define __ALIGN_MASK(x,mask) (((x)+(mask))&~(mask)) > -#define PTR_ALIGN(p, a) ((typeof(p))ALIGN((unsigned long)(p), (a))) > -#define IS_ALIGNED(x, a) (((x) & ((typeof(x))(a) - 1)) == 0) > +#define ALIGN(x, a) __ALIGN_MASK((x), (typeof(x)) (a) - 1) > +#define __ALIGN_MASK(x, mask) (((x) + (mask)) & ~(mask)) > +#define PTR_ALIGN(p, a) ((typeof(p)) ALIGN((unsigned long) (p), (a))) > +#define ALIGN_FLOOR(x, a) __ALIGN_FLOOR_MASK((x), (typeof(x)) (a) - 1) > +#define __ALIGN_FLOOR_MASK(x, mask) ((x) & ~(mask)) > +#define PTR_ALIGN_FLOOR(p, a) \ > + ((typeof(p)) ALIGN_FLOOR((unsigned long) (p), (a))) > +#define IS_ALIGNED(x, a) (((x) & ((typeof(x)) (a) - 1)) == 0) > + > +/* > + * Align pointer on natural object alignment. Object size must be power of two. > + */ > +#define object_align(obj) PTR_ALIGN((obj), sizeof(*(obj))) > +#define object_align_floor(obj) PTR_ALIGN_FLOOR((obj), sizeof(*(obj))) > + > +/** > + * offset_align - Calculate the offset needed to align an object on its natural > + * alignment towards higher addresses. > + * @align_drift: object offset from an "alignment"-aligned address. > + * @alignment: natural object alignment. Must be non-zero, power of 2. > + * > + * Returns the offset that must be added to align towards higher > + * addresses. > + */ > +static inline size_t offset_align(size_t align_drift, size_t alignment) > +{ > + return (alignment - align_drift) & (alignment - 1); > +} > + > +/** > + * offset_align_floor - Calculate the offset needed to align an object > + * on its natural alignment towards lower addresses. > + * @align_drift: object offset from an "alignment"-aligned address. > + * @alignment: natural object alignment. Must be non-zero, power of 2. > + * > + * Returns the offset that must be substracted to align towards lower addresses. > + */ > +static inline size_t offset_align_floor(size_t align_drift, size_t alignment) > +{ > + return (align_drift - alignment) & (alignment - 1); > +} > > #define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]) + __must_be_array(arr)) > > > -- > Mathieu Desnoyers > Operating System Efficiency R&D Consultant > EfficiOS Inc. > http://www.efficios.com -- Mathieu Desnoyers Operating System Efficiency R&D Consultant EfficiOS Inc. http://www.efficios.com