* [PATCH] NOMMU: Rename PowerPC's struct vm_region
@ 2008-12-11 12:53 David Howells
2008-12-11 14:37 ` Josh Boyer
` (2 more replies)
0 siblings, 3 replies; 4+ messages in thread
From: David Howells @ 2008-12-11 12:53 UTC (permalink / raw)
To: linuxppc-dev
Rename PowerPC's struct vm_region so that I can introduce my own global version
for NOMMU. It's feasible that the PowerPC version may wish to use my global
one instead.
The NOMMU vm_region struct defines areas of the physical memory map that are
under mmap. This may include chunks of RAM or regions of memory mapped
devices, such as flash. It is also used to retain copies of file content so
that shareable private memory mappings of files can be made. As such, it may
be compatible with what is described in the banner comment for PowerPC's
vm_region struct.
Signed-off-by: David Howells <dhowells@redhat.com>
---
arch/powerpc/lib/dma-noncoherent.c | 24 ++++++++++++------------
1 files changed, 12 insertions(+), 12 deletions(-)
diff --git a/arch/powerpc/lib/dma-noncoherent.c b/arch/powerpc/lib/dma-noncoherent.c
index 31734c0..a55c6ca 100644
--- a/arch/powerpc/lib/dma-noncoherent.c
+++ b/arch/powerpc/lib/dma-noncoherent.c
@@ -77,26 +77,26 @@ static DEFINE_SPINLOCK(consistent_lock);
* the amount of RAM found at boot time.) I would imagine that get_vm_area()
* would have to initialise this each time prior to calling vm_region_alloc().
*/
-struct vm_region {
+struct ppc_vm_region {
struct list_head vm_list;
unsigned long vm_start;
unsigned long vm_end;
};
-static struct vm_region consistent_head = {
+static struct ppc_vm_region consistent_head = {
.vm_list = LIST_HEAD_INIT(consistent_head.vm_list),
.vm_start = CONSISTENT_BASE,
.vm_end = CONSISTENT_END,
};
-static struct vm_region *
-vm_region_alloc(struct vm_region *head, size_t size, gfp_t gfp)
+static struct ppc_vm_region *
+ppc_vm_region_alloc(struct ppc_vm_region *head, size_t size, gfp_t gfp)
{
unsigned long addr = head->vm_start, end = head->vm_end - size;
unsigned long flags;
- struct vm_region *c, *new;
+ struct ppc_vm_region *c, *new;
- new = kmalloc(sizeof(struct vm_region), gfp);
+ new = kmalloc(sizeof(struct ppc_vm_region), gfp);
if (!new)
goto out;
@@ -130,9 +130,9 @@ vm_region_alloc(struct vm_region *head, size_t size, gfp_t gfp)
return NULL;
}
-static struct vm_region *vm_region_find(struct vm_region *head, unsigned long addr)
+static struct ppc_vm_region *ppc_vm_region_find(struct ppc_vm_region *head, unsigned long addr)
{
- struct vm_region *c;
+ struct ppc_vm_region *c;
list_for_each_entry(c, &head->vm_list, vm_list) {
if (c->vm_start == addr)
@@ -151,7 +151,7 @@ void *
__dma_alloc_coherent(size_t size, dma_addr_t *handle, gfp_t gfp)
{
struct page *page;
- struct vm_region *c;
+ struct ppc_vm_region *c;
unsigned long order;
u64 mask = 0x00ffffff, limit; /* ISA default */
@@ -191,7 +191,7 @@ __dma_alloc_coherent(size_t size, dma_addr_t *handle, gfp_t gfp)
/*
* Allocate a virtual address in the consistent mapping region.
*/
- c = vm_region_alloc(&consistent_head, size,
+ c = ppc_vm_region_alloc(&consistent_head, size,
gfp & ~(__GFP_DMA | __GFP_HIGHMEM));
if (c) {
unsigned long vaddr = c->vm_start;
@@ -239,7 +239,7 @@ EXPORT_SYMBOL(__dma_alloc_coherent);
*/
void __dma_free_coherent(size_t size, void *vaddr)
{
- struct vm_region *c;
+ struct ppc_vm_region *c;
unsigned long flags, addr;
pte_t *ptep;
@@ -247,7 +247,7 @@ void __dma_free_coherent(size_t size, void *vaddr)
spin_lock_irqsave(&consistent_lock, flags);
- c = vm_region_find(&consistent_head, (unsigned long)vaddr);
+ c = ppc_vm_region_find(&consistent_head, (unsigned long)vaddr);
if (!c)
goto no_area;
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH] NOMMU: Rename PowerPC's struct vm_region
2008-12-11 12:53 [PATCH] NOMMU: Rename PowerPC's struct vm_region David Howells
@ 2008-12-11 14:37 ` Josh Boyer
2008-12-11 14:54 ` David Howells
2008-12-12 10:15 ` Benjamin Herrenschmidt
2 siblings, 0 replies; 4+ messages in thread
From: Josh Boyer @ 2008-12-11 14:37 UTC (permalink / raw)
To: David Howells; +Cc: linuxppc-dev
On Thu, 11 Dec 2008 12:53:54 +0000
David Howells <dhowells@redhat.com> wrote:
> Rename PowerPC's struct vm_region so that I can introduce my own global version
> for NOMMU. It's feasible that the PowerPC version may wish to use my global
> one instead.
>
> The NOMMU vm_region struct defines areas of the physical memory map that are
> under mmap. This may include chunks of RAM or regions of memory mapped
> devices, such as flash. It is also used to retain copies of file content so
> that shareable private memory mappings of files can be made. As such, it may
> be compatible with what is described in the banner comment for PowerPC's
> vm_region struct.
>
> Signed-off-by: David Howells <dhowells@redhat.com>
> ---
>
> arch/powerpc/lib/dma-noncoherent.c | 24 ++++++++++++------------
> 1 files changed, 12 insertions(+), 12 deletions(-)
>
>
> diff --git a/arch/powerpc/lib/dma-noncoherent.c b/arch/powerpc/lib/dma-noncoherent.c
> index 31734c0..a55c6ca 100644
> --- a/arch/powerpc/lib/dma-noncoherent.c
> +++ b/arch/powerpc/lib/dma-noncoherent.c
> @@ -77,26 +77,26 @@ static DEFINE_SPINLOCK(consistent_lock);
> * the amount of RAM found at boot time.) I would imagine that get_vm_area()
> * would have to initialise this each time prior to calling vm_region_alloc().
> */
> -struct vm_region {
> +struct ppc_vm_region {
> struct list_head vm_list;
> unsigned long vm_start;
> unsigned long vm_end;
> };
>
> -static struct vm_region consistent_head = {
> +static struct ppc_vm_region consistent_head = {
> .vm_list = LIST_HEAD_INIT(consistent_head.vm_list),
> .vm_start = CONSISTENT_BASE,
> .vm_end = CONSISTENT_END,
> };
>
> -static struct vm_region *
> -vm_region_alloc(struct vm_region *head, size_t size, gfp_t gfp)
> +static struct ppc_vm_region *
> +ppc_vm_region_alloc(struct ppc_vm_region *head, size_t size, gfp_t gfp)
Is there a reason you renamed all the function names as well when they
are static?
josh
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] NOMMU: Rename PowerPC's struct vm_region
2008-12-11 12:53 [PATCH] NOMMU: Rename PowerPC's struct vm_region David Howells
2008-12-11 14:37 ` Josh Boyer
@ 2008-12-11 14:54 ` David Howells
2008-12-12 10:15 ` Benjamin Herrenschmidt
2 siblings, 0 replies; 4+ messages in thread
From: David Howells @ 2008-12-11 14:54 UTC (permalink / raw)
To: Josh Boyer; +Cc: linuxppc-dev
Josh Boyer <jwboyer@linux.vnet.ibm.com> wrote:
> Is there a reason you renamed all the function names as well when they
> are static?
Well, static functions can still conflict with a function of the same name
that's declared globally in a header file, but mainly because M-x
replace-string doesn't differentiate.
David
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH] NOMMU: Rename PowerPC's struct vm_region
2008-12-11 12:53 [PATCH] NOMMU: Rename PowerPC's struct vm_region David Howells
2008-12-11 14:37 ` Josh Boyer
2008-12-11 14:54 ` David Howells
@ 2008-12-12 10:15 ` Benjamin Herrenschmidt
2 siblings, 0 replies; 4+ messages in thread
From: Benjamin Herrenschmidt @ 2008-12-12 10:15 UTC (permalink / raw)
To: David Howells; +Cc: linuxppc-dev
On Thu, 2008-12-11 at 12:53 +0000, David Howells wrote:
> Rename PowerPC's struct vm_region so that I can introduce my own global version
> for NOMMU. It's feasible that the PowerPC version may wish to use my global
> one instead.
>
> The NOMMU vm_region struct defines areas of the physical memory map that are
> under mmap. This may include chunks of RAM or regions of memory mapped
> devices, such as flash. It is also used to retain copies of file content so
> that shareable private memory mappings of files can be made. As such, it may
> be compatible with what is described in the banner comment for PowerPC's
> vm_region struct.
Hrm... that whole dma-noncoherent stuff still eludes me as to why it
uses it's own region allocator instead of the vmalloc one .. since you
can use the later with explicit boundaries.
Cheers,
Ben.
> Signed-off-by: David Howells <dhowells@redhat.com>
> ---
>
> arch/powerpc/lib/dma-noncoherent.c | 24 ++++++++++++------------
> 1 files changed, 12 insertions(+), 12 deletions(-)
>
>
> diff --git a/arch/powerpc/lib/dma-noncoherent.c b/arch/powerpc/lib/dma-noncoherent.c
> index 31734c0..a55c6ca 100644
> --- a/arch/powerpc/lib/dma-noncoherent.c
> +++ b/arch/powerpc/lib/dma-noncoherent.c
> @@ -77,26 +77,26 @@ static DEFINE_SPINLOCK(consistent_lock);
> * the amount of RAM found at boot time.) I would imagine that get_vm_area()
> * would have to initialise this each time prior to calling vm_region_alloc().
> */
> -struct vm_region {
> +struct ppc_vm_region {
> struct list_head vm_list;
> unsigned long vm_start;
> unsigned long vm_end;
> };
>
> -static struct vm_region consistent_head = {
> +static struct ppc_vm_region consistent_head = {
> .vm_list = LIST_HEAD_INIT(consistent_head.vm_list),
> .vm_start = CONSISTENT_BASE,
> .vm_end = CONSISTENT_END,
> };
>
> -static struct vm_region *
> -vm_region_alloc(struct vm_region *head, size_t size, gfp_t gfp)
> +static struct ppc_vm_region *
> +ppc_vm_region_alloc(struct ppc_vm_region *head, size_t size, gfp_t gfp)
> {
> unsigned long addr = head->vm_start, end = head->vm_end - size;
> unsigned long flags;
> - struct vm_region *c, *new;
> + struct ppc_vm_region *c, *new;
>
> - new = kmalloc(sizeof(struct vm_region), gfp);
> + new = kmalloc(sizeof(struct ppc_vm_region), gfp);
> if (!new)
> goto out;
>
> @@ -130,9 +130,9 @@ vm_region_alloc(struct vm_region *head, size_t size, gfp_t gfp)
> return NULL;
> }
>
> -static struct vm_region *vm_region_find(struct vm_region *head, unsigned long addr)
> +static struct ppc_vm_region *ppc_vm_region_find(struct ppc_vm_region *head, unsigned long addr)
> {
> - struct vm_region *c;
> + struct ppc_vm_region *c;
>
> list_for_each_entry(c, &head->vm_list, vm_list) {
> if (c->vm_start == addr)
> @@ -151,7 +151,7 @@ void *
> __dma_alloc_coherent(size_t size, dma_addr_t *handle, gfp_t gfp)
> {
> struct page *page;
> - struct vm_region *c;
> + struct ppc_vm_region *c;
> unsigned long order;
> u64 mask = 0x00ffffff, limit; /* ISA default */
>
> @@ -191,7 +191,7 @@ __dma_alloc_coherent(size_t size, dma_addr_t *handle, gfp_t gfp)
> /*
> * Allocate a virtual address in the consistent mapping region.
> */
> - c = vm_region_alloc(&consistent_head, size,
> + c = ppc_vm_region_alloc(&consistent_head, size,
> gfp & ~(__GFP_DMA | __GFP_HIGHMEM));
> if (c) {
> unsigned long vaddr = c->vm_start;
> @@ -239,7 +239,7 @@ EXPORT_SYMBOL(__dma_alloc_coherent);
> */
> void __dma_free_coherent(size_t size, void *vaddr)
> {
> - struct vm_region *c;
> + struct ppc_vm_region *c;
> unsigned long flags, addr;
> pte_t *ptep;
>
> @@ -247,7 +247,7 @@ void __dma_free_coherent(size_t size, void *vaddr)
>
> spin_lock_irqsave(&consistent_lock, flags);
>
> - c = vm_region_find(&consistent_head, (unsigned long)vaddr);
> + c = ppc_vm_region_find(&consistent_head, (unsigned long)vaddr);
> if (!c)
> goto no_area;
>
>
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@ozlabs.org
> https://ozlabs.org/mailman/listinfo/linuxppc-dev
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2008-12-12 10:15 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-12-11 12:53 [PATCH] NOMMU: Rename PowerPC's struct vm_region David Howells
2008-12-11 14:37 ` Josh Boyer
2008-12-11 14:54 ` David Howells
2008-12-12 10:15 ` Benjamin Herrenschmidt
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).