From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758218AbYGUJa3 (ORCPT ); Mon, 21 Jul 2008 05:30:29 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1755758AbYGUJaT (ORCPT ); Mon, 21 Jul 2008 05:30:19 -0400 Received: from bu3sch.de ([62.75.166.246]:51194 "EHLO vs166246.vserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755499AbYGUJaS (ORCPT ); Mon, 21 Jul 2008 05:30:18 -0400 From: Michael Buesch To: John Linville Subject: [PATCH] b43legacy: Release mutex in error handling code Date: Mon, 21 Jul 2008 11:29:34 +0200 User-Agent: KMail/1.9.6 (enterprise 0.20070907.709405) Cc: Larry.Finger@lwfinger.net, stefano.brivio@polimi.it, linux-wireless@vger.kernel.org, jgarzik@pobox.com, linux-kernel@vger.kernel.org, kernel-janitors@vger.kernel.org, Julia Lawall MIME-Version: 1.0 Content-Disposition: inline Message-Id: <200807211129.34610.mb@bu3sch.de> Content-Type: Text/Plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Julia Lawall The mutex is released on a successful return, so it would seem that it should be released on an error return as well. The semantic patch finds this problem is as follows: (http://www.emn.fr/x-info/coccinelle/) // @@ expression l; @@ mutex_lock(l); ... when != mutex_unlock(l) when any when strict ( if (...) { ... when != mutex_unlock(l) + mutex_unlock(l); return ...; } | mutex_unlock(l); ) // Signed-off-by: Julia Lawall Signed-off-by: Michael Buesch Cc: stable --- John, please apply this bugfix to the next bugfix release. diff -u -p a/drivers/net/wireless/b43legacy/main.c b/drivers/net/wireless/b43legacy/main.c --- a/drivers/net/wireless/b43legacy/main.c +++ b/drivers/net/wireless/b43legacy/main.c @@ -3862,10 +3862,10 @@ static int b43legacy_resume(struct ssb_d goto out; } } - mutex_unlock(&wl->mutex); b43legacydbg(wl, "Device resumed.\n"); out: + mutex_unlock(&wl->mutex); return err; } -- Greetings Michael.