Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754345AbbHXXKv (ORCPT ); Mon, 24 Aug 2015 19:10:51 -0400 Received: from mx1.redhat.com ([209.132.183.28]:50379 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751020AbbHXXKu (ORCPT ); Mon, 24 Aug 2015 19:10:50 -0400 Subject: Re: [PATCH v6 1/3] genalloc:support memory-allocation with bytes-alignment to genalloc To: Zhao Qiang , scottwood@freescale.com References: <1440408703-6113-1-git-send-email-qiang.zhao@freescale.com> Cc: linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, lauraa@codeaurora.org, X.xie@freescale.com, benh@kernel.crashing.org, leoli@freescale.com, paulus@samba.org From: Laura Abbott Message-ID: <55DBA477.5020608@redhat.com> Date: Mon, 24 Aug 2015 16:10:47 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.1.0 MIME-Version: 1.0 In-Reply-To: <1440408703-6113-1-git-send-email-qiang.zhao@freescale.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2035 Lines: 63 On 08/24/2015 02:31 AM, Zhao Qiang wrote: > Bytes alignment is required to manage some special RAM, > so add gen_pool_first_fit_align to genalloc, > meanwhile add gen_pool_alloc_data to pass data to > gen_pool_first_fit_align(modify gen_pool_alloc as a wrapper) > > Signed-off-by: Zhao Qiang > --- > Changes for v6: > - patches set v6 include a new patch because of using > - genalloc to manage QE MURAM, patch 0001 is the new > - patch, adding bytes alignment for allocation for use. > > include/linux/genalloc.h | 23 +++++++++++++++---- > lib/genalloc.c | 58 +++++++++++++++++++++++++++++++++++++++++++----- > 2 files changed, 72 insertions(+), 9 deletions(-) > > diff --git a/include/linux/genalloc.h b/include/linux/genalloc.h > index 1ccaab4..55da07e 100644 > --- a/include/linux/genalloc.h > +++ b/include/linux/genalloc.h > @@ -34,6 +34,7 @@ > > struct device; > struct device_node; > +struct gen_pool; > > /** > * Allocation callback function type definition > @@ -47,7 +48,7 @@ typedef unsigned long (*genpool_algo_t)(unsigned long *map, > unsigned long size, > unsigned long start, > unsigned int nr, > - void *data); > + void *data, struct gen_pool *pool); > > /* > * General purpose special memory pool descriptor. > @@ -73,6 +74,13 @@ struct gen_pool_chunk { > unsigned long bits[0]; /* bitmap for allocating memory chunk */ > }; > > +/* > + * gen_pool data descriptor for gen_pool_first_fit_align. > + */ > +struct genpool_data_align { > + int align; /* alignment by bytes for starting address */ > +}; > + (sorry for chiming in late, I've been traveling) Is there an advantage here to wrapping this in a structure instead of just passing a pointer to an align integer? Thanks, Laura -- 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/