Received: by 2002:a05:7208:9594:b0:7e:5202:c8b4 with SMTP id gs20csp1204342rbb; Mon, 26 Feb 2024 01:58:52 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCWordWUsxJqP2eO/MdA8aQubGITpvHvAskyZhVXDz9nLxefr6spQsLdTL0qiqBMprHCufRVevk2wwP36y4UB5UJAbjGEtRqYy1w3nlmcA== X-Google-Smtp-Source: AGHT+IHTBCjKeLsd+1qwNfcyt6sIOsZGfQUfLt5LAuBtD7cljci6htKlFe2m634jS28X4WIbf7MA X-Received: by 2002:a05:620a:13c3:b0:787:4e73:13d2 with SMTP id g3-20020a05620a13c300b007874e7313d2mr8426404qkl.44.1708941532194; Mon, 26 Feb 2024 01:58:52 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1708941532; cv=pass; d=google.com; s=arc-20160816; b=IukVRnetEeHpoLmLOkQ9cWB9OWkLgv4c0LGdJbOSSprE8kBsxUGqyN15kosry8LSrj /qROvYHuqq1XV9N1unFU/Gr5uuXqpABXV+bmu5SehcMgvij/VH6wbbWst2Inp9ICKBop g8jkIlPtdExu0AJd3xa62hGg8kUXchqj1rmfGD2tc+/6jIdMo/ChbbuLlCEeXqdrWsaT gIpuoixZi0gdpLsrWiLLfapmxZWKdRIK9BFNLfUO7EScuythVt9yT1Cp7E6wU8M0+tJ5 BiOt0eqD9n9ko68GiPMv0+oq7cw6rbJmVsFjpnMABBjsLXGN8hYlbvySjNLU/EVSPYdk tihA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from; bh=iNmmRHT84Y8mAJ5g5tWSZdGcdYW9OSWfAHboTWoH7Mc=; fh=/1STbxAIgMcGmfPDmQY9Qa9CQcd8vtC0UBh6c/QvATI=; b=FmHFZaSu9IY6iikLar4M0EDAE50VK2NE/0VSL2Y1lLOgAKnlFkLXeex18vCq+zjMhl ArsqoaUigGgYSHRKpYjJ4LoDd/iMZn2LoqPv/yC+JEONsJG6eDPf6unuG1gF1IKjLAhH YS6Z3OsiZoRdgnzhzCVpB3VD7CJIEO1gGNYTbkaYgVs50RnFbLv/ZbFwm1QWtCqVzSIU NLgpzkrXHP1/5iuMxIcnPT1AoiFUmmF0PNFsWXiKjbtdIH3cNsXtO1WjoKemHneJbVMQ cqJpt6dgj/lYJBTgVx4sklTepDOWMVckTkRAW2fSrvyacVvG4HhbV35mE/Lrr81ptQyo 5JjQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=tecon.ru dmarc=pass fromdomain=tecon.ru); spf=pass (google.com: domain of linux-kernel+bounces-81055-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-81055-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=tecon.ru Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id h20-20020a05620a401400b00787c70e42ffsi4540424qko.368.2024.02.26.01.58.52 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 26 Feb 2024 01:58:52 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-81055-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=tecon.ru dmarc=pass fromdomain=tecon.ru); spf=pass (google.com: domain of linux-kernel+bounces-81055-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-81055-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=tecon.ru Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id EB88F1C257E0 for ; Mon, 26 Feb 2024 09:58:51 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 2999357332; Mon, 26 Feb 2024 09:29:54 +0000 (UTC) Received: from mail.tecon.ru (mail.tecon.ru [82.112.190.120]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6B17C5731A for ; Mon, 26 Feb 2024 09:29:48 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=82.112.190.120 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708939793; cv=none; b=oTXBraGrUfqucpIuS9NBVFmuolhqj50FTqLNyl3HRFhFEhPdA3yadjYhrIZj08J2vJuX0Q54A979O76WTYmoL4Cn1NZ2l+R8bgrqu9ep3hNk5vGL6ggh5+jr2q1MboR+ulki7fSeMLA2i/+LZ9j6Nhf+KZr3EA1Jg38t+xU40bY= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708939793; c=relaxed/simple; bh=gYtBtcr/egSZXz7QFAh1aw4h4I+YrruWBeItmKKyOGI=; h=From:To:CC:Subject:Date:Message-ID:MIME-Version:Content-Type; b=YICLj1cb0/0C4sYh6YiWKD8yLR75xOEfdvu/Qs4aFT0yAKDqHbZ/X9S2GGcuWDQF7DXnc19cwFzMozEK3gjTMDwuF9C476tsITH4c+2h7i0PTgr60+JdabHj8isaIZ7aR54cAsqbZ5AJVnfQfBPLlYOVLDKPKtsFSIYmxTB8Wc0= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=tecon.ru; spf=pass smtp.mailfrom=tecon.ru; arc=none smtp.client-ip=82.112.190.120 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=tecon.ru Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=tecon.ru From: Dmitry Dunaev To: CC: , Dmitry Dunaev , Tudor Ambarus , Pratyush Yadav , Michael Walle , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra , , Subject: [PATCH] mtd: spi-nor: Add Puya Semiconductor chips driver Date: Mon, 26 Feb 2024 12:23:10 +0300 Message-ID: <20240226092312.1834584-1-dunaev@tecon.ru> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain Add a SPI NOR manufacturer driver for Puya Semiconductor chips Signed-off-by: Dmitry Dunaev --- drivers/mtd/spi-nor/Makefile | 1 + drivers/mtd/spi-nor/puya.c | 64 ++++++++++++++++++++++++++++++++++++ 2 files changed, 65 insertions(+) create mode 100644 drivers/mtd/spi-nor/puya.c diff --git a/drivers/mtd/spi-nor/Makefile b/drivers/mtd/spi-nor/Makefile index 5e68468b72fc..3e22039d0432 100644 --- a/drivers/mtd/spi-nor/Makefile +++ b/drivers/mtd/spi-nor/Makefile @@ -10,6 +10,7 @@ spi-nor-objs += intel.o spi-nor-objs += issi.o spi-nor-objs += macronix.o spi-nor-objs += micron-st.o +spi-nor-objs += puya.o spi-nor-objs += spansion.o spi-nor-objs += sst.o spi-nor-objs += winbond.o diff --git a/drivers/mtd/spi-nor/puya.c b/drivers/mtd/spi-nor/puya.c new file mode 100644 index 000000000000..2198a9ed7101 --- /dev/null +++ b/drivers/mtd/spi-nor/puya.c @@ -0,0 +1,64 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Copyright (C) 2024, Tecon MT LLC. + */ + +#include + +#include "core.h" + +/* Puya Semiconductor (Shanghai) Co., Ltd */ +static const struct flash_info puya_nor_parts[] = { + { + .id = SNOR_ID(0x85, 0x60, 0x10), + .name = "p25q05h", + .size = SZ_64K, + .no_sfdp_flags = SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ, + }, { + .id = SNOR_ID(0x85, 0x60, 0x11), + .name = "p25q10h", + .size = SZ_128K, + .no_sfdp_flags = SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ, + }, { + .id = SNOR_ID(0x85, 0x60, 0x12), + .name = "p25q20h", + .size = SZ_256K, + .no_sfdp_flags = SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ, + }, { + .id = SNOR_ID(0x85, 0x60, 0x13), + .name = "p25q40h", + .size = SZ_512K, + .no_sfdp_flags = SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ, + }, { + .id = SNOR_ID(0x85, 0x60, 0x14), + .name = "p25q80h", + .size = SZ_1M, + .no_sfdp_flags = SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ, + }, { + .id = SNOR_ID(0x85, 0x60, 0x15), + .name = "p25q16h", + .size = SZ_2M, + .no_sfdp_flags = SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ, + }, { + .id = SNOR_ID(0x85, 0x60, 0x16), + .name = "p25q32h", + .size = SZ_4M, + .no_sfdp_flags = SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ, + }, { + .id = SNOR_ID(0x85, 0x60, 0x17), + .name = "p25q64h", + .size = SZ_8M, + .no_sfdp_flags = SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ, + }, { + .id = SNOR_ID(0x85, 0x60, 0x18), + .name = "p25q128h", + .size = SZ_8M, + .no_sfdp_flags = SECT_4K | SPI_NOR_DUAL_READ | SPI_NOR_QUAD_READ, + } +}; + +const struct spi_nor_manufacturer spi_nor_puya = { + .name = "puya", + .parts = puya_nor_parts, + .nparts = ARRAY_SIZE(puya_nor_parts), +}; -- 2.34.1