Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp1815105pxb; Mon, 11 Oct 2021 13:48:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwh2iqU4U9NQFi835A6YCAqOs666gtjaeC1QajEQjj2S+yX/SENdkEbF+MTTEDRIt+My9dA X-Received: by 2002:a17:906:4f8c:: with SMTP id o12mr7722844eju.115.1633985334354; Mon, 11 Oct 2021 13:48:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633985334; cv=none; d=google.com; s=arc-20160816; b=PzxCD+mtQTkD4V4wQSKjI0My2uEGIts3SX+prWvSrG94WmHSSf1MV77XvmVF/8iMXq XqXqCpMrfMYQNvunyp4dim1SB97EF7X9lo/zpcvsZzjSQioZ/Fg0x3bCsFY6uKZ15GyE EWt4JwJc1gn5bPeasZzPkkZQF64jE8Bg1XJKPB1CQxTZ8zc0S3gAONx43RLeAKJlCaFU qJhdj8hOjMxxStwHpiO8yBprJaAiRO5bx1NNVWcS0/wowR8W7VzhcdOWibjj+Mj9VB20 LCRP1/6g7gzgNlI3Cpp7YfegPdBAEQvV7huCzEE/hPEYtV6PMcz85Bb697luzXVu0asj do1Q== 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=aREyONMOYnqRN8v42O2++VQ4QoXlpiSb4xj0cGMxL0U=; b=tFao9DiJxJPQT3iXfk3DylAFtPB5ZSF/lzexKj2y8UirN4JPGQMIo7VW5mCMNhTdic uY1zIrZJFUdoGm82vHbZ74cOb2HxM8OxL1Zuysr8IMeC9adKnyUSeR+gPcGXAk19rDMO U+zNFn4+Kg6sgSJoVN47T8fYMEAiGDnzF1iUT4T3l8EeEeTp73E7DfdIFmKj3Oyc6Gcm Gl55sQd/5WN8dWux2qogVIJM+tdn7MADnGbwS5eg8WDrxsRoAfnCYyS/qeaWEUn5hi54 s8YXzNhlbuzAM/RbLkMgbPNyjf2zMBR4e9mFWrKzteivUM/xqEjSTEwmC2+SxKkB6xSw 05Cg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=XzwSqtA7; 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=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id sb28si18309675ejc.136.2021.10.11.13.48.30; Mon, 11 Oct 2021 13:48:54 -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=@ti.com header.s=ti-com-17Q1 header.b=XzwSqtA7; 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=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234980AbhJKUsr (ORCPT + 99 others); Mon, 11 Oct 2021 16:48:47 -0400 Received: from fllv0016.ext.ti.com ([198.47.19.142]:51000 "EHLO fllv0016.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234918AbhJKUsq (ORCPT ); Mon, 11 Oct 2021 16:48:46 -0400 Received: from lelv0266.itg.ti.com ([10.180.67.225]) by fllv0016.ext.ti.com (8.15.2/8.15.2) with ESMTP id 19BKkRYX058438; Mon, 11 Oct 2021 15:46:27 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1633985187; bh=aREyONMOYnqRN8v42O2++VQ4QoXlpiSb4xj0cGMxL0U=; h=From:To:CC:Subject:Date; b=XzwSqtA7XhUvLhbISa+tUaTG5Ll0BqlsAkgQzJibz7r4dM5tYKnptnHcTBfB1XpQd ihj8nNbkPCiCx633voyYjudC1q3sg6QHuLh7tuK4U3wg1GAHWl72yKZ25VfNmoHLV8 fs0M/5ILEQaf8WZarUu17WCHa3sAsLXe22MIf+F4= Received: from DFLE100.ent.ti.com (dfle100.ent.ti.com [10.64.6.21]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 19BKkRbK104929 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Mon, 11 Oct 2021 15:46:27 -0500 Received: from DFLE105.ent.ti.com (10.64.6.26) by DFLE100.ent.ti.com (10.64.6.21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2308.14; Mon, 11 Oct 2021 15:46:26 -0500 Received: from lelv0326.itg.ti.com (10.180.67.84) by DFLE105.ent.ti.com (10.64.6.26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2308.14 via Frontend Transport; Mon, 11 Oct 2021 15:46:26 -0500 Received: from LT5CD112GSQZ.dhcp.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by lelv0326.itg.ti.com (8.15.2/8.15.2) with ESMTP id 19BKkKEe069811; Mon, 11 Oct 2021 15:46:21 -0500 From: Apurva Nandan To: Miquel Raynal , Richard Weinberger , Vignesh Raghavendra , Mark Brown , Apurva Nandan , Patrice Chotard , Christophe Kerello , Boris Brezillon , , , CC: Subject: [PATCH v2 00/14] mtd: spinand: Add Octal DTR SPI (8D-8D-8D) mode support Date: Tue, 12 Oct 2021 02:16:05 +0530 Message-ID: <20211011204619.81893-1-a-nandan@ti.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, This series proposes patches for adding the following functionality in SPI NAND core: - Octal DTR SPI (8D-8D-8D) mode support - Winbond W35N01JW SPI NAND chip support - Power-on-Reset instruction support This series has been tested on TI J721e EVM with the Winbond W35N01JW flash with following test utilities: - nandtest Test log: https://textbin.net/raw/fhypoz63f9 - mtd_stresstest Test log: https://textbin.net/raw/0xqjmqntj7 - UBIFS LTP stress test (NAND_XL_STRESS_DD_RW_UBIFS). Test log: https://textbin.net/raw/pyokws7wku Datasheet: https://www.winbond.com/export/sites/winbond/datasheet/W35N01JW_Datasheet_Brief.pdf --- Changes in v2: - Removed *_ALL_ARGS() macros from spi-mem.h, and redefined DTR macros. - Renamed spinand_setup_op() to spinand_patch_op(). Reduced one conditional check from this function. Had to keep tweaking in hot-path to avoid complicated implementation "hacks". - Changes in commit messages and added comments. - Dropped "Reject 8D-8D-8D op_templates if octal_dtr_enale() is missing in manufacturer_op" patch. - Reduced PoR reset delay. - Splitted "mtd: spinand: Add support for Winbond W35N01JW SPI NAND flash" into 3 independent patches. Apurva Nandan (14): spi: spi-mem: Add DTR templates for cmd, address, dummy and data phase mtd: spinand: Add enum spinand_proto to indicate current SPI IO mode mtd: spinand: Patch spi_mem_op for the SPI IO protocol using reg_proto mtd: spinand: Fix odd byte addr and data phase in read and write reg op for Octal DTR mode mtd: spinand: Add adjust_op() in manufacturer_ops to modify the ops for manufacturer specific changes mtd: spinand: Add macros for Octal DTR page read and write operations mtd: spinand: Allow enabling Octal DTR mode in the core mtd: spinand: winbond: Add support for write volatile configuration register op mtd: spinand: winbond: Add octal_dtr_enable() for manufacturer_ops mtd: spinand: Add support for Power-on-Reset (PoR) instruction mtd: spinand: Perform Power-on-Reset on the flash in mtd_suspend() mtd: spinand: Add adjust_op() in Winbond manufacturer_ops mtd: spinand: winbond: Rename cache op_variants struct variable mtd: spinand: winbond: Add support for Winbond W35N01JW SPI NAND flash drivers/mtd/nand/spi/core.c | 187 +++++++++++++++++++++++++++++- drivers/mtd/nand/spi/winbond.c | 200 +++++++++++++++++++++++++++++++-- include/linux/mtd/spinand.h | 67 +++++++++++ include/linux/spi/spi-mem.h | 41 +++++++ 4 files changed, 484 insertions(+), 11 deletions(-) -- 2.25.1