Refreshed all patches. Altered patches: - 400-mtd-add-rootfs-split-support.patch Compile-tested on: none Runtime-tested on: none Signed-off-by: Koen Vandeputte <koen.vandeputte@ncentric.com>
		
			
				
	
	
		
			69 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
From 01f9c7240a900d5676a8496496f2974dd36996b1 Mon Sep 17 00:00:00 2001
 | 
						|
From: Brian Norris <computersforpeace@gmail.com>
 | 
						|
Date: Tue, 23 May 2017 07:30:20 +0200
 | 
						|
Subject: [PATCH] mtd: partitions: factor out code calling parser
 | 
						|
MIME-Version: 1.0
 | 
						|
Content-Type: text/plain; charset=UTF-8
 | 
						|
Content-Transfer-Encoding: 8bit
 | 
						|
 | 
						|
This code is going to be reused for parsers matched using OF so let's
 | 
						|
factor it out to make this easier.
 | 
						|
 | 
						|
Signed-off-by: Brian Norris <computersforpeace@gmail.com>
 | 
						|
Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
 | 
						|
Acked-by: Brian Norris <computersforpeace@gmail.com>
 | 
						|
---
 | 
						|
 drivers/mtd/mtdpart.c | 33 ++++++++++++++++++++++++---------
 | 
						|
 1 file changed, 24 insertions(+), 9 deletions(-)
 | 
						|
 | 
						|
--- a/drivers/mtd/mtdpart.c
 | 
						|
+++ b/drivers/mtd/mtdpart.c
 | 
						|
@@ -832,6 +832,27 @@ static const char * const default_mtd_pa
 | 
						|
 	NULL
 | 
						|
 };
 | 
						|
 
 | 
						|
+static int mtd_part_do_parse(struct mtd_part_parser *parser,
 | 
						|
+			     struct mtd_info *master,
 | 
						|
+			     struct mtd_partitions *pparts,
 | 
						|
+			     struct mtd_part_parser_data *data)
 | 
						|
+{
 | 
						|
+	int ret;
 | 
						|
+
 | 
						|
+	ret = (*parser->parse_fn)(master, &pparts->parts, data);
 | 
						|
+	pr_debug("%s: parser %s: %i\n", master->name, parser->name, ret);
 | 
						|
+	if (ret <= 0)
 | 
						|
+		return ret;
 | 
						|
+
 | 
						|
+	pr_notice("%d %s partitions found on MTD device %s\n", ret,
 | 
						|
+		  parser->name, master->name);
 | 
						|
+
 | 
						|
+	pparts->nr_parts = ret;
 | 
						|
+	pparts->parser = parser;
 | 
						|
+
 | 
						|
+	return ret;
 | 
						|
+}
 | 
						|
+
 | 
						|
 /**
 | 
						|
  * parse_mtd_partitions - parse MTD partitions
 | 
						|
  * @master: the master partition (describes whole MTD device)
 | 
						|
@@ -872,16 +893,10 @@ int parse_mtd_partitions(struct mtd_info
 | 
						|
 			 parser ? parser->name : NULL);
 | 
						|
 		if (!parser)
 | 
						|
 			continue;
 | 
						|
-		ret = (*parser->parse_fn)(master, &pparts->parts, data);
 | 
						|
-		pr_debug("%s: parser %s: %i\n",
 | 
						|
-			 master->name, parser->name, ret);
 | 
						|
-		if (ret > 0) {
 | 
						|
-			printk(KERN_NOTICE "%d %s partitions found on MTD device %s\n",
 | 
						|
-			       ret, parser->name, master->name);
 | 
						|
-			pparts->nr_parts = ret;
 | 
						|
-			pparts->parser = parser;
 | 
						|
+		ret = mtd_part_do_parse(parser, master, pparts, data);
 | 
						|
+		/* Found partitions! */
 | 
						|
+		if (ret > 0)
 | 
						|
 			return 0;
 | 
						|
-		}
 | 
						|
 		mtd_part_parser_put(parser);
 | 
						|
 		/*
 | 
						|
 		 * Stash the first error we see; only report it if no parser
 |