mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-11-03 14:34:27 -05:00 
			
		
		
		
	Changelog: https://cdn.kernel.org/pub/linux/kernel/v4.x/ChangeLog-4.4.14 Some manual changes to target/linux/generic/patches-4.4/610- netfilter_match_bypass_default_checks.patch were needed. Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
		
			
				
	
	
		
			84 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
Content-Type: text/plain; charset="utf-8"
 | 
						|
MIME-Version: 1.0
 | 
						|
Content-Transfer-Encoding: 7bit
 | 
						|
Subject: [v3,
 | 
						|
	1/5] mtd: nand: Create a BBT flag to access bad block markers in raw
 | 
						|
	mode
 | 
						|
From: Archit Taneja <architt@codeaurora.org>
 | 
						|
X-Patchwork-Id: 6927081
 | 
						|
Message-Id: <1438578498-32254-2-git-send-email-architt@codeaurora.org>
 | 
						|
To: linux-mtd@lists.infradead.org, dehrenberg@google.com,
 | 
						|
	cernekee@gmail.com, computersforpeace@gmail.com
 | 
						|
Cc: linux-arm-msm@vger.kernel.org, agross@codeaurora.org,
 | 
						|
	sboyd@codeaurora.org, linux-kernel@vger.kernel.org,
 | 
						|
	Archit Taneja <architt@codeaurora.org>
 | 
						|
Date: Mon,  3 Aug 2015 10:38:14 +0530
 | 
						|
 | 
						|
Some controllers can access the factory bad block marker from OOB only
 | 
						|
when they read it in raw mode. When ECC is enabled, these controllers
 | 
						|
discard reading/writing bad block markers, preventing access to them
 | 
						|
altogether.
 | 
						|
 | 
						|
The bbt driver assumes MTD_OPS_PLACE_OOB when scanning for bad blocks.
 | 
						|
This results in the nand driver's ecc->read_oob() op to be called, which
 | 
						|
works with ECC enabled.
 | 
						|
 | 
						|
Create a new BBT option flag that tells nand_bbt to force the mode to
 | 
						|
MTD_OPS_RAW. This would result in the correct op being called for the
 | 
						|
underlying nand controller driver.
 | 
						|
 | 
						|
Reviewed-by: Andy Gross <agross@codeaurora.org>
 | 
						|
Signed-off-by: Archit Taneja <architt@codeaurora.org>
 | 
						|
 | 
						|
---
 | 
						|
drivers/mtd/nand/nand_base.c | 6 +++++-
 | 
						|
 drivers/mtd/nand/nand_bbt.c  | 6 +++++-
 | 
						|
 include/linux/mtd/bbm.h      | 7 +++++++
 | 
						|
 3 files changed, 17 insertions(+), 2 deletions(-)
 | 
						|
 | 
						|
--- a/drivers/mtd/nand/nand_base.c
 | 
						|
+++ b/drivers/mtd/nand/nand_base.c
 | 
						|
@@ -394,7 +394,11 @@ static int nand_default_block_markbad(st
 | 
						|
 	} else {
 | 
						|
 		ops.len = ops.ooblen = 1;
 | 
						|
 	}
 | 
						|
-	ops.mode = MTD_OPS_PLACE_OOB;
 | 
						|
+
 | 
						|
+	if (unlikely(chip->bbt_options & NAND_BBT_ACCESS_BBM_RAW))
 | 
						|
+		ops.mode = MTD_OPS_RAW;
 | 
						|
+	else
 | 
						|
+		ops.mode = MTD_OPS_PLACE_OOB;
 | 
						|
 
 | 
						|
 	/* Write to first/last page(s) if necessary */
 | 
						|
 	if (chip->bbt_options & NAND_BBT_SCANLASTPAGE)
 | 
						|
--- a/drivers/mtd/nand/nand_bbt.c
 | 
						|
+++ b/drivers/mtd/nand/nand_bbt.c
 | 
						|
@@ -420,7 +420,11 @@ static int scan_block_fast(struct mtd_in
 | 
						|
 	ops.oobbuf = buf;
 | 
						|
 	ops.ooboffs = 0;
 | 
						|
 	ops.datbuf = NULL;
 | 
						|
-	ops.mode = MTD_OPS_PLACE_OOB;
 | 
						|
+
 | 
						|
+	if (unlikely(bd->options & NAND_BBT_ACCESS_BBM_RAW))
 | 
						|
+		ops.mode = MTD_OPS_RAW;
 | 
						|
+	else
 | 
						|
+		ops.mode = MTD_OPS_PLACE_OOB;
 | 
						|
 
 | 
						|
 	for (j = 0; j < numpages; j++) {
 | 
						|
 		/*
 | 
						|
--- a/include/linux/mtd/bbm.h
 | 
						|
+++ b/include/linux/mtd/bbm.h
 | 
						|
@@ -116,6 +116,12 @@ struct nand_bbt_descr {
 | 
						|
 #define NAND_BBT_NO_OOB_BBM	0x00080000
 | 
						|
 
 | 
						|
 /*
 | 
						|
+ * Force MTD_OPS_RAW mode when trying to access bad block markes from OOB. To
 | 
						|
+ * be used by controllers which can access BBM only when ECC is disabled, i.e,
 | 
						|
+ * when in RAW access mode
 | 
						|
+ */
 | 
						|
+#define NAND_BBT_ACCESS_BBM_RAW        0x00100000
 | 
						|
+/*
 | 
						|
  * Flag set by nand_create_default_bbt_descr(), marking that the nand_bbt_descr
 | 
						|
  * was allocated dynamicaly and must be freed in nand_release(). Has no meaning
 | 
						|
  * in nand_chip.bbt_options.
 |