m68k/amiga: Chip RAM - Always allocate from the start of memory
authorGeert Uytterhoeven <geert@linux-m68k.org>
Sun, 24 Apr 2011 21:19:05 +0000 (23:19 +0200)
committerGeert Uytterhoeven <geert@linux-m68k.org>
Sat, 30 Jul 2011 19:21:38 +0000 (21:21 +0200)
As of commit 5df1abdbd37af2ae317a1c5b5944173284dc55d6 ('m68k/amiga: Fix
"debug=mem"'), "debug=mem" no longer uses amiga_chip_alloc_res(), so we
can remove the hack to prefer memory at the safe end.

This allows to simplify the code and make amiga_chip_alloc() just call
amiga_chip_alloc_res() internally.

Signed-off-by: Geert Uytterhoeven <geert@linux-m68k.org>
arch/m68k/amiga/chipram.c

index 9005fa07f2e213ec9897504fa6731c41b2c751c3..e5a8dbc9abafbe8b41918d3bc7750c6e496667bd 100644 (file)
@@ -43,24 +43,20 @@ void __init amiga_chip_init(void)
 void *amiga_chip_alloc(unsigned long size, const char *name)
 {
        struct resource *res;
+       void *p;
 
-       /* round up */
-       size = PAGE_ALIGN(size);
-
-       pr_debug("amiga_chip_alloc: allocate %lu bytes\n", size);
        res = kzalloc(sizeof(struct resource), GFP_KERNEL);
        if (!res)
                return NULL;
-       res->name = name;
 
-       if (allocate_resource(&chipram_res, res, size, 0, UINT_MAX, PAGE_SIZE,
-                             NULL, NULL) < 0) {
+       res->name = name;
+       p = amiga_chip_alloc_res(size, res);
+       if (!p) {
                kfree(res);
                return NULL;
        }
-       chipavail -= size;
-       pr_debug("amiga_chip_alloc: returning %pR\n", res);
-       return (void *)ZTWO_VADDR(res->start);
+
+       return p;
 }
 EXPORT_SYMBOL(amiga_chip_alloc);
 
@@ -72,23 +68,22 @@ EXPORT_SYMBOL(amiga_chip_alloc);
         *  those drivers must not free that Chip RAM afterwards.
         */
 
-void * __init amiga_chip_alloc_res(unsigned long size, struct resource *res)
+void *amiga_chip_alloc_res(unsigned long size, struct resource *res)
 {
-       unsigned long start;
+       int error;
 
        /* round up */
        size = PAGE_ALIGN(size);
-       /* dmesg into chipmem prefers memory at the safe end */
-       start = CHIP_PHYSADDR + chipavail - size;
 
        pr_debug("amiga_chip_alloc_res: allocate %lu bytes\n", size);
-       if (allocate_resource(&chipram_res, res, size, start, UINT_MAX,
-                             PAGE_SIZE, NULL, NULL) < 0) {
-               pr_err("amiga_chip_alloc_res: first alloc failed!\n");
-               if (allocate_resource(&chipram_res, res, size, 0, UINT_MAX,
-                                     PAGE_SIZE, NULL, NULL) < 0)
-                       return NULL;
+       error = allocate_resource(&chipram_res, res, size, 0, UINT_MAX,
+                                 PAGE_SIZE, NULL, NULL);
+       if (error < 0) {
+               pr_err("amiga_chip_alloc_res: allocate_resource() failed %d!\n",
+                      error);
+               return NULL;
        }
+
        chipavail -= size;
        pr_debug("amiga_chip_alloc_res: returning %pR\n", res);
        return (void *)ZTWO_VADDR(res->start);