diff options
| author | Pekon Gupta <pekon@ti.com> | 2013-10-24 18:20:18 +0530 | 
|---|---|---|
| committer | Evan Wilson <evan@oliodevices.com> | 2014-11-29 14:48:40 -0800 | 
| commit | 581912e24a799799990cfa070124dc70d1e8aa61 (patch) | |
| tree | 3136316eab19b69708d0f0280d969bc63372c752 | |
| parent | 0ed0fbbcdd33c043f3f2df02ef3253d894decd33 (diff) | |
| download | olio-linux-3.10-581912e24a799799990cfa070124dc70d1e8aa61.tar.xz olio-linux-3.10-581912e24a799799990cfa070124dc70d1e8aa61.zip | |
mtd: nand: omap: combine different flavours of 1-bit hamming ecc schemes
OMAP NAND driver currently supports multiple flavours of 1-bit Hamming
ecc-scheme, like:
- OMAP_ECC_HAMMING_CODE_DEFAULT
	1-bit hamming ecc code using software library
- OMAP_ECC_HAMMING_CODE_HW
	1-bit hamming ecc-code using GPMC h/w engine
- OMAP_ECC_HAMMING_CODE_HW_ROMCODE
	1-bit hamming ecc-code using GPMC h/w engin with ecc-layout compatible
	to ROM code.
This patch combines above multiple ecc-schemes into single implementation:
- OMAP_ECC_HAM1_CODE_HW
	1-bit hamming ecc-code using GPMC h/w engine with ROM-code compatible
	ecc-layout.
Signed-off-by: Pekon Gupta <pekon@ti.com>
Reviewed-by: Felipe Balbi <balbi@ti.com>
Acked-by: Tony Lindgren <tony@atomide.com>
Tested-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com>
Signed-off-by: Brian Norris <computersforpeace@gmail.com>
| -rw-r--r-- | Documentation/devicetree/bindings/mtd/gpmc-nand.txt | 8 | ||||
| -rw-r--r-- | arch/arm/mach-omap2/board-flash.c | 2 | ||||
| -rw-r--r-- | drivers/mtd/nand/omap2.c | 9 | ||||
| -rw-r--r-- | include/linux/platform_data/mtd-nand-omap2.h | 7 | 
4 files changed, 9 insertions, 17 deletions
| diff --git a/Documentation/devicetree/bindings/mtd/gpmc-nand.txt b/Documentation/devicetree/bindings/mtd/gpmc-nand.txt index bfe07e15273..5e1f31b5ff7 100644 --- a/Documentation/devicetree/bindings/mtd/gpmc-nand.txt +++ b/Documentation/devicetree/bindings/mtd/gpmc-nand.txt @@ -22,10 +22,10 @@ Optional properties:  				width of 8 is assumed.   - ti,nand-ecc-opt:		A string setting the ECC layout to use. One of: - -		"sw"		Software method (default) -		"hw"		Hardware method -		"hw-romcode"	gpmc hamming mode method & romcode layout +		"sw"		<deprecated> use "ham1" instead +		"hw"		<deprecated> use "ham1" instead +		"hw-romcode"	<deprecated> use "ham1" instead +		"ham1"		1-bit Hamming ecc code  		"bch4"		4-bit BCH ecc code  		"bch8"		8-bit BCH ecc code diff --git a/arch/arm/mach-omap2/board-flash.c b/arch/arm/mach-omap2/board-flash.c index c33adea0247..df4508c092d 100644 --- a/arch/arm/mach-omap2/board-flash.c +++ b/arch/arm/mach-omap2/board-flash.c @@ -139,7 +139,7 @@ __init board_nand_init(struct mtd_partition *nand_parts, u8 nr_parts, u8 cs,  	board_nand_data.nr_parts	= nr_parts;  	board_nand_data.devsize		= nand_type; -	board_nand_data.ecc_opt = OMAP_ECC_HAMMING_CODE_DEFAULT; +	board_nand_data.ecc_opt = OMAP_ECC_BCH8_CODE_HW;  	gpmc_nand_init(&board_nand_data, gpmc_t);  }  #endif /* CONFIG_MTD_NAND_OMAP2 || CONFIG_MTD_NAND_OMAP2_MODULE */ diff --git a/drivers/mtd/nand/omap2.c b/drivers/mtd/nand/omap2.c index 4ecf0e5fd48..8d521aa001c 100644 --- a/drivers/mtd/nand/omap2.c +++ b/drivers/mtd/nand/omap2.c @@ -1993,10 +1993,7 @@ static int omap_nand_probe(struct platform_device *pdev)  	}  	/* select the ecc type */ -	if (pdata->ecc_opt == OMAP_ECC_HAMMING_CODE_DEFAULT) -		info->nand.ecc.mode = NAND_ECC_SOFT; -	else if ((pdata->ecc_opt == OMAP_ECC_HAMMING_CODE_HW) || -		(pdata->ecc_opt == OMAP_ECC_HAMMING_CODE_HW_ROMCODE)) { +	if (pdata->ecc_opt == OMAP_ECC_HAM1_CODE_HW) {  		info->nand.ecc.bytes            = 3;  		info->nand.ecc.size             = 512;  		info->nand.ecc.strength         = 1; @@ -2025,7 +2022,7 @@ static int omap_nand_probe(struct platform_device *pdev)  	}  	/* rom code layout */ -	if (pdata->ecc_opt == OMAP_ECC_HAMMING_CODE_HW_ROMCODE) { +	if (pdata->ecc_opt == OMAP_ECC_HAM1_CODE_HW) {  		if (info->nand.options & NAND_BUSWIDTH_16)  			offset = 2; @@ -2033,7 +2030,7 @@ static int omap_nand_probe(struct platform_device *pdev)  			offset = 1;  			info->nand.badblock_pattern = &bb_descrip_flashbased;  		} -		omap_oobinfo.eccbytes = 3 * (info->mtd.oobsize/16); +		omap_oobinfo.eccbytes = 3 * (info->mtd.writesize / 512);  		for (i = 0; i < omap_oobinfo.eccbytes; i++)  			omap_oobinfo.eccpos[i] = i+offset; diff --git a/include/linux/platform_data/mtd-nand-omap2.h b/include/linux/platform_data/mtd-nand-omap2.h index e4128f1510b..4da5bfa2147 100644 --- a/include/linux/platform_data/mtd-nand-omap2.h +++ b/include/linux/platform_data/mtd-nand-omap2.h @@ -23,13 +23,8 @@ enum nand_io {  };  enum omap_ecc { -		/* 1-bit ecc: stored at end of spare area */ -	OMAP_ECC_HAMMING_CODE_DEFAULT = 0, /* Default, s/w method */ -	OMAP_ECC_HAMMING_CODE_HW, /* gpmc to detect the error */ -		/* 1-bit ecc: stored at beginning of spare area as romcode */ -	OMAP_ECC_HAMMING_CODE_HW_ROMCODE, /* gpmc method & romcode layout */  	/* 1-bit  ECC calculation by GPMC, Error detection by Software */ -	OMAP_ECC_HAM1_CODE_HW, +	OMAP_ECC_HAM1_CODE_HW = 0,  	/* 4-bit  ECC calculation by GPMC, Error detection by Software */  	OMAP_ECC_BCH4_CODE_HW_DETECTION_SW,  	/* 4-bit  ECC calculation by GPMC, Error detection by ELM */ |