All of lore.kernel.org
 help / color / mirror / Atom feed
From: Scott Wood <scottwood@freescale.com>
To: Zhao Qiang-B45475 <qiang.zhao@freescale.com>
Cc: "linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
	"linuxppc-dev@lists.ozlabs.org" <linuxppc-dev@lists.ozlabs.org>,
	"lauraa@codeaurora.org" <lauraa@codeaurora.org>,
	Xie Xiaobo-R63061 <X.Xie@freescale.com>,
	"benh@kernel.crashing.org" <benh@kernel.crashing.org>,
	Li Yang-Leo-R58472 <LeoLi@freescale.com>,
	"paulus@samba.org" <paulus@samba.org>
Subject: Re: [PATCH V7 1/3] genalloc:support memory-allocation with bytes-alignment to genalloc
Date: Tue, 1 Sep 2015 21:18:19 -0500	[thread overview]
Message-ID: <1441160299.4966.122.camel@freescale.com> (raw)
In-Reply-To: <SN1PR0301MB1550752EBCD1B8DECF06483A9B690@SN1PR0301MB1550.namprd03.prod.outlook.com>

On Tue, 2015-09-01 at 21:10 -0500, Zhao Qiang-B45475 wrote:
> On Wed, 2015-09-02 at 08:38AM +0800, Wood Scott-B07421 wrote:
> > -----Original Message-----
> > From: Wood Scott-B07421
> > Sent: Wednesday, September 02, 2015 8:30 AM
> > To: Zhao Qiang-B45475
> > Cc: linux-kernel@vger.kernel.org; linuxppc-dev@lists.ozlabs.org;
> > lauraa@codeaurora.org; Xie Xiaobo-R63061; benh@kernel.crashing.org; Li
> > Yang-Leo-R58472; paulus@samba.org
> > Subject: Re: [PATCH V7 1/3] genalloc:support memory-allocation with
> > bytes-alignment to genalloc
> > 
> > On Mon, 2015-08-31 at 16:58 +0800, 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 <qiang.zhao@freescale.com>
> > > ---
> > > 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.
> > > Changes for v7:
> > >       - cpm muram also need to use genalloc to manage, it has
> > >         a function to reserve a specific region of muram,
> > >         add offset to genpool_data for start addr to be allocated.
> > 
> > This seems to be describing more than just the changes in this patch.
> > What does also handling cpm have to do with this patch?  Are you adding
> > support for reserving a specific region in this patch?  I don't see it,
> > and in any case it should go in a different patch.
> 
> Yes, I added. The code below can support the function.
>       offset_bit = (alignment->offset + (1UL << order) - 1) >> order;
>       return bitmap_find_next_zero_area(map, size, start + offset_bit, nr,
>                         align_mask);
>
> CPM has an function cpm_muram_alloc_fixed, needing to allocate muram from a
> Specific offset. So I add the code and add offset to struct data.

I thought the offset was related to the previous discussion of checking for 
allocation failure.  Are you using it to implement alloc_fixed()?  If so, 
please don't.  Besides the awkward implementation (what does it logically 
have to do with gen_pool_first_fit_align?), it does not appear to be correct -
- what happens with multiple chunks?  What happens if part of the region the 
caller is trying to reserve is already taken?  Implement a proper function to 
reserve a fixed genalloc region.

> This patch is the first patch of this patch set, so I explain what changes 
> about
> Set v7 and why I add support for reserving a specific region in this patch.

If you want to provide commentary that covers the entire patchset, use a 
cover letter.

> > > +/*
> > > + *  gen_pool data descriptor for gen_pool_first_fit_align.
> > > + */
> > > +struct genpool_data_align {
> > > +     int align;              /* alignment by bytes for starting
> > address */
> > > +     unsigned long offset;   /* the offset of allocation start addr*/
> > > +};
> > 
> > The offset belongs on the caller side, not here.
> 
> So, how do I pass offset to gen_pool_alloc_data or pool->algo?

You don't.

-Scott

  reply	other threads:[~2015-09-02  2:18 UTC|newest]

Thread overview: 42+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-08-31  8:58 [PATCH V7 1/3] genalloc:support memory-allocation with bytes-alignment to genalloc Zhao Qiang
2015-08-31  8:58 ` [PATCH V7 2/3] qe_common: add qe_muram_ functions to manage muram Zhao Qiang
2015-09-02  0:34   ` Scott Wood
2015-09-02  2:22     ` Zhao Qiang
2015-09-02  2:22       ` Zhao Qiang
2015-09-02  2:30       ` Scott Wood
2015-09-02  2:32         ` Zhao Qiang
2015-09-02  2:32           ` Zhao Qiang
2015-09-06  6:37     ` Zhao Qiang
2015-09-06  6:37       ` Zhao Qiang
2015-09-09 16:38       ` Scott Wood
2015-09-10  2:34         ` Zhao Qiang
2015-09-10  2:34           ` Zhao Qiang
2015-09-10 22:09           ` Scott Wood
2015-09-11  1:59             ` Zhao Qiang
2015-09-11  1:59               ` Zhao Qiang
2015-09-11  2:05               ` Scott Wood
2015-08-31  8:58 ` [PATCH V7 3/3] QE: Move QE from arch/powerpc to drivers/soc Zhao Qiang
2015-09-02  0:30 ` [PATCH V7 1/3] genalloc:support memory-allocation with bytes-alignment to genalloc Scott Wood
2015-09-02  2:10   ` Zhao Qiang
2015-09-02  2:10     ` Zhao Qiang
2015-09-02  2:18     ` Scott Wood [this message]
2015-09-02  2:29       ` Zhao Qiang
2015-09-02  2:29         ` Zhao Qiang
2015-09-02  2:33         ` Scott Wood
2015-09-02  3:05           ` Zhao Qiang
2015-09-02  3:05             ` Zhao Qiang
2015-09-02  3:08             ` Scott Wood
2015-09-02  3:57               ` Zhao Qiang
2015-09-02  3:57                 ` Zhao Qiang
2015-09-02  4:51                 ` Scott Wood
2015-09-06  3:13       ` Zhao Qiang
2015-09-06  3:13         ` Zhao Qiang
2015-09-09 16:37         ` Scott Wood
2015-09-10  2:26           ` Zhao Qiang
2015-09-10  2:26             ` Zhao Qiang
2015-09-10 22:07             ` Scott Wood
2015-09-11  2:09               ` Zhao Qiang
2015-09-11  2:09                 ` Zhao Qiang
2015-09-11  2:15                 ` Scott Wood
2015-09-11  2:25                   ` Zhao Qiang
2015-09-11  2:25                     ` Zhao Qiang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1441160299.4966.122.camel@freescale.com \
    --to=scottwood@freescale.com \
    --cc=LeoLi@freescale.com \
    --cc=X.Xie@freescale.com \
    --cc=benh@kernel.crashing.org \
    --cc=lauraa@codeaurora.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linuxppc-dev@lists.ozlabs.org \
    --cc=paulus@samba.org \
    --cc=qiang.zhao@freescale.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.