Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp3764931pxu; Sun, 20 Dec 2020 15:08:27 -0800 (PST) X-Google-Smtp-Source: ABdhPJyZ4y4r9Tc8wDyD9yM4VnWN8VARjMPtK9NuBaPk3+FTmQgb9HfVXHgHu0VbT/RsO0dabQTe X-Received: by 2002:a17:906:5290:: with SMTP id c16mr13310731ejm.188.1608505707472; Sun, 20 Dec 2020 15:08:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608505707; cv=none; d=google.com; s=arc-20160816; b=omm3PwnNcedon4osJLoTOMHTFwk65gqBj3aG+RrIFGZ7RjZPF0IgbjLoeC4S6OznFk RYAGMKmrpuGRknttjJeOp6QooDQoPaa/FYCbrxQsIUNqETQrZPI0Walwm8cEk/y7WPbY N6alWTb93EdPLqrYYhbUYULtDMjDMjGYgfVulAw0PqoZLu2b1UFalpNQNk/Zx5Dw8vwE rDLJLNUZZca7p25AKwz+/Fo7eb8K5qoB4n9ovMSQUuLbC6tP3tblAfIQ7erCAMTjOT2e /c3uI63IY/42lGYy8XDqwV6b6wTXPEbhtwXJY9VQ2BznpD+PQEXaSvjm7low4RQAKA75 yxXw== 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; bh=3uqAxzp9+eWfkThdv4v4p7Y4Ppo6opuComeeZnadBTw=; b=BHaqDFVCiidONFg7MkG6eqOwZN2Cx0h2gedVELIsMFegEKqkR+3tgexsPTNFE+1Nj/ ygX3OaVONP3y3ZC50gp0wIOsdAB34ddXavlTGjIdpixUKMFcJjCCEEBLswf4vKMsfL7p E5PVd/dfyff7wHNfTRczYLO6muYh/H7jjPMaEwZUT+JaVOQ5DYaPNIZT3ALpOQL2L99g 8h2Y60d8JEu4DDYlEL1mkK76mN3viaAgCUZT0ROsgTvJT5uefUU6nGzi8iiSb0BtGrWH zPhXB5xIGpvs08idcZFaJCKl7m5BNc14mgLqb4gL7ht4lJEWqxMzy3hRGVYFnZUTebOQ rS7A== 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 w11si9282730ejc.702.2020.12.20.15.07.55; Sun, 20 Dec 2020 15:08:27 -0800 (PST) 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 S1728294AbgLTXGQ (ORCPT + 99 others); Sun, 20 Dec 2020 18:06:16 -0500 Received: from mx.h4ck.space ([159.69.146.50]:59752 "EHLO mx.h4ck.space" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726507AbgLTXGL (ORCPT ); Sun, 20 Dec 2020 18:06:11 -0500 X-Greylist: delayed 512 seconds by postgrey-1.27 at vger.kernel.org; Sun, 20 Dec 2020 18:06:10 EST From: Andreas Rammhold To: Tudor Ambarus , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra , linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org Cc: Andreas Rammhold , microcai , Daniel Golle Subject: [PATCH] spi-nor: Add support for xt25f128b Date: Sun, 20 Dec 2020 23:43:15 +0100 Message-Id: <20201220224314.2659-1-andreas@rammhold.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This adds support for the xt25f128b as found on the rockpi4b SBC. Signed-off-by: Andreas Rammhold --- This continues the efforts done in [1] & [2] that went stale. I've tested this patch on my RockPi4b which only has the xt25f128b (and not the xt25f32b as also propsed in [2]). I have tried to obtain a copy of the datasheets but was unable to find them. Not sure whre you would get them. While [1] was already for the new spi-nor layout it was missing the bits in the core.{c,h} files. [1]: https://patchwork.ozlabs.org/project/linux-mtd/patch/CAMgqO2y9MYDj6antOaWLBRKU8vGEwqCB-Y1TkXTSWsmsed+W6A@mail.gmail.com/ [2]: https://patchwork.ozlabs.org/project/linux-mtd/patch/20200206171941.GA2398@makrotopia.org/ drivers/mtd/spi-nor/Makefile | 1 + drivers/mtd/spi-nor/core.c | 1 + drivers/mtd/spi-nor/core.h | 1 + drivers/mtd/spi-nor/xtx.c | 16 ++++++++++++++++ 4 files changed, 19 insertions(+) create mode 100644 drivers/mtd/spi-nor/xtx.c diff --git a/drivers/mtd/spi-nor/Makefile b/drivers/mtd/spi-nor/Makefile index 653923896205..3f7a52d7fa0b 100644 --- a/drivers/mtd/spi-nor/Makefile +++ b/drivers/mtd/spi-nor/Makefile @@ -17,6 +17,7 @@ spi-nor-objs += sst.o spi-nor-objs += winbond.o spi-nor-objs += xilinx.o spi-nor-objs += xmc.o +spi-nor-objs += xtx.o obj-$(CONFIG_MTD_SPI_NOR) += spi-nor.o obj-$(CONFIG_MTD_SPI_NOR) += controllers/ diff --git a/drivers/mtd/spi-nor/core.c b/drivers/mtd/spi-nor/core.c index f0ae7a01703a..ca1988554945 100644 --- a/drivers/mtd/spi-nor/core.c +++ b/drivers/mtd/spi-nor/core.c @@ -2024,6 +2024,7 @@ static const struct spi_nor_manufacturer *manufacturers[] = { &spi_nor_winbond, &spi_nor_xilinx, &spi_nor_xmc, + &spi_nor_xtx, }; static const struct flash_info * diff --git a/drivers/mtd/spi-nor/core.h b/drivers/mtd/spi-nor/core.h index 6f2f6b27173f..cea8c0c25c9f 100644 --- a/drivers/mtd/spi-nor/core.h +++ b/drivers/mtd/spi-nor/core.h @@ -398,6 +398,7 @@ extern const struct spi_nor_manufacturer spi_nor_sst; extern const struct spi_nor_manufacturer spi_nor_winbond; extern const struct spi_nor_manufacturer spi_nor_xilinx; extern const struct spi_nor_manufacturer spi_nor_xmc; +extern const struct spi_nor_manufacturer spi_nor_xtx; int spi_nor_write_enable(struct spi_nor *nor); int spi_nor_write_disable(struct spi_nor *nor); diff --git a/drivers/mtd/spi-nor/xtx.c b/drivers/mtd/spi-nor/xtx.c new file mode 100644 index 000000000000..a10102d8b3e2 --- /dev/null +++ b/drivers/mtd/spi-nor/xtx.c @@ -0,0 +1,16 @@ +// SPDX-License-Identifier: GPL-2.0 + +#include + +#include "core.h" + +static const struct flash_info xtx_parts[] = { + /* XTX (Shenzhen Xin Tian Xia Tech) */ + { "xt25f128b", INFO(0x0b4018, 0, 64 * 1024, 256, SECT_4K) }, +}; + +const struct spi_nor_manufacturer spi_nor_xtx = { + .name = "xtx", + .parts = xtx_parts, + .nparts = ARRAY_SIZE(xtx_parts), +}; -- 2.29.2