Received: by 2002:a25:ef43:0:0:0:0:0 with SMTP id w3csp529704ybm; Thu, 28 May 2020 08:43:18 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzSedo1kBYT76cu2t4TTpYtAWomYIuLi3/JKS8k21md4/ORSbCQYywH7/EjJRNKlbssGQ+P X-Received: by 2002:a17:906:f74c:: with SMTP id jp12mr3748160ejb.490.1590680598492; Thu, 28 May 2020 08:43:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590680598; cv=none; d=google.com; s=arc-20160816; b=Lrxh4SLKhOdaZBSAkmiIlXw3BPSmG+FxNxCKStQS+gj+T/8XxU3p8H/p8+veZA9rFX wq4fxIip0q27Djjenzc4p8By3D/MWLUv2UCeidsM1/LZEtl5FVuVOTw88Setie6ao+gh 7x3+c/ojiH+hMXAFteIFIDWUWHfQb2TaHtjzWMf4h1JySWqmv/gR2vDKGuq59GDlDFI+ 0HTbtTZKQbSOHey/1REqPwctdGwf/fDNbfmA1a/sEslYJcnFvO8JSg5a7yL7FA/kRaOA XI+QLBY+/KVgsPuz6KLkONHob9OviAZDrnfoIijopSCXgrhFVH/5IDgzUF2eMkB8VDsN v7Iw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=OJL/H8V0L97nO00A/RRS+QfN/Cgcfdv/25BhhC7gTJU=; b=iMTywgyUvyVaZWI7GeqJMh7FqcF9NEeJTB++DY8TWeFQJ7LUHIjH2OMuiZWwDVm4/7 uPe7NzlRLNeGoWJ/x1vCEKmc06lIuNYd3V4dNuexr2ofWpZ7yzqFJWX82xf8OZ0rh93P MWRVCxtSvX8HY4tCMovXGEuzZk2145YfPE9Qcj/Lc5PAYt1sklPGM3dVlqd0dDcaqmuP +IMHPFy054TooHwA9YG9ZElHK7oTkZ6qlvo+Inl69zmrSV2mhB4R43wqlzr54al5CX00 uLPOiTWhkfBx4doJQA0oJZQbP1vzsI+u2PVLE1Px6s4654qk3XoM/J999LubFjDg32Bi z9mw== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u1si1576108ejt.432.2020.05.28.08.42.55; Thu, 28 May 2020 08:43:18 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2404545AbgE1PlA (ORCPT + 99 others); Thu, 28 May 2020 11:41:00 -0400 Received: from mga06.intel.com ([134.134.136.31]:54841 "EHLO mga06.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2404538AbgE1Pk6 (ORCPT ); Thu, 28 May 2020 11:40:58 -0400 IronPort-SDR: PqtUecNVM4VdFkQCbT9kfFXkM0qpgoAnLsa+tCB5lpzEno+KtkYjSTW+e08Yusz8e7saUOV2zQ E7RRVRoa5p7g== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga007.jf.intel.com ([10.7.209.58]) by orsmga104.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 28 May 2020 08:40:55 -0700 IronPort-SDR: t3jJpTLklTUfu9+PbASaz3ZHWDvl+/mHzqyV1ImCImAJtS4wrGRZvj4ZirXckChfNZrYTAQA4v yoF9teUTPweA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.73,445,1583222400"; d="scan'208";a="256199245" Received: from sgsxdev004.isng.intel.com (HELO localhost) ([10.226.88.13]) by orsmga007.jf.intel.com with ESMTP; 28 May 2020 08:40:50 -0700 From: "Ramuthevar,Vadivel MuruganX" To: linux-kernel@vger.kernel.org, linux-mtd@lists.infradead.org, devicetree@vger.kernel.org, miquel.raynal@bootlin.com Cc: richard@nod.at, vigneshr@ti.com, arnd@arndb.de, brendanhiggins@google.com, tglx@linutronix.de, boris.brezillon@collabora.com, anders.roxell@linaro.org, masonccyang@mxic.com.tw, robh+dt@kernel.org, linux-mips@vger.kernel.org, hauke.mehrtens@intel.com, andriy.shevchenko@intel.com, qi-ming.wu@intel.com, cheol.yong.kim@intel.com, "Ramuthevar,Vadivel MuruganX" Subject: [PATCH v10 0/2] mtd: rawnand: Add NAND controller support on Intel LGM SoC Date: Thu, 28 May 2020 23:39:27 +0800 Message-Id: <20200528153929.46859-1-vadivel.muruganx.ramuthevar@linux.intel.com> X-Mailer: git-send-email 2.11.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch adds the new IP of Nand Flash Controller(NFC) support on Intel's Lightning Mountain(LGM) SoC. DMA is used for burst data transfer operation, also DMA HW supports aligned 32bit memory address and aligned data access by default. DMA burst of 8 supported. Data register used to support the read/write operation from/to device. NAND controller also supports in-built HW ECC engine. NAND controller driver implements ->exec_op() to replace legacy hooks, these specific call-back method to execute NAND operations. Thanks Boris, Andy, Arnd and Rob for the review comments and suggestions. --- v10: - No Change v9: - No change v8: - fix the kbuild bot warnings - correct the typo's v7: - indentation issue is fixed - add error check for retrieve the resource from dt v6: - update EBU_ADDR_SELx register base value build it from DT - Add tabs in in Kconfig v5: - replace by 'HSNAND_CLE_OFFS | HSNAND_CS_OFFS' to NAND_WRITE_CMD and NAND_WRITE_ADDR - remove the unused macros - update EBU_ADDR_MASK(x) macro - update the EBU_ADDR_SELx register values to be written v4: - add ebu_nand_cs structure for multiple-CS support - mask/offset encoding for 0x51 value - update macro HSNAND_CTL_ENABLE_ECC - drop the op argument and un-used macros. - updated the datatype and macros - add function disable nand module - remove ebu_host->dma_rx = NULL; - rename MMIO address range variables to ebu and hsnand - implement ->setup_data_interface() - update label err_cleanup_nand and err_cleanup_dma - add return value check in the nand_remove function - add/remove tabs and spaces as per coding standard - encoded CS ids by reg property v3: - Add depends on MACRO in Kconfig - file name update in Makefile - file name update to intel-nand-controller - modification of MACRO divided like EBU, HSNAND and NAND - add NAND_ALE_OFFS, NAND_CLE_OFFS and NAND_CS_OFFS - rename lgm_ to ebu_ and _va suffix is removed in the whole file - rename structure and varaibles as per review comments. - remove lgm_read_byte(), lgm_dev_ready() and cmd_ctrl() un-used function - update in exec_op() as per review comments - rename function lgm_dma_exit() by lgm_dma_cleanup() - hardcoded magic value for base and offset replaced by MACRO defined - mtd_device_unregister() + nand_cleanup() instead of nand_release() v2: - implement the ->exec_op() to replaces the legacy hook-up. - update the commit message - add MIPS maintainers and xway_nand driver author in CC v1: - initial version dt-bindings: mtd: Add Nand Flash Controller support for Intel LGM SoC --- v10: - fix bot errors v9: - Rob's review comments address - dual licensed - compatible change - add reg-names - drop clock-names and clock-cells - correct typo's v8: No change v7: - Rob's review comments addressed - dt-schema build issue fixed with upgraded dt-schema v6: - Rob's review comments addressed in YAML file - add addr_sel0 and addr_sel1 reg-names in YAML example v5: - add the example in YAML file v4: - No change v3: - No change v2: YAML compatible string update to intel, lgm-nand-controller v1: - initial version Ramuthevar Vadivel Murugan (2): dt-bindings: mtd: Add Nand Flash Controller support for Intel LGM SoC mtd: rawnand: Add NAND controller support on Intel LGM SoC .../devicetree/bindings/mtd/intel,lgm-nand.yaml | 93 +++ drivers/mtd/nand/raw/Kconfig | 8 + drivers/mtd/nand/raw/Makefile | 1 + drivers/mtd/nand/raw/intel-nand-controller.c | 747 +++++++++++++++++++++ 4 files changed, 849 insertions(+) create mode 100644 Documentation/devicetree/bindings/mtd/intel,lgm-nand.yaml create mode 100644 drivers/mtd/nand/raw/intel-nand-controller.c -- 2.11.0