Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp473368ybz; Wed, 29 Apr 2020 03:45:20 -0700 (PDT) X-Google-Smtp-Source: APiQypKHTo151HfVZcJYVQFz0Jt7/B1k63nP7igtcDJtlkkZPUr4zHP2RofOqsoegLPXCSu2T9f0 X-Received: by 2002:a05:6402:1b08:: with SMTP id by8mr1763656edb.286.1588157119960; Wed, 29 Apr 2020 03:45:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588157119; cv=none; d=google.com; s=arc-20160816; b=YWYIE0XDnpcaU+XdSx3FB1L4F+RW4n8YKwqdKZNbnbuDNjsPilviy6iV3r/hRZIyrf xZ4yIN85EoiuPmT9dXPFUmBQfVuAgxKnzW/hhzs+H/hDQcYfOLmWY0MVRn+f3EgktLXf 7BScfq0hYC5BXtDqOUs+uljLRQatf4bv0ncR9nK3inv8Tji07v5GQxAgENw4cKWQW4jU xAVLFdzWHQeKbGa1vViWyyG+8eXumUuF3KOPtJI3od5dh/VXSHmfeFzDaI8vHs81qH5J bf4TjnRkaKwyfXkEGPRZFqXqji+T9Gf0Ur+MYYnKYYmwaqvv4crAQa9IeZDzSyH2SFjf nLbw== 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=Kcz2x4aICH6bULou4l/O3QOkrpFei5Wzy3vc8qWpJ6s=; b=HieseHzFbZYpaBeM0KJjt6fmMI4GS957Nb83pDXxgjdiCQamtwm6sOqSTOZj7H5XKh sdqyRKU8wp2lQUYaLwn1bDcknmAcAWtQmM6fO3F+VSx97V49TI/ciUuRSECnrKCUfpXg 69k3CxQiwfnCCk7EShGJGJDXUKC2PSivGwpnQVyLJEHpzSrDH4kW3KhvT2EsHl67QLoW GyMJEwsBBxxCNu6AvhriYNae5af8vcpYE56UgwhguKS9TelOheLvSnUmy9D4o8YU8spU 8d4PqfE7XtIFn4Ybu1bhZxy4+Oj2exPvxCX9kbUcMc4p8mZZ0OI6wUQTEfQjR3xtvG1H rUZg== 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 h2si3867186ejc.510.2020.04.29.03.44.56; Wed, 29 Apr 2020 03:45:19 -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 S1726844AbgD2KnM (ORCPT + 99 others); Wed, 29 Apr 2020 06:43:12 -0400 Received: from mga05.intel.com ([192.55.52.43]:31837 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726686AbgD2KnL (ORCPT ); Wed, 29 Apr 2020 06:43:11 -0400 IronPort-SDR: iOvZuyU6q4rhjOL6OmyqqkSg85M0ABdYpfB4gGvMWNDsVfhk/vm8LTmedcBZ9Ur1ze+E7SP7Ka xRC6tMD7PRvQ== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 29 Apr 2020 03:43:11 -0700 IronPort-SDR: 9Jx9NwxNY2JPoS2yf+EjHFue3aobICBG/OyEM1nzA4wtu4at6wbq7pMXDODz2bBcuydgXueJ1D /atmhjTv5l+A== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.73,331,1583222400"; d="scan'208";a="257924250" Received: from sgsxdev004.isng.intel.com (HELO localhost) ([10.226.88.13]) by orsmga003.jf.intel.com with ESMTP; 29 Apr 2020 03:43:06 -0700 From: "Ramuthevar,Vadivel MuruganX" To: linux-kernel@vger.kernel.org, linux-mtd@lists.infradead.org, devicetree@vger.kernel.org Cc: miquel.raynal@bootlin.com, 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 Murugan Subject: [PATCH v4 0/2] mtd: rawnand: Add NAND controller support on Intel LGM SoC Date: Wed, 29 Apr 2020 18:42:03 +0800 Message-Id: <20200429104205.18780-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 From: Ramuthevar Vadivel Murugan 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. Thank you very much Boris, Miquel and Hauke for the reviews and suggestions. --- 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 - YAML compatible string update to intel, lgm-nand-controller - add MIPS maintainers and xway_nand driver author in CC v1: - initial version Ramuthevar Vadivel Murugan (2): dt-bindings: mtd: Add YAML for Nand Flash Controller support mtd: rawnand: Add NAND controller support on Intel LGM SoC .../devicetree/bindings/mtd/intel,lgm-nand.yaml | 61 ++ drivers/mtd/nand/raw/Kconfig | 8 + drivers/mtd/nand/raw/Makefile | 1 + drivers/mtd/nand/raw/intel-nand-controller.c | 750 +++++++++++++++++++++ 4 files changed, 820 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