Received: by 2002:a25:824b:0:0:0:0:0 with SMTP id d11csp1400144ybn; Wed, 25 Sep 2019 17:47:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqxUBlk0g3+qAZK7Uullr5AP8twWub9vnHkoJB7ohrIcK4br979lxng+WhPhxO9kYRSdrgdL X-Received: by 2002:a17:906:1c4e:: with SMTP id l14mr863157ejg.276.1569458874273; Wed, 25 Sep 2019 17:47:54 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1569458874; cv=pass; d=google.com; s=arc-20160816; b=z94WllXd+lqGGfYebfBQzNnlHuovX0LPeEi6XcVN2XJHBh9WxkKmaRRTjlR4Ve9U9P Nj2vuzexkdRfAfO3AnDXDOL4GA/6umatTp4xuW+GCqxZBrkYB+XaD6Dj64A6QBJRKfw8 FmppmH+GkEgx6eT9wh2yvnx2k/9d/Psx32njETfxA61wk9VRFFTSKksb3qAjC6NfHlD8 bYLLwCKTbDTY9a5Fn0gkitz/LDTyRZxskYv3yVyHTXewzz5ZDGaDPhIVRb19D2pbLhAI D+77kkIzI+8Ph9iNoBKG0LIMCJ7NU1FyfeKOAJwgvEa1KBSMrffp+O3cHpsb1B9i2TUg +wfQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :content-language:accept-language:in-reply-to:references:message-id :date:thread-index:thread-topic:subject:cc:to:from:dkim-signature :ironport-sdr; bh=8VDCyvHSOv9P80Ue/P+4wVsE5m6IE5589YJSUDfOwAU=; b=gZW6jRMAXMT8GslBwnfOvkXrzyvyXrCP+Dn6iKlcGFRsQRUtOX0AGiN1BMR1TqJdzM YPYeOpsNjLSNgKkBtH7bPZcJSoMIw5aeEdgelNp4e5Y61foTNkpiTE0JXBmdYia/timx N1RN3cIvZ5mLwdGW9NFno2WThj4ewI9ogecKVOJwXzX1qU1BGhDPygfpmlO+PatJHjlq AQHECEVF+6pJfOvPFpZ0npJTxpY3lcC6XGx2FI5NhW86nN0v+p6kqZEGC4qyEbq0UdT0 IC7Rz3VEE9Rr8yAH59eoTe+KcAuvhCmrRLI1MPEMOgJP5vJ6X6ozzuee5WYgwL21/wtB PwGQ== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@microchiptechnology.onmicrosoft.com header.s=selector2-microchiptechnology-onmicrosoft-com header.b=RYhFSPjG; arc=pass (i=1 spf=pass spfdomain=microchip.com dkim=pass dkdomain=microchip.com dmarc=pass fromdomain=microchip.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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=microchip.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h2si417230edw.29.2019.09.25.17.47.30; Wed, 25 Sep 2019 17:47:54 -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; dkim=pass header.i=@microchiptechnology.onmicrosoft.com header.s=selector2-microchiptechnology-onmicrosoft-com header.b=RYhFSPjG; arc=pass (i=1 spf=pass spfdomain=microchip.com dkim=pass dkdomain=microchip.com dmarc=pass fromdomain=microchip.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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=microchip.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2409322AbfIXHqM (ORCPT + 99 others); Tue, 24 Sep 2019 03:46:12 -0400 Received: from esa3.microchip.iphmx.com ([68.232.153.233]:28011 "EHLO esa3.microchip.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2408088AbfIXHqK (ORCPT ); Tue, 24 Sep 2019 03:46:10 -0400 Received-SPF: Pass (esa3.microchip.iphmx.com: domain of Tudor.Ambarus@microchip.com designates 198.175.253.82 as permitted sender) identity=mailfrom; client-ip=198.175.253.82; receiver=esa3.microchip.iphmx.com; envelope-from="Tudor.Ambarus@microchip.com"; x-sender="Tudor.Ambarus@microchip.com"; x-conformance=spf_only; x-record-type="v=spf1"; x-record-text="v=spf1 mx a:ushub1.microchip.com a:smtpout.microchip.com a:mx1.microchip.iphmx.com a:mx2.microchip.iphmx.com include:servers.mcsv.net include:mktomail.com include:spf.protection.outlook.com ~all" Received-SPF: None (esa3.microchip.iphmx.com: no sender authenticity information available from domain of postmaster@email.microchip.com) identity=helo; client-ip=198.175.253.82; receiver=esa3.microchip.iphmx.com; envelope-from="Tudor.Ambarus@microchip.com"; x-sender="postmaster@email.microchip.com"; x-conformance=spf_only Authentication-Results: esa3.microchip.iphmx.com; spf=Pass smtp.mailfrom=Tudor.Ambarus@microchip.com; spf=None smtp.helo=postmaster@email.microchip.com; dkim=pass (signature verified) header.i=@microchiptechnology.onmicrosoft.com; dmarc=pass (p=none dis=none) d=microchip.com IronPort-SDR: AKroLHfP+g0yMJpe8jB1S7cCVTxy12qTxz4eQXWNaO5zEMq6mDd1Q7kUP3HQvlMpxvjFga4FzJ 8aIiAkdz28JChnIpg+y2ea1tF6RRT4L9OLR5tFa8DInPaxhu5Qzzra3lKh3MNWjz3ucDgVhVCN wQs1eDg6+qMDj7gSEuUgUMG6r1QDRjKnClsi+qigxyC+0Vk1XjzqTH5uFEryh4wyWziIjBzT+W 9oTe3XC8mVSlde/ixN2jt1WJ7FTOIZ+EBchxM/7EjxC5bF+qFuTl1BJSwH8xKDzXIE9C7u/9q2 4WI= X-IronPort-AV: E=Sophos;i="5.64,543,1559545200"; d="scan'208";a="50281743" Received: from smtpout.microchip.com (HELO email.microchip.com) ([198.175.253.82]) by esa3.microchip.iphmx.com with ESMTP/TLS/AES256-SHA256; 24 Sep 2019 00:46:09 -0700 Received: from chn-vm-ex01.mchp-main.com (10.10.85.143) by chn-vm-ex01.mchp-main.com (10.10.85.143) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5; Tue, 24 Sep 2019 00:46:09 -0700 Received: from NAM01-SN1-obe.outbound.protection.outlook.com (10.10.215.89) by email.microchip.com (10.10.87.71) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5 via Frontend Transport; Tue, 24 Sep 2019 00:46:09 -0700 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=Vb4+YufVA0UWiJW58DgCMbpLaItaqCJNrgnX4zip8M4xdT6Q/4mYUfYXzD6c8k4OJIUSYfa6pKC+IgvtqVrAJrpbeYq07tqKRTYPIfSgWi5VthbsDo6qXApZokbbPtS3tD0cLWhxqcyUVL+BgGo/rCNyiVLIMt8DWtylSTQIO/EFYiSRQtngaY7A7hVYpoBxcMwsdjE/Ac7APfjz3+jlCxXdG8v8eQyiVlFaMB/LAoxkZk+35Gdsg7zRJFY18qvBZ2TXM+miKtAf6vEdbiOxhtRAPpBqgNtJgnjbmmrbLCEY2z2/TMGqsQdd8vrZEHAFUP4e35cGyh10uxScKTPHZg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=8VDCyvHSOv9P80Ue/P+4wVsE5m6IE5589YJSUDfOwAU=; b=OuwnylsSUzp9fgz4fRkr7T0J2hwsDrFn674ZRuN/Ep/2vYh2XZTmK+z5cUYUHkPIItWQ0a5ateha2mUCFgJcFsvjTfWcwyJVOHIOS1+mZKDTGNAnPxgt3817gTDYEloDc5A5NatN2B97he1aAqH9XPymuCzDH/HQILsWERioUvextdf65Wu8iu1rjWxWcOZrXEbqnUymzgbL9FdqqQqhxCFchFZnaItpU622Qyg9ql7f8EOLVAXIbh4emC39z32VelwoB5Rp6x0nFFLERgNnQdaFiW9q+iG2LqjUmteSSUs20A/xBJIYYA2EbRsJSQv6lwgbZ6qrGfzj3DJOjMUnWw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=microchip.com; dmarc=pass action=none header.from=microchip.com; dkim=pass header.d=microchip.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microchiptechnology.onmicrosoft.com; s=selector2-microchiptechnology-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=8VDCyvHSOv9P80Ue/P+4wVsE5m6IE5589YJSUDfOwAU=; b=RYhFSPjGHPi3wCmsLDPMwukGSdNbDbTSsEUbCq74aOuuU5+tBEJoNdFeQGp/MZje3u9LoWggXpJ0PiFWETPu7eGe8Y/0F/tedcl9hpqp8tjhH8IWC6dk1hUf5FWlHQU3IgAbigxnhzcPD5T2zR4DDy/oB7qKpK0THcvSjynhXb8= Received: from MN2PR11MB4448.namprd11.prod.outlook.com (52.135.39.157) by MN2PR11MB4319.namprd11.prod.outlook.com (52.135.39.155) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2284.26; Tue, 24 Sep 2019 07:46:08 +0000 Received: from MN2PR11MB4448.namprd11.prod.outlook.com ([fe80::c951:b15a:e4b3:30f7]) by MN2PR11MB4448.namprd11.prod.outlook.com ([fe80::c951:b15a:e4b3:30f7%7]) with mapi id 15.20.2284.023; Tue, 24 Sep 2019 07:46:08 +0000 From: To: , , , , , CC: , , , , , , , , , , , , Subject: [PATCH v2 05/22] mtd: spi-nor: Rework read_sr() Thread-Topic: [PATCH v2 05/22] mtd: spi-nor: Rework read_sr() Thread-Index: AQHVcqwggo0opq7ZEEeQh8oJ3AuUcg== Date: Tue, 24 Sep 2019 07:46:08 +0000 Message-ID: <20190924074533.6618-6-tudor.ambarus@microchip.com> References: <20190924074533.6618-1-tudor.ambarus@microchip.com> In-Reply-To: <20190924074533.6618-1-tudor.ambarus@microchip.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-clientproxiedby: VI1PR0101CA0082.eurprd01.prod.exchangelabs.com (2603:10a6:800:1f::50) To MN2PR11MB4448.namprd11.prod.outlook.com (2603:10b6:208:193::29) x-ms-exchange-messagesentrepresentingtype: 1 x-mailer: git-send-email 2.9.5 x-originating-ip: [94.177.32.156] x-ms-publictraffictype: Email x-ms-office365-filtering-correlation-id: 0ae09e48-4e5c-4e70-7be1-08d740c342a4 x-microsoft-antispam: BCL:0;PCL:0;RULEID:(2390118)(7020095)(4652040)(8989299)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(5600167)(711020)(4605104)(1401327)(2017052603328)(7193020);SRVR:MN2PR11MB4319; x-ms-traffictypediagnostic: MN2PR11MB4319: x-ms-exchange-transport-forked: True x-microsoft-antispam-prvs: x-ms-oob-tlc-oobclassifiers: OLM:10000; x-forefront-prvs: 0170DAF08C x-forefront-antispam-report: SFV:NSPM;SFS:(10009020)(366004)(396003)(136003)(346002)(39860400002)(376002)(189003)(199004)(14444005)(5660300002)(2201001)(6436002)(256004)(86362001)(11346002)(14454004)(476003)(2501003)(305945005)(186003)(2616005)(26005)(386003)(102836004)(6506007)(25786009)(6486002)(8936002)(81156014)(2906002)(3846002)(81166006)(107886003)(7736002)(8676002)(6512007)(486006)(36756003)(52116002)(71200400001)(71190400001)(50226002)(446003)(66446008)(76176011)(99286004)(66946007)(4326008)(66476007)(64756008)(66556008)(6116002)(54906003)(110136005)(66066001)(316002)(1076003)(7416002)(478600001);DIR:OUT;SFP:1101;SCL:1;SRVR:MN2PR11MB4319;H:MN2PR11MB4448.namprd11.prod.outlook.com;FPR:;SPF:None;LANG:en;PTR:InfoNoRecords;MX:1;A:1; received-spf: None (protection.outlook.com: microchip.com does not designate permitted sender hosts) x-ms-exchange-senderadcheck: 1 x-microsoft-antispam-message-info: Nrh54uSBeRG3XmIDOUtv2qgGewGnDrbMskVR51hE6ZLLuIRS8r2NVUJiTD0zh96UnO5Zfbk4Agx0A7uVNVYDiwcfGpQpahfFcDsQx7eqdwAK/Nw0lb+hCMb98SRjfiMLbzMlQOgOqirjnaKXTdFhg3Atipdpn+Fz6Xdx2EZIre9IsaJ+nLolUAcfdbJqmebnAAVjPmp6xYSJ7P1LZMUyiJJMe1wpMBa2oWpSrk7BZHb5ZjYVAIcW+0pVZrVx3HIYH/zvMQ2ppGx7Pc7pO8bPw7qtMwhs3ma2zWogCpRzclZVPNMlCOhdGDMmcNHxPHQ7aHcL1nIQRxjfN64lhCK/KzhH0PWK8hcp66sjsnUTPG6RxoMjzPjAzRyucVW6Q6Q6XhZ/Jp3Xxmm8B4WG4yWlxu2FspTEAqmMQZVzqHS8WB0= Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-MS-Exchange-CrossTenant-Network-Message-Id: 0ae09e48-4e5c-4e70-7be1-08d740c342a4 X-MS-Exchange-CrossTenant-originalarrivaltime: 24 Sep 2019 07:46:08.0888 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 3f4057f3-b418-4d4e-ba84-d55b4e897d88 X-MS-Exchange-CrossTenant-mailboxtype: HOSTED X-MS-Exchange-CrossTenant-userprincipalname: r1bwvMTrBTGtmAh4wFZ93My5IMqowohQsYIwApi3RGYbfr+v6Da2ln18B2xbyfJXcozUYMiGSLeOWrYRZFKy+CiePh2PRRd6Gam2xnklhIc= X-MS-Exchange-Transport-CrossTenantHeadersStamped: MN2PR11MB4319 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tudor Ambarus static int read_sr(struct spi_nor *nor) becomes static int spi_nor_read_sr(struct spi_nor *nor, u8 *sr) The new function returns 0 on success and -errno otherwise. We let the callers pass the pointer to the buffer where the value of the Status Register will be written. This way we avoid the casts between int and u8, which can be confusing. Prepend spi_nor_ to the function name, all functions should begin with that. S/pr_err/dev_err and drop duplicated dev_err in callers, in case the function returns error. Signed-off-by: Tudor Ambarus --- drivers/mtd/spi-nor/spi-nor.c | 131 +++++++++++++++++++++-----------------= ---- 1 file changed, 65 insertions(+), 66 deletions(-) diff --git a/drivers/mtd/spi-nor/spi-nor.c b/drivers/mtd/spi-nor/spi-nor.c index 7d0c1b598250..a23783641146 100644 --- a/drivers/mtd/spi-nor/spi-nor.c +++ b/drivers/mtd/spi-nor/spi-nor.c @@ -388,12 +388,14 @@ static ssize_t spi_nor_write_data(struct spi_nor *nor= , loff_t to, size_t len, return nor->controller_ops->write(nor, to, len, buf); } =20 -/* - * Read the status register, returning its value in the location - * Return the status register value. - * Returns negative if error occurred. +/** + * spi_nor_read_sr() - Read the Status Register. + * @nor: pointer to 'struct spi_nor' + * @sr: buffer where the value of the Status Register will be written. + * + * Return: 0 on success, -errno otherwise. */ -static int read_sr(struct spi_nor *nor) +static int spi_nor_read_sr(struct spi_nor *nor, u8 *sr) { int ret; =20 @@ -402,20 +404,17 @@ static int read_sr(struct spi_nor *nor) SPI_MEM_OP(SPI_MEM_OP_CMD(SPINOR_OP_RDSR, 1), SPI_MEM_OP_NO_ADDR, SPI_MEM_OP_NO_DUMMY, - SPI_MEM_OP_DATA_IN(1, nor->bouncebuf, 1)); + SPI_MEM_OP_DATA_IN(1, sr, 1)); =20 ret =3D spi_mem_exec_op(nor->spimem, &op); } else { - ret =3D nor->controller_ops->read_reg(nor, SPINOR_OP_RDSR, - nor->bouncebuf, 1); + ret =3D nor->controller_ops->read_reg(nor, SPINOR_OP_RDSR, sr, 1); } =20 - if (ret < 0) { - pr_err("error %d reading SR\n", (int) ret); - return ret; - } + if (ret) + dev_err(nor->dev, "error %d reading SR\n", ret); =20 - return nor->bouncebuf[0]; + return ret; } =20 /* @@ -752,12 +751,14 @@ static int spi_nor_clear_sr(struct spi_nor *nor) =20 static int spi_nor_sr_ready(struct spi_nor *nor) { - int sr =3D read_sr(nor); - if (sr < 0) - return sr; + int ret =3D spi_nor_read_sr(nor, &nor->bouncebuf[0]); + + if (ret) + return ret; =20 - if (nor->flags & SNOR_F_USE_CLSR && sr & (SR_E_ERR | SR_P_ERR)) { - if (sr & SR_E_ERR) + if (nor->flags & SNOR_F_USE_CLSR && + nor->bouncebuf[0] & (SR_E_ERR | SR_P_ERR)) { + if (nor->bouncebuf[0] & SR_E_ERR) dev_err(nor->dev, "Erase Error occurred\n"); else dev_err(nor->dev, "Programming Error occurred\n"); @@ -766,7 +767,7 @@ static int spi_nor_sr_ready(struct spi_nor *nor) return -EIO; } =20 - return !(sr & SR_WIP); + return !(nor->bouncebuf[0] & SR_WIP); } =20 static int spi_nor_clear_fsr(struct spi_nor *nor) @@ -1341,11 +1342,11 @@ static int write_sr_and_check(struct spi_nor *nor, = u8 status_new, u8 mask) if (ret) return ret; =20 - ret =3D read_sr(nor); - if (ret < 0) + ret =3D spi_nor_read_sr(nor, &nor->bouncebuf[0]); + if (ret) return ret; =20 - return ((ret & mask) !=3D (status_new & mask)) ? -EIO : 0; + return ((nor->bouncebuf[0] & mask) !=3D (status_new & mask)) ? -EIO : 0; } =20 static void stm_get_locked_range(struct spi_nor *nor, u8 sr, loff_t *ofs, @@ -1440,16 +1441,18 @@ static int stm_is_unlocked_sr(struct spi_nor *nor, = loff_t ofs, uint64_t len, static int stm_lock(struct spi_nor *nor, loff_t ofs, uint64_t len) { struct mtd_info *mtd =3D &nor->mtd; - int status_old, status_new; + int ret, status_old, status_new; u8 mask =3D SR_BP2 | SR_BP1 | SR_BP0; u8 shift =3D ffs(mask) - 1, pow, val; loff_t lock_len; bool can_be_top =3D true, can_be_bottom =3D nor->flags & SNOR_F_HAS_SR_TB= ; bool use_top; =20 - status_old =3D read_sr(nor); - if (status_old < 0) - return status_old; + ret =3D spi_nor_read_sr(nor, &nor->bouncebuf[0]); + if (ret) + return ret; + + status_old =3D nor->bouncebuf[0]; =20 /* If nothing in our range is unlocked, we don't need to do anything */ if (stm_is_locked_sr(nor, ofs, len, status_old)) @@ -1520,16 +1523,18 @@ static int stm_lock(struct spi_nor *nor, loff_t ofs= , uint64_t len) static int stm_unlock(struct spi_nor *nor, loff_t ofs, uint64_t len) { struct mtd_info *mtd =3D &nor->mtd; - int status_old, status_new; + int ret, status_old, status_new; u8 mask =3D SR_BP2 | SR_BP1 | SR_BP0; u8 shift =3D ffs(mask) - 1, pow, val; loff_t lock_len; bool can_be_top =3D true, can_be_bottom =3D nor->flags & SNOR_F_HAS_SR_TB= ; bool use_top; =20 - status_old =3D read_sr(nor); - if (status_old < 0) - return status_old; + ret =3D spi_nor_read_sr(nor, &nor->bouncebuf[0]); + if (ret) + return ret; + + status_old =3D nor->bouncebuf[0]; =20 /* If nothing in our range is locked, we don't need to do anything */ if (stm_is_unlocked_sr(nor, ofs, len, status_old)) @@ -1604,13 +1609,12 @@ static int stm_unlock(struct spi_nor *nor, loff_t o= fs, uint64_t len) */ static int stm_is_locked(struct spi_nor *nor, loff_t ofs, uint64_t len) { - int status; + int ret =3D spi_nor_read_sr(nor, &nor->bouncebuf[0]); =20 - status =3D read_sr(nor); - if (status < 0) - return status; + if (ret) + return ret; =20 - return stm_is_locked_sr(nor, ofs, len, status); + return stm_is_locked_sr(nor, ofs, len, nor->bouncebuf[0]); } =20 static const struct spi_nor_locking_ops stm_locking_ops =3D { @@ -1717,24 +1721,28 @@ static int write_sr_cr(struct spi_nor *nor, u8 *sr_= cr) */ static int macronix_quad_enable(struct spi_nor *nor) { - int ret, val; + int ret; =20 - val =3D read_sr(nor); - if (val < 0) - return val; - if (val & SR_QUAD_EN_MX) + ret =3D spi_nor_read_sr(nor, &nor->bouncebuf[0]); + if (ret) + return ret; + + if (nor->bouncebuf[0] & SR_QUAD_EN_MX) return 0; =20 write_enable(nor); =20 - write_sr(nor, val | SR_QUAD_EN_MX); + write_sr(nor, nor->bouncebuf[0] | SR_QUAD_EN_MX); =20 ret =3D spi_nor_wait_till_ready(nor); if (ret) return ret; =20 - ret =3D read_sr(nor); - if (!(ret > 0 && (ret & SR_QUAD_EN_MX))) { + ret =3D spi_nor_read_sr(nor, &nor->bouncebuf[0]); + if (ret) + return ret; + + if (!(nor->bouncebuf[0] & SR_QUAD_EN_MX)) { dev_err(nor->dev, "Macronix Quad bit not set\n"); return -EINVAL; } @@ -1805,12 +1813,10 @@ static int spansion_no_read_cr_quad_enable(struct s= pi_nor *nor) int ret; =20 /* Keep the current value of the Status Register. */ - ret =3D read_sr(nor); - if (ret < 0) { - dev_err(nor->dev, "error while reading status register\n"); - return -EINVAL; - } - sr_cr[0] =3D ret; + ret =3D spi_nor_read_sr(nor, &sr_cr[0]); + if (ret) + return ret; + sr_cr[1] =3D CR_QUAD_EN_SPAN; =20 return write_sr_cr(nor, sr_cr); @@ -1848,12 +1854,9 @@ static int spansion_read_cr_quad_enable(struct spi_n= or *nor) sr_cr[1] =3D ret | CR_QUAD_EN_SPAN; =20 /* Keep the current value of the Status Register. */ - ret =3D read_sr(nor); - if (ret < 0) { - dev_err(dev, "error while reading status register\n"); - return -EINVAL; - } - sr_cr[0] =3D ret; + ret =3D spi_nor_read_sr(nor, &sr_cr[0]); + if (ret) + return ret; =20 ret =3D write_sr_cr(nor, sr_cr); if (ret) @@ -1964,15 +1967,13 @@ static int spi_nor_clear_sr_bp(struct spi_nor *nor) int ret; u8 mask =3D SR_BP2 | SR_BP1 | SR_BP0; =20 - ret =3D read_sr(nor); - if (ret < 0) { - dev_err(nor->dev, "error while reading status register\n"); + ret =3D spi_nor_read_sr(nor, &nor->bouncebuf[0]); + if (ret) return ret; - } =20 write_enable(nor); =20 - ret =3D write_sr(nor, ret & ~mask); + ret =3D write_sr(nor, nor->bouncebuf[0] & ~mask); if (ret) { dev_err(nor->dev, "write to status register failed\n"); return ret; @@ -2018,13 +2019,11 @@ static int spi_nor_spansion_clear_sr_bp(struct spi_= nor *nor) if (ret & CR_QUAD_EN_SPAN) { sr_cr[1] =3D ret; =20 - ret =3D read_sr(nor); - if (ret < 0) { - dev_err(nor->dev, - "error while reading status register\n"); + ret =3D spi_nor_read_sr(nor, &sr_cr[0]); + if (ret) return ret; - } - sr_cr[0] =3D ret & ~mask; + + sr_cr[0] &=3D ~mask; =20 ret =3D write_sr_cr(nor, sr_cr); if (ret) --=20 2.9.5