Received: by 2002:a25:ef43:0:0:0:0:0 with SMTP id w3csp321538ybm; Fri, 29 May 2020 00:40:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJypKmuIf7IuwtiSNA1c0j1S2hlQvksrKUh4c6FJs6X5vhIPoCJ98fd3fo0i0pTvOks4tszk X-Received: by 2002:a17:906:7e56:: with SMTP id z22mr6293922ejr.60.1590738017634; Fri, 29 May 2020 00:40:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590738017; cv=none; d=google.com; s=arc-20160816; b=GevVEZnNZEkfLeeQVkazQuskdQtagAzt/QF1cCVF8YLhVMlfQbH8ilx6xl+vEY7JQU GHGHHs+0qrHXDHy5S7L1XI6MfeD/Dbz0M0ALZEDeRokaa5kdmvkEQCPn3FKk2GFq3i90 9v4sNTGGOtuftAu1Hd5u869G0COnMgSI5Fm75UcFBZ0316TA/USVZh4oYRKz/Qkl1pj4 tgZKQ9hRb/28A1A6sjR66CgBszZsBXYHbzd5zkLJ8sl22zGbahQZnrtldlyuwFr5jpwn FBlzm6nZrSaVTv5l4pxk2MZ3jzRiAv5aSNQgTAqdXQS7FNC0m5d4TMhdTfsGRkd0V1av fkfA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=DL7NVDy0eAyHAjUpsyCpqeKmtn+tgtf7F+fh7GRH9ls=; b=FNQPBgz9r6I8jHJKsbvHG0XdGRDjqYZWeSK+I0g2VFDrROtRJO+zgtVPDOE9h2ureQ 6dYXPTrUXKFZkpUAUM68OuKVSRLUr5FE/ShbM0fw5bp8b3LIY5wuiO+/cSdQpFPuFOsM dA7Sh3tc1sk7CkHElYq2jBX3H1vSSXOKLSKwRRFjh0mxEqmWcLSWxUaozBQZtOxo/Ytt dh+WhdvkNSBR4VbCLUN4qlBrpNAH30T7aJcqaiWqpXkFcK3io+RZI1zkRHtiK2iKc41k UfpJw7s3McDsryDWbE8oOxnbkRq1f/Y8vdK39hjwdKT1iWRO4+L64N7J16/nAjqa6QUB RYTQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w8si598946ejb.473.2020.05.29.00.39.54; Fri, 29 May 2020 00:40:17 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726735AbgE2Hg6 (ORCPT + 99 others); Fri, 29 May 2020 03:36:58 -0400 Received: from twhmllg4.macronix.com ([211.75.127.132]:24680 "EHLO TWHMLLG4.macronix.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726701AbgE2Hg4 (ORCPT ); Fri, 29 May 2020 03:36:56 -0400 Received: from localhost.localdomain ([172.17.195.96]) by TWHMLLG4.macronix.com with ESMTP id 04T7aHq3067318; Fri, 29 May 2020 15:36:23 +0800 (GMT-8) (envelope-from masonccyang@mxic.com.tw) From: Mason Yang To: broonie@kernel.org, tudor.ambarus@microchip.com, miquel.raynal@bootlin.com, richard@nod.at, vigneshr@ti.com, boris.brezillon@collabora.com, matthias.bgg@gmail.com Cc: p.yadav@ti.com, juliensu@mxic.com.tw, linux-kernel@vger.kernel.org, linux-mtd@lists.infradead.org, linux-spi@vger.kernel.org, Mason Yang Subject: [PATCH v4 7/7] mtd: spi-nor: macronix: Add Octal 8D-8D-8D supports for Macronix mx25uw51245g Date: Fri, 29 May 2020 15:36:15 +0800 Message-Id: <1590737775-4798-8-git-send-email-masonccyang@mxic.com.tw> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1590737775-4798-1-git-send-email-masonccyang@mxic.com.tw> References: <1590737775-4798-1-git-send-email-masonccyang@mxic.com.tw> X-MAIL: TWHMLLG4.macronix.com 04T7aHq3067318 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Macronix mx25uw51245g is a SPI NOR that supports 1-1-1/8-8-8 mode. Correct the dummy cycles to device for various frequencies after xSPI profile 1.0 table parsed. Enable mx25uw51245g to Octal DTR mode by executing the command sequences to change to octal DTR mode. Signed-off-by: Mason Yang --- drivers/mtd/spi-nor/macronix.c | 55 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) diff --git a/drivers/mtd/spi-nor/macronix.c b/drivers/mtd/spi-nor/macronix.c index 96735d8..6c9a24c 100644 --- a/drivers/mtd/spi-nor/macronix.c +++ b/drivers/mtd/spi-nor/macronix.c @@ -8,6 +8,57 @@ #include "core.h" +#define MXIC_CR2_DUMMY_SET_ADDR 0x300 + +/* Fixup the dummy cycles to device and setup octa_dtr_enable() */ +static void mx25uw51245g_post_sfdp_fixups(struct spi_nor *nor) +{ + struct spi_nor_flash_parameter *params = nor->params; + int ret; + u8 rdc, wdc; + + ret = spi_nor_read_cr2(nor, MXIC_CR2_DUMMY_SET_ADDR, &rdc); + if (ret) + return; + + /* Refer to dummy cycle and frequency table(MHz) */ + switch (params->dummy_cycles) { + case 10: /* 10 dummy cycles for 104 MHz */ + wdc = 5; + break; + case 12: /* 12 dummy cycles for 133 MHz */ + wdc = 4; + break; + case 16: /* 16 dummy cycles for 166 MHz */ + wdc = 2; + break; + case 18: /* 18 dummy cycles for 173 MHz */ + wdc = 1; + break; + case 20: /* 20 dummy cycles for 200 MHz */ + default: + wdc = 0; + } + + if (rdc != wdc) + spi_nor_write_cr2(nor, MXIC_CR2_DUMMY_SET_ADDR, &wdc); + + if (params->cmd_seq[0].len) { + params->octal_dtr_enable = spi_nor_cmd_seq_octal_dtr; + params->hwcaps.mask |= SNOR_HWCAPS_READ_8_8_8_DTR; + params->hwcaps.mask |= SNOR_HWCAPS_PP_8_8_8_DTR; + + } else { + params->octal_dtr_enable = NULL; + params->hwcaps.mask &= ~SNOR_HWCAPS_READ_8_8_8_DTR; + params->hwcaps.mask &= ~SNOR_HWCAPS_PP_8_8_8_DTR; + } +} + +static struct spi_nor_fixups mx25uw51245g_fixups = { + .post_sfdp = mx25uw51245g_post_sfdp_fixups, +}; + static int mx25l25635_post_bfpt_fixups(struct spi_nor *nor, const struct sfdp_parameter_header *bfpt_header, @@ -84,6 +135,10 @@ SPI_NOR_QUAD_READ) }, { "mx66l1g55g", INFO(0xc2261b, 0, 64 * 1024, 2048, SPI_NOR_QUAD_READ) }, + { "mx25uw51245g", INFO(0xc2813a, 0, 64 * 1024, 1024, + SECT_4K | SPI_NOR_4B_OPCODES | + SPI_NOR_OCTAL_DTR_READ) + .fixups = &mx25uw51245g_fixups }, }; static void macronix_default_init(struct spi_nor *nor) -- 1.9.1