From 06b98ae56795cb840a98877542fc37d767655186 Mon Sep 17 00:00:00 2001 From: Geert Uytterhoeven Date: Sat, 7 May 2011 20:56:00 +0200 Subject: [PATCH] --- yaml --- r: 261847 b: refs/heads/master c: b7785e954348465e1926d9c10ff3e49c207d4ec6 h: refs/heads/master i: 261845: 4bd41bf41327b857a313485a7464f46099603001 261843: d8ad55c6de4cfdc1656922e107805942b66de8d3 261839: a1d6fd5e30fa1287516b7953c6c040a914de71f3 v: v3 --- [refs] | 2 +- trunk/arch/m68k/amiga/chipram.c | 22 +++++++++++----------- 2 files changed, 12 insertions(+), 12 deletions(-) diff --git a/[refs] b/[refs] index 9f9a3526efa0..abf62c825fce 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 1c388919d89ca35741e9c4d3255adf87f76f0c06 +refs/heads/master: b7785e954348465e1926d9c10ff3e49c207d4ec6 diff --git a/trunk/arch/m68k/amiga/chipram.c b/trunk/arch/m68k/amiga/chipram.c index 4790f77cbd48..99449fbf9a72 100644 --- a/trunk/arch/m68k/amiga/chipram.c +++ b/trunk/arch/m68k/amiga/chipram.c @@ -93,21 +93,21 @@ void *amiga_chip_alloc_res(unsigned long size, struct resource *res) void amiga_chip_free(void *ptr) { unsigned long start = ZTWO_PADDR(ptr); - struct resource **p, *res; + struct resource *res; unsigned long size; - for (p = &chipram_res.child; (res = *p); p = &res->sibling) { - if (res->start != start) - continue; - *p = res->sibling; - size = resource_size(res); - pr_debug("amiga_chip_free: free %lu bytes at %p\n", size, ptr); - atomic_add(size, &chipavail); - kfree(res); + res = lookup_resource(&chipram_res, start); + if (!res) { + pr_err("amiga_chip_free: trying to free nonexistent region at " + "%p\n", ptr); return; } - pr_err("amiga_chip_free: trying to free nonexistent region at %p\n", - ptr); + + size = resource_size(res); + pr_debug("amiga_chip_free: free %lu bytes at %p\n", size, ptr); + atomic_add(size, &chipavail); + release_resource(res); + kfree(res); } EXPORT_SYMBOL(amiga_chip_free);