Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp3394059pxb; Mon, 30 Aug 2021 00:36:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxcCoCebS2uxxGcO7oc0+K6ciHGjCxcgjvUx3bEYEBpDgyxTjghJYobcoy8Ibp2zslds8z0 X-Received: by 2002:a17:906:d04d:: with SMTP id bo13mr24357001ejb.351.1630308963541; Mon, 30 Aug 2021 00:36:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630308963; cv=none; d=google.com; s=arc-20160816; b=iOkz81BTGnrngj8uG4swqpqScF2n9+t8DslWHKpXVYSR0Ll7waOQVn29LrQRwnlXtz qwR6yjAD/dl/eTZeUZgcRT/fmbCPALxRA3r7IS+Q3bQuHoWPTbWxRpaRTK+eJUVHYD6s 9603AZvXrCscRQ4C3ccT1BBINtBoytZ3/Z/TV8qP6Q4jepRIpbW8fVELGaMdsYYNZ5NA sugbu7Xc40BaMxuTUefGgD6QrAIbSnffoPC7zl876Vl/cTZb4Y0+h4JLd6sOE8oGEndL NrJDR9ytgQyY74Y8vHzOAUou5MCEsy4BdwNrO7p9FJ5Ra4O77AuHJ1ZkbK1ZmVNQRqjO eGTQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=xIhb2Ds6MFMkxjqPtaOtTzzwUnAe7e7xvIAI58hQ+yg=; b=ZYiiMc6vypfz3L7qF6oG4RuSmqRv/qYrdVJaPcoSwJVqSInhqNJbMqaM04fSSNG/7m Tt0xLvtaJJi4alXOlVO3QKFXxjEgrNtBNr51g+15y39WjoGoPzpX/7QrglpBhSk9r9b1 WRE75ShstLIA963reZDWt+p/GrhQ4g8MjoZZYm8zqOd66+ExljSEk/1lUXHYsrbQWlCO OkSGGHkkECg765Dr798JVGpkQFxG67mGAhB4ix64G4WcVndAnU0RbVIt1DAGJg2F0cYq ZQtvXz4dkomJaDzK2Bg5KtoCLYlG6u0EQw40o3D99TG5nB41CD8qxtYggxQoE6lJp2MW 8vgw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@fris.de header.s=dkim header.b=DDivLjq+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=fris.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bl2si14589147ejb.55.2021.08.30.00.35.39; Mon, 30 Aug 2021 00:36:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@fris.de header.s=dkim header.b=DDivLjq+; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=fris.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233830AbhH3Hcn (ORCPT + 99 others); Mon, 30 Aug 2021 03:32:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36314 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233109AbhH3Hca (ORCPT ); Mon, 30 Aug 2021 03:32:30 -0400 X-Greylist: delayed 496 seconds by postgrey-1.37 at lindbergh.monkeyblade.net; Mon, 30 Aug 2021 00:31:37 PDT Received: from mail.fris.de (mail.fris.de [IPv6:2a01:4f8:c2c:390b::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C50D3C061575; Mon, 30 Aug 2021 00:31:37 -0700 (PDT) Received: from [127.0.0.1] (localhost [127.0.0.1]) by localhost (Mailerdaemon) with ESMTPSA id EE655BFBD1; Mon, 30 Aug 2021 09:23:16 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fris.de; s=dkim; t=1630308197; h=from:subject:date:message-id:to:cc:mime-version: content-transfer-encoding; bh=xIhb2Ds6MFMkxjqPtaOtTzzwUnAe7e7xvIAI58hQ+yg=; b=DDivLjq+bOlvSpVO8vG/ADNmBIO0xdUGwkY9az5bEiGv37TgVPXttzxYsCpePhc7ZnW2Gr zqFInNaCeQpvjLUBHLLLyIVgSThGd/kkqqkOnhaKUmE+9R1vYLZgzfpSCmUmTTrB/STx2d yYzeYCXkwWjKhQzYEKyzk0ecEl/RPo+Jqclb9MpjZG4DQQbVxXbP6hkyIewYT99Gt+w+t+ mtmw1KLxGMBmL8t2Y7L4En99+ReqziXd2/y1zY0WtlPBtCMpvKXjhsmlp2KxuAg/EuYsfZ oXEi09gXNHFzB32ARN0Ml6rseRgCz+gXtPCCFuOc+9yMRjpz0bCUl6oSCYIydA== From: Frieder Schrempf To: Miquel Raynal Cc: Frieder Schrempf , stable@vger.kernel.org, voice INTER connect GmbH , Alexander Lobakin , Felix Fietkau , Greg Kroah-Hartman , linux-kernel@vger.kernel.org, linux-mtd@lists.infradead.org, Richard Weinberger , YouChing Lin Subject: [RESEND PATCH 5.10.x] mtd: spinand: Fix incorrect parameters for on-die ECC Date: Mon, 30 Aug 2021 09:21:07 +0200 Message-Id: <20210830072108.13770-1-frieder@fris.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Last-TLS-Session-Version: TLSv1.3 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Frieder Schrempf The new generic NAND ECC framework stores the configuration and requirements in separate places since commit 93ef92f6f422 (" mtd: nand: Use the new generic ECC object "). In 5.10.x The SPI NAND layer still uses only the requirements to track the ECC properties. This mismatch leads to values of zero being used for ECC strength and step_size in the SPI NAND layer wherever nanddev_get_ecc_conf() is used and therefore breaks the SPI NAND on-die ECC support in 5.10.x. By using nanddev_get_ecc_requirements() instead of nanddev_get_ecc_conf() for SPI NAND, we make sure that the correct parameters for the detected chip are used. In later versions (5.11.x) this is fixed anyway with the implementation of the SPI NAND on-die ECC engine. Cc: stable@vger.kernel.org # 5.10.x Reported-by: voice INTER connect GmbH Signed-off-by: Frieder Schrempf --- Resending this with an improved subject prefix and because the previous mail wasn't delivered to some of the lists. --- drivers/mtd/nand/spi/core.c | 6 +++--- drivers/mtd/nand/spi/macronix.c | 6 +++--- drivers/mtd/nand/spi/toshiba.c | 6 +++--- 3 files changed, 9 insertions(+), 9 deletions(-) diff --git a/drivers/mtd/nand/spi/core.c b/drivers/mtd/nand/spi/core.c index 558d8a14810b..8794a1f6eacd 100644 --- a/drivers/mtd/nand/spi/core.c +++ b/drivers/mtd/nand/spi/core.c @@ -419,7 +419,7 @@ static int spinand_check_ecc_status(struct spinand_device *spinand, u8 status) * fixed, so let's return the maximum possible value so that * wear-leveling layers move the data immediately. */ - return nanddev_get_ecc_conf(nand)->strength; + return nanddev_get_ecc_requirements(nand)->strength; case STATUS_ECC_UNCOR_ERROR: return -EBADMSG; @@ -1090,8 +1090,8 @@ static int spinand_init(struct spinand_device *spinand) mtd->oobavail = ret; /* Propagate ECC information to mtd_info */ - mtd->ecc_strength = nanddev_get_ecc_conf(nand)->strength; - mtd->ecc_step_size = nanddev_get_ecc_conf(nand)->step_size; + mtd->ecc_strength = nanddev_get_ecc_requirements(nand)->strength; + mtd->ecc_step_size = nanddev_get_ecc_requirements(nand)->step_size; return 0; diff --git a/drivers/mtd/nand/spi/macronix.c b/drivers/mtd/nand/spi/macronix.c index 8e801e4c3a00..cd7a9cacc3fb 100644 --- a/drivers/mtd/nand/spi/macronix.c +++ b/drivers/mtd/nand/spi/macronix.c @@ -84,11 +84,11 @@ static int mx35lf1ge4ab_ecc_get_status(struct spinand_device *spinand, * data around if it's not necessary. */ if (mx35lf1ge4ab_get_eccsr(spinand, &eccsr)) - return nanddev_get_ecc_conf(nand)->strength; + return nanddev_get_ecc_requirements(nand)->strength; - if (WARN_ON(eccsr > nanddev_get_ecc_conf(nand)->strength || + if (WARN_ON(eccsr > nanddev_get_ecc_requirements(nand)->strength || !eccsr)) - return nanddev_get_ecc_conf(nand)->strength; + return nanddev_get_ecc_requirements(nand)->strength; return eccsr; diff --git a/drivers/mtd/nand/spi/toshiba.c b/drivers/mtd/nand/spi/toshiba.c index 21fde2875674..6fe7bd2a94d2 100644 --- a/drivers/mtd/nand/spi/toshiba.c +++ b/drivers/mtd/nand/spi/toshiba.c @@ -90,12 +90,12 @@ static int tx58cxgxsxraix_ecc_get_status(struct spinand_device *spinand, * data around if it's not necessary. */ if (spi_mem_exec_op(spinand->spimem, &op)) - return nanddev_get_ecc_conf(nand)->strength; + return nanddev_get_ecc_requirements(nand)->strength; mbf >>= 4; - if (WARN_ON(mbf > nanddev_get_ecc_conf(nand)->strength || !mbf)) - return nanddev_get_ecc_conf(nand)->strength; + if (WARN_ON(mbf > nanddev_get_ecc_requirements(nand)->strength || !mbf)) + return nanddev_get_ecc_requirements(nand)->strength; return mbf; -- 2.32.0