Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp1144724imw; Wed, 13 Jul 2022 14:36:45 -0700 (PDT) X-Google-Smtp-Source: AGRyM1sB8RpOrIfKZmqgmXUsO3u7UUE6y7tVH49CMfIGl5KanrHjPYp1iDJI8ROU/6jhJD7ZBkTl X-Received: by 2002:a05:6402:4c3:b0:43a:f612:179d with SMTP id n3-20020a05640204c300b0043af612179dmr7895981edw.422.1657748204899; Wed, 13 Jul 2022 14:36:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657748204; cv=none; d=google.com; s=arc-20160816; b=bNfpV3Y+tq/McnkUSskBYhOxjBDjNlI+hzpzcP4Dx2kyL6s0Jg+Vj/+bYM3SvoKFwb FCmWXmisXsdhO030eJ1Q12JOwxpbfvIECaC0RqNxL5ck49NVSo4q/1udvjjFNMB18XmY beIYf9PzjRvx86i+VvvLHqet7bTRSEYTBHARREM0DFD19dQm6wMfJIZXUMDEAT9c0ihT CF+PnuJsOTeLfh2eO4e23Kb5WagOshKOO9Ha/A9w6tWtDj++qLZJWZeKZTVaK2mrzr8/ kmwdKQbV5Rt+MA5Mvc+ctYbcJDPolI93NCdtRxoKXFsstyJQdLDxHpLLX2uOOJ9aTVmH lL9g== 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=490C69vkYrYG3grw7z3HU8TvedAfOCosDlNscR4taAY=; b=t8KQ5kjWCRcdtcNKOlO2OVqq/2hq+UxjAQe1ugUxJ/ic09Fp3gT+TB7pgNiPpemccG x2AD1hobWHoVCKxTHaqKC73nzs9vmAk8xn0uWHWgEKIgM8TrgK3M6i46Xn2JTnHHBSwq LmxmxTArOKEzPAhWCjY0II2Faa5GKnmqqSMD3v7ZqRTaD6BmQsfFWZ4CZAlX/5GV7lEg PC5cAba7CNMpaOXgZMsh72kXfE6VbSVeF7amkMj2RqETn+rTm8I0wIf3ccOWzcRRfBqC rchIiFgxcrjpAVb+/r7Z9tVe6wSALNSR7aLiyd+NiyGTR2bSmCKpIvcmFhzOsOmtUfXO MGgg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=jqPnh9rh; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i10-20020a05640242ca00b0043ad32fcc93si17848541edc.565.2022.07.13.14.36.19; Wed, 13 Jul 2022 14:36:44 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=jqPnh9rh; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237366AbiGMVM2 (ORCPT + 99 others); Wed, 13 Jul 2022 17:12:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34428 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237354AbiGMVM1 (ORCPT ); Wed, 13 Jul 2022 17:12:27 -0400 Received: from alexa-out-sd-01.qualcomm.com (alexa-out-sd-01.qualcomm.com [199.106.114.38]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2557B33412 for ; Wed, 13 Jul 2022 14:12:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1657746747; x=1689282747; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=490C69vkYrYG3grw7z3HU8TvedAfOCosDlNscR4taAY=; b=jqPnh9rhV31gCtduSjoWvSOEMmlv0gvVbWHPaD5Jg0Tsenn4iraY88Fg h8fDCJfYwbo6BCJ7TrujkTWaG8Zqp2uiaFz2kLs/n1X8q1+09fIW0NtFe fiKNUa+ERnutuPOFWC3ldvXVKyyuXCI5S4SNSqiKdXHAAckM1oDVFNW14 g=; Received: from unknown (HELO ironmsg04-sd.qualcomm.com) ([10.53.140.144]) by alexa-out-sd-01.qualcomm.com with ESMTP; 13 Jul 2022 14:12:26 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg04-sd.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 13 Jul 2022 14:12:26 -0700 Received: from nalasex01a.na.qualcomm.com (10.47.209.196) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Wed, 13 Jul 2022 14:12:26 -0700 Received: from maru.qualcomm.com (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Wed, 13 Jul 2022 14:12:25 -0700 From: Jae Hyun Yoo To: Tudor Ambarus , Pratyush Yadav , Michael Walle CC: Jamie Iles , Graeme Gregory , =?UTF-8?q?C=C3=A9dric=20Le=20Goater?= , Jae Hyun Yoo , , Subject: [PATCH v2] mtd: spi-nor: winbond: add support for W25Q512NW-IQ Date: Wed, 13 Jul 2022 14:12:10 -0700 Message-ID: <20220713211210.1945044-1-quic_jaehyoo@quicinc.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nalasex01a.na.qualcomm.com (10.47.209.196) X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add support for Winbond W25Q512NW-IQ/IN Signed-off-by: Jae Hyun Yoo Link: https://www.winbond.com/resource-files/W25Q512NW%20RevB%2007192021.pdf Reviewed-by: Cédric Le Goater --- Changes in v2: * Refined commit message (Michael) Test result on AST2600 SoC's SPI controller: $ cat /sys/bus/platform/devices/1e620000.spi/spi_master/spi0/spi0.1/spi-nor/jedec_id ef6020 $ cat /sys/bus/platform/devices/1e620000.spi/spi_master/spi0/spi0.1/spi-nor/manufacturer winbond $ cat /sys/bus/platform/devices/1e620000.spi/spi_master/spi0/spi0.1/spi-nor/partname w25q512nwq $ hexdump /sys/bus/platform/devices/1e620000.spi/spi_master/spi0/spi0.1/spi-nor/sfdp 0000000 4653 5044 0106 ff01 0600 1001 0080 ff00 0000010 0084 0201 00d0 ff00 ffff ffff ffff ffff 0000020 ffff ffff ffff ffff ffff ffff ffff ffff * 0000080 20e5 fffb ffff 1fff eb44 6b08 3b08 bb42 0000090 fffe ffff ffff 0000 ffff eb40 200c 520f 00000a0 d810 0000 0233 00a6 e781 d914 63e9 3376 00000b0 757a 757a bdf7 5cd5 f719 ff5d 70e9 a5f9 00000c0 ffff ffff ffff ffff ffff ffff ffff ffff 00000d0 0aff fff0 ff21 ffdc 00000d8 $ flash_otp_info -u /dev/mtd0 Number of OTP user blocks on /dev/mtd0: 3 block 0: offset = 0x0000 size = 256 bytes [unlocked] block 1: offset = 0x0100 size = 256 bytes [unlocked] block 2: offset = 0x0200 size = 256 bytes [unlocked] $ flash_otp_dump -u /dev/mtd0 0x2d0 OTP user data for /dev/mtd0 0x02d0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff 0x02e0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff 0x02f0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff $ echo -n otp test | flash_otp_write -u /dev/mtd0 0x2d0 Writing OTP user data on /dev/mtd0 at offset 0x2d0 Wrote 8 bytes of OTP user data $ flash_otp_dump -u /dev/mtd0 0x2d0 OTP user data for /dev/mtd0 0x02d0: 6f 74 70 20 74 65 73 74 ff ff ff ff ff ff ff ff 0x02e0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff 0x02f0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff $ flash_otp_erase -u /dev/mtd0 0x200 0x100 $ flash_otp_dump -u /dev/mtd0 0x2d0 OTP user data for /dev/mtd0 0x02d0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff 0x02e0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff 0x02f0: ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff drivers/mtd/spi-nor/winbond.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/drivers/mtd/spi-nor/winbond.c b/drivers/mtd/spi-nor/winbond.c index ffaa24055259..d6f1a3b7267e 100644 --- a/drivers/mtd/spi-nor/winbond.c +++ b/drivers/mtd/spi-nor/winbond.c @@ -133,6 +133,9 @@ static const struct flash_info winbond_nor_parts[] = { { "w25m512jv", INFO(0xef7119, 0, 64 * 1024, 1024) NO_SFDP_FLAGS(SECT_4K | SPI_NOR_QUAD_READ | SPI_NOR_DUAL_READ) }, + { "w25q512nwq", INFO(0xef6020, 0, 64 * 1024, 1024) + PARSE_SFDP + OTP_INFO(256, 3, 0x1000, 0x1000) }, { "w25q512nwm", INFO(0xef8020, 0, 64 * 1024, 1024) PARSE_SFDP OTP_INFO(256, 3, 0x1000, 0x1000) }, -- 2.25.1