Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp1266262ybl; Fri, 23 Aug 2019 16:32:03 -0700 (PDT) X-Google-Smtp-Source: APXvYqxk1F0Tyi0SFwS9Jlbg+FLLzFvJobKie/UNEFeA8hN4IIDZEgVgoku66rR6YlQoIEYUAQCm X-Received: by 2002:a17:90a:b30e:: with SMTP id d14mr7416773pjr.26.1566603123097; Fri, 23 Aug 2019 16:32:03 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1566603123; cv=pass; d=google.com; s=arc-20160816; b=JdheR92jaEL9ZgJTuj6TnU/djxb33TqEvs1WeKqzNHC25DijgpcNXLG5leuBRdZAa2 ThDLjWNKrlx7zFWod/pemuZMPaEICqp4H6E9hP1vr4/WmHeIAhwrc7CWdv5fbv36ZrPI f/ChlhW/zsZAqMnw8LXr+FVr7hA1g9umGPunnBsbQk4j3SQY5Rp27vxyD4fTvdsyfkZr lQNZKkwsNhb+LaoFMZPJo5w7iLLMNysCyzLpSgLU0hZvO7zxbepjgNpyCajaF6dAAdPi QmqsKAgBWfJPvc/2qdWjFICJKKhgk8XM0CMnnc2AJCnN5WUXZU0rG9vvbWf04odpoV0L UYCA== 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=d/KRyp26hAp5KBM+H0hXLK88dP++vAEExmA9URMWPnc=; b=zLMXBd9V3hSYU5xxTKbBNsC3YsViRnxJdy+MilpMoKru1OiP9QeteH0oYeXV48Uacl JAiB0StVP18lhCRnYE6ctFM3KbBSXvG5N7/stMvlSA6sA/JGhN91Ch4KWXT/MjOSmewN BEKztR2E6pJh6wk2WUYFZNTdHET1bAa8rHQZ3Z4i3hpei0kGBcL/SDVAXc1rdI316nT/ X+HMTJFzw40e/Cw0sAOAotqxVVae4mSC2ptshGfOjVSxpjHc+WVX9gygS1LORsk+/COO sUXtgwzH3hBUL3pAtaMHArGYea5x0F33RaA77fYzDGr25aVLj9Pkwu8ONgD7PNNtmg0M Hnyg== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@microchiptechnology.onmicrosoft.com header.s=selector2-microchiptechnology-onmicrosoft-com header.b=R61999iO; 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 6si3706956pla.88.2019.08.23.16.31.47; Fri, 23 Aug 2019 16:32:03 -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=R61999iO; 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 S2436619AbfHWPxm (ORCPT + 99 others); Fri, 23 Aug 2019 11:53:42 -0400 Received: from esa3.microchip.iphmx.com ([68.232.153.233]:37628 "EHLO esa3.microchip.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2436612AbfHWPxk (ORCPT ); Fri, 23 Aug 2019 11:53:40 -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: GTzxIOdwWNIN3ljmEw/b5UKxNew9XhdpjqaAeOB5lkTkIeYkW5+VZhqthZO8ezOfrZKjMsx7q0 8Ausc0E5A9AVD0y3ryEQBHKUJXJpRpDrPjmIkq9HmmMHxt9uRzxh8J6urly21h6hWQl8v3cAkH wf9kmzUuFUIFkLLVbMuwEO8S1B72cbbJTBX9N8ZT7nezzgXuuX6v8dYStkv/gXX7mirYIuJCPc l8Wcs8oLWGKOzYA5KNUS7nDR8QxO+REgKtVxjP72p9mpbdq51d8/74H6KhxTAR+baVt7jKfpAC 6Tc= X-IronPort-AV: E=Sophos;i="5.64,421,1559545200"; d="scan'208";a="46398674" Received: from smtpout.microchip.com (HELO email.microchip.com) ([198.175.253.82]) by esa3.microchip.iphmx.com with ESMTP/TLS/AES256-SHA256; 23 Aug 2019 08:53:39 -0700 Received: from chn-vm-ex01.mchp-main.com (10.10.85.143) by chn-vm-ex04.mchp-main.com (10.10.85.152) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5; Fri, 23 Aug 2019 08:53:38 -0700 Received: from NAM05-DM3-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_CBC_SHA256) id 15.1.1713.5 via Frontend Transport; Fri, 23 Aug 2019 08:53:37 -0700 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=HPLdIqL2i4Obno9/Gq/R9ruK4Ivp4CyJ0SzimPdgX3pl1N/PN8HN7vBaRonLRGUiDxyWkwmHWtARCKyRXEnUO9IQaNteqrVLav0lR32As47jN1qbWhJixWI/DNAu/B9VGmz2Zx+ArAqFr5XpnGyRSABkrWVqkRfXm7FIJ2zpUTQiGZdDV3SonE1dhqGNDsacVhvQ+tMXlSeqickz8yMYNemadVJz6ipL2MT2CufkPMm1EVf+6mGdOyeB6B0NjaULGOPdLBQnfvimYsNtHLFQZbv1oKQrswo4ZvOFy8xLVJsC76NcabdY3DZ7eMr5biqX8e8RnG6PpxQdrRhxauiy/g== 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=d/KRyp26hAp5KBM+H0hXLK88dP++vAEExmA9URMWPnc=; b=KQ9qSGAVeee5N84gvKXxZZTvNxTu+Uc/iy3yjIPMr8qYf5s8EXgT9HB24y00AFJ72APoXTqlT5t3wwpX0TyTuvMkwz7llkP+ewiqKV01ZrOnqppRv83ePiqIusIHYw5+YWf5pLVQVOFzdxbPQeZdBRPiejiiz7EsRKTACdSVPA+BjOU56HYxFKYmOvT72DAuvu971EQxqzRiiKiWmfSvWjIu10Ipx+ZKyQvpt1PoJOeak5j2siL8ukhsPAPlxkfLckYcY07gHkR/CfNJLyBbgnM/qjKWPww3TDevWo8x95JHPxKOPOwlnYKvAl0IFrg/SH+mrZ4YHuvkHSTvg9QFbw== 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=d/KRyp26hAp5KBM+H0hXLK88dP++vAEExmA9URMWPnc=; b=R61999iOve7beSkKJgqa/X8z7VQn9mKA3PsUDW/iTSGuS51f4DvohC/mbLgUmNk9/HEaFmm58ThjqekE3VbwxggrRhFK/1o6pw8iq2wAgyMLTSGvxqNJx2WYWt6PJjqeR5UQkb71ye0tEtkC72YycLx8l1Q7ZC6C9KcOZsipQ9o= Received: from MN2PR11MB4448.namprd11.prod.outlook.com (52.135.39.157) by MN2PR11MB3567.namprd11.prod.outlook.com (20.178.251.95) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2178.18; Fri, 23 Aug 2019 15:53:37 +0000 Received: from MN2PR11MB4448.namprd11.prod.outlook.com ([fe80::70c3:e929:4da2:60a5]) by MN2PR11MB4448.namprd11.prod.outlook.com ([fe80::70c3:e929:4da2:60a5%7]) with mapi id 15.20.2178.020; Fri, 23 Aug 2019 15:53:37 +0000 From: To: , , , , , , CC: Subject: [PATCH 2/5] mtd: spi-nor: Use nor->params Thread-Topic: [PATCH 2/5] mtd: spi-nor: Use nor->params Thread-Index: AQHVWcrtbtxtMtrsS0Obi5u9y2hX/A== Date: Fri, 23 Aug 2019 15:53:37 +0000 Message-ID: <20190823155325.13459-3-tudor.ambarus@microchip.com> References: <20190823155325.13459-1-tudor.ambarus@microchip.com> In-Reply-To: <20190823155325.13459-1-tudor.ambarus@microchip.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-clientproxiedby: VI1PR07CA0247.eurprd07.prod.outlook.com (2603:10a6:803:b4::14) 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: 2332093c-f85d-4f12-8329-08d727e20fad x-microsoft-antispam: BCL:0;PCL:0;RULEID:(2390118)(7020095)(4652040)(8989299)(5600166)(711020)(4605104)(1401327)(4534185)(4627221)(201703031133081)(201702281549075)(8990200)(2017052603328)(7193020);SRVR:MN2PR11MB3567; x-ms-traffictypediagnostic: MN2PR11MB3567: x-ms-exchange-transport-forked: True x-microsoft-antispam-prvs: x-ms-oob-tlc-oobclassifiers: OLM:8273; x-forefront-prvs: 0138CD935C x-forefront-antispam-report: SFV:NSPM;SFS:(10009020)(346002)(376002)(136003)(39860400002)(366004)(396003)(199004)(189003)(1076003)(102836004)(5660300002)(2616005)(476003)(71190400001)(71200400001)(6486002)(66066001)(256004)(386003)(486006)(53936002)(6436002)(446003)(2501003)(11346002)(36756003)(6506007)(76176011)(8936002)(86362001)(6116002)(4326008)(3846002)(2201001)(6512007)(66946007)(26005)(186003)(25786009)(52116002)(99286004)(305945005)(81156014)(81166006)(7736002)(14454004)(66446008)(66476007)(316002)(107886003)(110136005)(2906002)(50226002)(8676002)(478600001)(66556008)(64756008);DIR:OUT;SFP:1101;SCL:1;SRVR:MN2PR11MB3567;H:MN2PR11MB4448.namprd11.prod.outlook.com;FPR:;SPF:None;LANG:en;PTR:InfoNoRecords;A:1;MX: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: G3J3ZmEQQovplt1dv9hD6bfz3h+pXnzEF5Y5SQuY1xen1oll5Oes1ghCUcmhn8elWTZOhZjwjgsDv6AaZo5+DvMlJa7vxrQJ2Gn2IvE5qp2WIFeVifCWNe7D9mvKkGVnU2ux2OBjcotIEcG3JK3xtTXi2W6HA/Qf0meCi0xB25og5Nl4+xM0RdSm8YmELLdGXKKwEeQ+scT2O5zzLnt5111Cicspp7o6Vgi5QsqsOx5FnsV333dH1Q190oiDIoQSv0mS4ftdOORKUejCUv4nzfXBeXJ4euC7D2xiPo2FLXQucEnV6e1htprUbKR/TAgtGtBZeIRvb8xvhcT6Fx+IIo5im5NctDJEmdXi/ivhOCuc1ZixNvey9yuPcLZbpNfhhy6Fr2Syp3fl4/D+GIFYKASF2iguF9+Jiag6flHhW78= Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 X-MS-Exchange-CrossTenant-Network-Message-Id: 2332093c-f85d-4f12-8329-08d727e20fad X-MS-Exchange-CrossTenant-originalarrivaltime: 23 Aug 2019 15:53:37.7814 (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: GLzAz4cCHQJZQ8iQaPtaipXHHF7QrhFkwCXJnVk1cbQi4tGdzmxvAsqmeWflXtyyRyDjPd9eehsoYxRVMiHI2STnckKCfNoi7CWffzwvvxQ= X-MS-Exchange-Transport-CrossTenantHeadersStamped: MN2PR11MB3567 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tudor Ambarus The Flash parameters and settings are now stored in 'struct spi_nor'. Use this instead of the stack allocated params. Few functions stop passing pointer to params, as they can get it from 'struct spi_nor'. spi_nor_parse_sfdp() and children will keep passing pointer to params because of the roll-back mechanism: in case the parsing of SFDP fails, the legacy flash parameter and settings will be restored. Zeroizing params is no longer needed because all SPI NOR users kzalloc 'struct spi_nor'. Signed-off-by: Tudor Ambarus --- drivers/mtd/spi-nor/spi-nor.c | 46 ++++++++++++++++++---------------------= ---- 1 file changed, 19 insertions(+), 27 deletions(-) diff --git a/drivers/mtd/spi-nor/spi-nor.c b/drivers/mtd/spi-nor/spi-nor.c index d35dc6a97521..e9b9cd70a999 100644 --- a/drivers/mtd/spi-nor/spi-nor.c +++ b/drivers/mtd/spi-nor/spi-nor.c @@ -2974,16 +2974,13 @@ static int spi_nor_spimem_check_pp(struct spi_nor *= nor, * spi_nor_spimem_adjust_hwcaps - Find optimal Read/Write protocol * based on SPI controller capabilities * @nor: pointer to a 'struct spi_nor' - * @params: pointer to the 'struct spi_nor_flash_parameter' - * representing SPI NOR flash capabilities * @hwcaps: pointer to resulting capabilities after adjusting * according to controller and flash's capability */ static void -spi_nor_spimem_adjust_hwcaps(struct spi_nor *nor, - const struct spi_nor_flash_parameter *params, - u32 *hwcaps) +spi_nor_spimem_adjust_hwcaps(struct spi_nor *nor, u32 *hwcaps) { + struct spi_nor_flash_parameter *params =3D &nor->params; unsigned int cap; =20 /* DTR modes are not supported yet, mask them all. */ @@ -4129,16 +4126,13 @@ static int spi_nor_parse_sfdp(struct spi_nor *nor, return err; } =20 -static int spi_nor_init_params(struct spi_nor *nor, - struct spi_nor_flash_parameter *params) +static int spi_nor_init_params(struct spi_nor *nor) { + struct spi_nor_flash_parameter *params =3D &nor->params; struct spi_nor_erase_map *map =3D &nor->erase_map; const struct flash_info *info =3D nor->info; u8 i, erase_mask; =20 - /* Set legacy flash parameters as default. */ - memset(params, 0, sizeof(*params)); - /* Set SPI NOR sizes. */ params->size =3D (u64)info->sector_size * info->n_sectors; params->page_size =3D info->page_size; @@ -4255,7 +4249,6 @@ static int spi_nor_init_params(struct spi_nor *nor, } =20 static int spi_nor_select_read(struct spi_nor *nor, - const struct spi_nor_flash_parameter *params, u32 shared_hwcaps) { int cmd, best_match =3D fls(shared_hwcaps & SNOR_HWCAPS_READ_MASK) - 1; @@ -4268,7 +4261,7 @@ static int spi_nor_select_read(struct spi_nor *nor, if (cmd < 0) return -EINVAL; =20 - read =3D ¶ms->reads[cmd]; + read =3D &nor->params.reads[cmd]; nor->read_opcode =3D read->opcode; nor->read_proto =3D read->proto; =20 @@ -4287,7 +4280,6 @@ static int spi_nor_select_read(struct spi_nor *nor, } =20 static int spi_nor_select_pp(struct spi_nor *nor, - const struct spi_nor_flash_parameter *params, u32 shared_hwcaps) { int cmd, best_match =3D fls(shared_hwcaps & SNOR_HWCAPS_PP_MASK) - 1; @@ -4300,7 +4292,7 @@ static int spi_nor_select_pp(struct spi_nor *nor, if (cmd < 0) return -EINVAL; =20 - pp =3D ¶ms->page_programs[cmd]; + pp =3D &nor->params.page_programs[cmd]; nor->program_opcode =3D pp->opcode; nor->write_proto =3D pp->proto; return 0; @@ -4407,9 +4399,9 @@ static int spi_nor_select_erase(struct spi_nor *nor, = u32 wanted_size) } =20 static int spi_nor_setup(struct spi_nor *nor, - const struct spi_nor_flash_parameter *params, const struct spi_nor_hwcaps *hwcaps) { + struct spi_nor_flash_parameter *params =3D &nor->params; u32 ignored_mask, shared_mask; bool enable_quad_io; int err; @@ -4426,7 +4418,7 @@ static int spi_nor_setup(struct spi_nor *nor, * need to discard some of them based on what the SPI * controller actually supports (using spi_mem_supports_op()). */ - spi_nor_spimem_adjust_hwcaps(nor, params, &shared_mask); + spi_nor_spimem_adjust_hwcaps(nor, &shared_mask); } else { /* * SPI n-n-n protocols are not supported when the SPI @@ -4442,7 +4434,7 @@ static int spi_nor_setup(struct spi_nor *nor, } =20 /* Select the (Fast) Read command. */ - err =3D spi_nor_select_read(nor, params, shared_mask); + err =3D spi_nor_select_read(nor, shared_mask); if (err) { dev_err(nor->dev, "can't select read settings supported by both the SPI controller and me= mory.\n"); @@ -4450,7 +4442,7 @@ static int spi_nor_setup(struct spi_nor *nor, } =20 /* Select the Page Program command. */ - err =3D spi_nor_select_pp(nor, params, shared_mask); + err =3D spi_nor_select_pp(nor, shared_mask); if (err) { dev_err(nor->dev, "can't select write settings supported by both the SPI controller and m= emory.\n"); @@ -4553,11 +4545,11 @@ static const struct flash_info *spi_nor_match_id(co= nst char *name) int spi_nor_scan(struct spi_nor *nor, const char *name, const struct spi_nor_hwcaps *hwcaps) { - struct spi_nor_flash_parameter params; const struct flash_info *info =3D NULL; struct device *dev =3D nor->dev; struct mtd_info *mtd =3D &nor->mtd; struct device_node *np =3D spi_nor_get_flash_node(nor); + struct spi_nor_flash_parameter *params =3D &nor->params; int ret; int i; =20 @@ -4639,7 +4631,7 @@ int spi_nor_scan(struct spi_nor *nor, const char *nam= e, nor->clear_sr_bp =3D spi_nor_clear_sr_bp; =20 /* Parse the Serial Flash Discoverable Parameters table. */ - ret =3D spi_nor_init_params(nor, ¶ms); + ret =3D spi_nor_init_params(nor); if (ret) return ret; =20 @@ -4649,7 +4641,7 @@ int spi_nor_scan(struct spi_nor *nor, const char *nam= e, mtd->type =3D MTD_NORFLASH; mtd->writesize =3D 1; mtd->flags =3D MTD_CAP_NORFLASH; - mtd->size =3D params.size; + mtd->size =3D params->size; mtd->_erase =3D spi_nor_erase; mtd->_read =3D spi_nor_read; mtd->_resume =3D spi_nor_resume; @@ -4688,18 +4680,18 @@ int spi_nor_scan(struct spi_nor *nor, const char *n= ame, mtd->flags |=3D MTD_NO_ERASE; =20 mtd->dev.parent =3D dev; - nor->page_size =3D params.page_size; + nor->page_size =3D params->page_size; mtd->writebufsize =3D nor->page_size; =20 if (np) { /* If we were instantiated by DT, use it */ if (of_property_read_bool(np, "m25p,fast-read")) - params.hwcaps.mask |=3D SNOR_HWCAPS_READ_FAST; + params->hwcaps.mask |=3D SNOR_HWCAPS_READ_FAST; else - params.hwcaps.mask &=3D ~SNOR_HWCAPS_READ_FAST; + params->hwcaps.mask &=3D ~SNOR_HWCAPS_READ_FAST; } else { /* If we weren't instantiated by DT, default to fast-read */ - params.hwcaps.mask |=3D SNOR_HWCAPS_READ_FAST; + params->hwcaps.mask |=3D SNOR_HWCAPS_READ_FAST; } =20 if (of_property_read_bool(np, "broken-flash-reset")) @@ -4707,7 +4699,7 @@ int spi_nor_scan(struct spi_nor *nor, const char *nam= e, =20 /* Some devices cannot do fast-read, no matter what DT tells us */ if (info->flags & SPI_NOR_NO_FR) - params.hwcaps.mask &=3D ~SNOR_HWCAPS_READ_FAST; + params->hwcaps.mask &=3D ~SNOR_HWCAPS_READ_FAST; =20 /* * Configure the SPI memory: @@ -4716,7 +4708,7 @@ int spi_nor_scan(struct spi_nor *nor, const char *nam= e, * - set the SPI protocols for register and memory accesses. * - set the Quad Enable bit if needed (required by SPI x-y-4 protos). */ - ret =3D spi_nor_setup(nor, ¶ms, hwcaps); + ret =3D spi_nor_setup(nor, hwcaps); if (ret) return ret; =20 --=20 2.9.5