Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp541590imm; Wed, 4 Jul 2018 01:27:38 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdQ+vd2E6PiNy+vq5TMOaH0EveENE2FpyjWLKLf/dfsb7Xutz5pVsOakBc2LItkqqIubOgD X-Received: by 2002:a62:850d:: with SMTP id u13-v6mr1174737pfd.131.1530692858489; Wed, 04 Jul 2018 01:27:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530692858; cv=none; d=google.com; s=arc-20160816; b=wu8Q7wijyTPwmZBMyFe2JI9r8jBNf+XEqqc7pjTZfRioRRUYaZgWiMstdoEGt3KxRA IT88P70Sen7ObrODHtX4TjVxu1NAyYV5It3UmiYVCQTUP9J1evqzjP1sg4MWdJhqY+lD cNkm58FYwYUDWWfsihgCaK71J9bmP5+Xq11Xsrx6i9s/E82DijgaI6luCT08JsUjaULN kRJ31SMXkmnRUet9TMHdIMwJFAJzvM2BNYDIYX2is7D3IU+Ut/nfADNFfL1GpEU2Gt0L pSSjGpIwm40UuK3jtUpz/Ta8mGpJa4RRH3mVucME2SasdkQ96eA/OUCVnwEUoMc2JZMH l3aw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :arc-authentication-results; bh=LWr196dPm/eygTCcU+DYGvLB6Z2o7k+O6qzCRQLE9WM=; b=i8GhXfUtW3oLAlZYT94M5N+HFjaL8QERxkMXA8bEYoa5fVs/Zs/L2GHQb2cBYA6hW8 XDauNDKbX5+H9WPQNhh3m6N8c3yEoWqBE9L4FLvbxHWii28k/X3HBXFb/CmxOSblbOnO 08/ANRlemM8Cj6B1RE8TCKtA/02cppXlqoHcV/xOVgBxbP6nzG4fPPf2P2F9Ki6/m8E1 x8FbuvK1vuuJeSlrEDBiJxTlmoxjzr5zQ0jU2XycW6EiV7Le8gdQVAMr7yAxTJXGoZx2 1WcFXMWr9DbwONLxO9TM4MAGI8BeRVnfMN8GwgvyKTJkn5+063AFscwELkhSr3oLYeNZ CVKA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r3-v6si2777787pgo.606.2018.07.04.01.27.23; Wed, 04 Jul 2018 01:27:38 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933942AbeGDIZo (ORCPT + 99 others); Wed, 4 Jul 2018 04:25:44 -0400 Received: from mail.bootlin.com ([62.4.15.54]:38292 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932290AbeGDIZn (ORCPT ); Wed, 4 Jul 2018 04:25:43 -0400 Received: by mail.bootlin.com (Postfix, from userid 110) id B64F120787; Wed, 4 Jul 2018 10:25:40 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on mail.bootlin.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT, URIBL_BLOCKED shortcircuit=ham autolearn=disabled version=3.4.0 Received: from bbrezillon (AAubervilliers-681-1-39-106.w90-88.abo.wanadoo.fr [90.88.158.106]) by mail.bootlin.com (Postfix) with ESMTPSA id 6FEAB2084E; Wed, 4 Jul 2018 10:25:30 +0200 (CEST) Date: Wed, 4 Jul 2018 10:25:31 +0200 From: Boris Brezillon To: Wei Yongjun Cc: Miquel Raynal , Richard Weinberger , "David Woodhouse" , Brian Norris , Marek Vasut , Peter Pan , Frieder Schrempf , , , Subject: Re: [PATCH -next] mtd: spinand: Fix missing unlock on error path Message-ID: <20180704102531.7af9a2e6@bbrezillon> In-Reply-To: <1530692979-6274-1-git-send-email-weiyongjun1@huawei.com> References: <1530692979-6274-1-git-send-email-weiyongjun1@huawei.com> X-Mailer: Claws Mail 3.15.0-dirty (GTK+ 2.24.31; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 4 Jul 2018 08:29:39 +0000 Wei Yongjun wrote: > Add the missing unlock before return from function > spinand_mtd_(read|write) in the error handling case. > > Fixes: c898e0526fb6 ("mtd: nand: Add core infrastructure to support SPI NANDs") > Signed-off-by: Wei Yongjun > --- > drivers/mtd/nand/spi/core.c | 12 ++++++++---- > 1 file changed, 8 insertions(+), 4 deletions(-) > > diff --git a/drivers/mtd/nand/spi/core.c b/drivers/mtd/nand/spi/core.c > index 17d207a..8ac1ba95 100644 > --- a/drivers/mtd/nand/spi/core.c > +++ b/drivers/mtd/nand/spi/core.c > @@ -560,12 +560,16 @@ static int spinand_mtd_read(struct mtd_info *mtd, loff_t from, > > nanddev_io_for_each_page(nand, from, ops, &iter) { > ret = spinand_select_target(spinand, iter.req.pos.target); > - if (ret) > + if (ret) { > + mutex_unlock(&spinand->lock); > return ret; > + } Why not if (ret) break; ? > > ret = spinand_ecc_enable(spinand, enable_ecc); > - if (ret) > + if (ret) { > + mutex_unlock(&spinand->lock); > return ret; > + } Ditto. > > ret = spinand_read_page(spinand, &iter.req, enable_ecc); > if (ret < 0 && ret != -EBADMSG) > @@ -609,11 +613,11 @@ static int spinand_mtd_write(struct mtd_info *mtd, loff_t to, > nanddev_io_for_each_page(nand, to, ops, &iter) { > ret = spinand_select_target(spinand, iter.req.pos.target); > if (ret) > - return ret; > + break; > > ret = spinand_ecc_enable(spinand, enable_ecc); > if (ret) > - return ret; > + break; > > ret = spinand_write_page(spinand, &iter.req); > if (ret) >