From patchwork Sat May 21 19:39:15 2011 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Geert Uytterhoeven X-Patchwork-Id: 96705 X-Patchwork-Delegate: davem@davemloft.net Return-Path: X-Original-To: patchwork-incoming@ozlabs.org Delivered-To: patchwork-incoming@ozlabs.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 5E97AB71B0 for ; Sun, 22 May 2011 05:39:40 +1000 (EST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757317Ab1EUTjc (ORCPT ); Sat, 21 May 2011 15:39:32 -0400 Received: from brigitte.telenet-ops.be ([195.130.137.66]:41895 "EHLO brigitte.telenet-ops.be" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1757293Ab1EUTj3 (ORCPT ); Sat, 21 May 2011 15:39:29 -0400 Received: from ayla.of.borg ([84.193.80.148]) by brigitte.telenet-ops.be with bizsmtp id mKfT1g0053C005g0GKfThe; Sat, 21 May 2011 21:39:27 +0200 Received: from geert by ayla.of.borg with local (Exim 4.71) (envelope-from ) id 1QNs1H-0008L1-F6; Sat, 21 May 2011 21:39:27 +0200 From: Geert Uytterhoeven To: linux-kernel@vger.kernel.org, sparclinux@vger.kernel.org, linux-m68k@lists.linux-m68k.org Cc: Geert Uytterhoeven Subject: [PATCH 3/4] m68k/amiga: Chip RAM - Use lookup_resource() Date: Sat, 21 May 2011 21:39:15 +0200 Message-Id: <1306006756-32009-4-git-send-email-geert@linux-m68k.org> X-Mailer: git-send-email 1.7.0.4 In-Reply-To: <1306006756-32009-1-git-send-email-geert@linux-m68k.org> References: <1306006756-32009-1-git-send-email-geert@linux-m68k.org> Sender: sparclinux-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: sparclinux@vger.kernel.org Replace a custom implementation (which doesn't lock the resource tree) by a call to lookup_resource() Signed-off-by: Geert Uytterhoeven --- arch/m68k/amiga/chipram.c | 22 +++++++++++----------- 1 files changed, 11 insertions(+), 11 deletions(-) diff --git a/arch/m68k/amiga/chipram.c b/arch/m68k/amiga/chipram.c index cfd3b7a..9d53417 100644 --- a/arch/m68k/amiga/chipram.c +++ b/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);