Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp4811526pxb; Mon, 15 Feb 2021 01:40:53 -0800 (PST) X-Google-Smtp-Source: ABdhPJz2JJGE4uBie26uFUmWJSjs/wFaMrPZqxI4+w297GBc3Dd4lVGzRroRcvtMUXwY2zp8tMQv X-Received: by 2002:a50:d714:: with SMTP id t20mr14254455edi.65.1613382053478; Mon, 15 Feb 2021 01:40:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613382053; cv=none; d=google.com; s=arc-20160816; b=s9H2c4/oZxADNy3EL+InB+c2Amx1uLk0kVqUQgfOUwbjMVoi828lRRiNBj/7A47cBk iJRHWsk/za07irDXF5xbHFVJCWoZ5coEICLLKTrA9b+g2v7/a/Y7UTcS2aqFhHyYu4gD nBBWbq7nxFQJ8pk5YTd+SnB17tuusHx0rlhidxtLDvbu1cqiXUgXjCITMZVAeCitkmbw r6VPP8JKfih2Xfe12OZsMmhDzE2AomBCZN07Cr5KK/r1mnjIqYQTGJVHsLI07DZlsyMR m7PQfP84Q763ECN3nyTFb1Ho8P4jXugAkLckxtHTUOoqXR3e/164uIXEIk35baVesWYz iWKg== 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=j3ckuPrqHhj+a9wM1FpqARhpl+yXkW6M1ONJjD4HIFU=; b=CTpC1tMX31J0QH9NDspZ1dJcW0skeYPo4K4whQitPf0QLXJ8Wf5oqMOMod5opQfx85 crjA3ydQT/8ZnNVRCDZrowLZ5+9Z0Ct6MpkcN7dBZNxyTrl5doPXfAHNOOLD+TIc2b/p eX34wmWIJPgxJ7ikCc0YMYbDtWNDfoUCw6yrnrxWGigzsH8eijqkPjQIHft6RJChgcIO cO/fVMaKXuh4OtAPxCxI5KCcBLYxsGqX8H2t1cUcOfCrXleAT+Vfe/JbUcMmeZuR4onI gMSAytj6jb+E7BU6OqcLR9V4iOmoOswD8k5ILDEZUgutZYaTMR6eNfpE5vo+MBiYZiKA SVsw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=MTsSPieE; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t16si15477346edi.293.2021.02.15.01.40.29; Mon, 15 Feb 2021 01:40:53 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=MTsSPieE; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230241AbhBOJjA (ORCPT + 99 others); Mon, 15 Feb 2021 04:39:00 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47922 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229992AbhBOJii (ORCPT ); Mon, 15 Feb 2021 04:38:38 -0500 Received: from mail-lj1-x231.google.com (mail-lj1-x231.google.com [IPv6:2a00:1450:4864:20::231]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B600AC061574; Mon, 15 Feb 2021 01:37:57 -0800 (PST) Received: by mail-lj1-x231.google.com with SMTP id v6so6920733ljh.9; Mon, 15 Feb 2021 01:37:57 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=j3ckuPrqHhj+a9wM1FpqARhpl+yXkW6M1ONJjD4HIFU=; b=MTsSPieEeX4km2tagPGx8RvLv5f+XB7O2V2K2REq8f/x+EqJW31CA0aYINGF49Di6E xylN3jtjbn18pW9Tzfn5iJiAeSRFJTPFJQ+Tj45xqZ7+eOneojyqhsAkhEfINWf6PFUU Ug71oVnaT5McTA+cPrYVX2RFwZhW9Jw5XrN+A7qFWOHdRp8oUAYbfCGO3t4NJHRmPUY9 10vRn/BLgwPDfzL9hzmM7q18UXNJLbb7APR4BLzNoGTeNnL8uI16wFeWRUrfLAnKIUmQ XEja8KcjWSKkllNC/k0bteEQfldN54ZdOy3nWKZZg1nzHl5PbxExI4ykabdN0akIbch1 h9QA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=j3ckuPrqHhj+a9wM1FpqARhpl+yXkW6M1ONJjD4HIFU=; b=FfAur0gdCvN98QvlHSuGi5fVaa+0nTWbFR430UvawIjpJ7a7IoyvnzY1anldnPgsBT rIaTG693UVUmuQVDH9y4/FmT+G/HN9qwZTcaboCgeLjzQihY6qk6h1/dMMuN4Y5MNmOz 3t9tJzzHPK8r6EhtGSl7NogdWtxu0+7R8EInVXfBuNnWqtU7U9L2uJmwCK177NiCze5q UYkgzMcAqqvSiIYA3coOfihQlyc9XxpLtynJKZjwIhkxq9lUq7ljStmRLuQVCYNnorPg /YcpDM3VKSvQOn9ypCtFnOHjS/j1OXpzXB/PCnsFh+g5VhvMwD74B5a5NMri53CKpdWB IaSA== X-Gm-Message-State: AOAM533NbIRBjU/b6sl2G0dqETk6qqQsXFmPPY5uJNPwYP3tP0tAt8ej +7nBmIeeYNXXTVnfymISgRA= X-Received: by 2002:a2e:730f:: with SMTP id o15mr9360582ljc.145.1613381876281; Mon, 15 Feb 2021 01:37:56 -0800 (PST) Received: from localhost.lan (ip-194-187-74-233.konfederacka.maverick.com.pl. [194.187.74.233]) by smtp.gmail.com with ESMTPSA id i21sm2733258lfe.102.2021.02.15.01.37.54 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 15 Feb 2021 01:37:55 -0800 (PST) From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= To: Miquel Raynal , Richard Weinberger , Vignesh Raghavendra , Rob Herring Cc: Boris Brezillon , linux-mtd@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= Subject: [PATCH] mtd: parsers: add MTD_OF_PARTS_BCM4908 config option Date: Mon, 15 Feb 2021 10:37:40 +0100 Message-Id: <20210215093740.20080-1-zajec5@gmail.com> X-Mailer: git-send-email 2.26.2 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Rafał Miłecki Right now ofpart parser gets always compiled with the BCM4908 support. It's not a big issue at this point as BCM4908 partitioning support comes at close-to-zero cost. It may differ for possible further ofpart quirks though. Make BCM4908 support selectable to set a clean pattern for adding further quirks. Signed-off-by: Rafał Miłecki --- This is NOT urgent and is NOT intended for the 5.12. Please review this change in a free moment, probably after merge window closes. --- drivers/mtd/parsers/Kconfig | 9 +++++++++ drivers/mtd/parsers/Makefile | 3 ++- .../parsers/{bcm4908-partitions.c => ofpart_bcm4908.c} | 2 +- .../parsers/{bcm4908-partitions.h => ofpart_bcm4908.h} | 8 ++++++++ drivers/mtd/parsers/{ofpart.c => ofpart_core.c} | 2 +- 5 files changed, 21 insertions(+), 3 deletions(-) rename drivers/mtd/parsers/{bcm4908-partitions.c => ofpart_bcm4908.c} (97%) rename drivers/mtd/parsers/{bcm4908-partitions.h => ofpart_bcm4908.h} (52%) rename drivers/mtd/parsers/{ofpart.c => ofpart_core.c} (99%) diff --git a/drivers/mtd/parsers/Kconfig b/drivers/mtd/parsers/Kconfig index d90c30229052..05b6a24cedd8 100644 --- a/drivers/mtd/parsers/Kconfig +++ b/drivers/mtd/parsers/Kconfig @@ -67,6 +67,15 @@ config MTD_OF_PARTS flash memory node, as described in Documentation/devicetree/bindings/mtd/partition.txt. +config MTD_OF_PARTS_BCM4908 + bool "BCM4908 partitioning support" + depends on MTD_OF_PARTS && (ARCH_BCM4908 || COMPILE_TEST) + default ARCH_BCM4908 + help + This provides partitions parser for BCM4908 family devices + that can have multiple "firmware" partitions. It takes care of + finding currently used one and backup ones. + config MTD_PARSER_IMAGETAG tristate "Parser for BCM963XX Image Tag format partitions" depends on BCM63XX || BMIPS_GENERIC || COMPILE_TEST diff --git a/drivers/mtd/parsers/Makefile b/drivers/mtd/parsers/Makefile index bf58a5221730..2dfe9fb602de 100644 --- a/drivers/mtd/parsers/Makefile +++ b/drivers/mtd/parsers/Makefile @@ -4,7 +4,8 @@ obj-$(CONFIG_MTD_BCM47XX_PARTS) += bcm47xxpart.o obj-$(CONFIG_MTD_BCM63XX_PARTS) += bcm63xxpart.o obj-$(CONFIG_MTD_CMDLINE_PARTS) += cmdlinepart.o obj-$(CONFIG_MTD_OF_PARTS) += ofpart.o -ofpart-objs := bcm4908-partitions.o +ofpart-y += ofpart_core.o +ofpart-$(CONFIG_MTD_OF_PARTS_BCM4908) += ofpart_bcm4908.o obj-$(CONFIG_MTD_PARSER_IMAGETAG) += parser_imagetag.o obj-$(CONFIG_MTD_AFS_PARTS) += afs.o obj-$(CONFIG_MTD_PARSER_TRX) += parser_trx.o diff --git a/drivers/mtd/parsers/bcm4908-partitions.c b/drivers/mtd/parsers/ofpart_bcm4908.c similarity index 97% rename from drivers/mtd/parsers/bcm4908-partitions.c rename to drivers/mtd/parsers/ofpart_bcm4908.c index ac69a2169763..3cfa4f4ec562 100644 --- a/drivers/mtd/parsers/bcm4908-partitions.c +++ b/drivers/mtd/parsers/ofpart_bcm4908.c @@ -10,7 +10,7 @@ #include #include -#include "bcm4908-partitions.h" +#include "ofpart_bcm4908.h" #define BLPARAMS_FW_OFFSET "NAND_RFS_OFS" diff --git a/drivers/mtd/parsers/bcm4908-partitions.h b/drivers/mtd/parsers/ofpart_bcm4908.h similarity index 52% rename from drivers/mtd/parsers/bcm4908-partitions.h rename to drivers/mtd/parsers/ofpart_bcm4908.h index df25f0487d0a..80f8c086641f 100644 --- a/drivers/mtd/parsers/bcm4908-partitions.h +++ b/drivers/mtd/parsers/ofpart_bcm4908.h @@ -2,6 +2,14 @@ #ifndef __BCM4908_PARTITIONS_H #define __BCM4908_PARTITIONS_H +#ifdef CONFIG_MTD_OF_PARTS_BCM4908 int bcm4908_partitions_post_parse(struct mtd_info *mtd, struct mtd_partition *parts, int nr_parts); +#else +static inline int bcm4908_partitions_post_parse(struct mtd_info *mtd, struct mtd_partition *parts, + int nr_parts) +{ + return -EOPNOTSUPP; +} +#endif #endif diff --git a/drivers/mtd/parsers/ofpart.c b/drivers/mtd/parsers/ofpart_core.c similarity index 99% rename from drivers/mtd/parsers/ofpart.c rename to drivers/mtd/parsers/ofpart_core.c index 6b221df8401c..258c06a42283 100644 --- a/drivers/mtd/parsers/ofpart.c +++ b/drivers/mtd/parsers/ofpart_core.c @@ -16,7 +16,7 @@ #include #include -#include "bcm4908-partitions.h" +#include "ofpart_bcm4908.h" struct fixed_partitions_quirks { int (*post_parse)(struct mtd_info *mtd, struct mtd_partition *parts, int nr_parts); -- 2.26.2