Skip to content

Commit 8f40842

Browse files
committed
Merge tag 'for-linus-20160324' of git://git.infradead.org/linux-mtd
Pull MTD updates from Brian Norris: "NAND: - Add sunxi_nand randomizer support - begin refactoring NAND ecclayout structs - fix pxa3xx_nand dmaengine usage - brcmnand: fix support for v7.1 controller - add Qualcomm NAND controller driver SPI NOR: - add new ls1021a, ls2080a support to Freescale QuadSPI - add new flash ID entries - support bottom-block protection for Winbond flash - support Status Register Write Protect - remove broken QPI support for Micron SPI flash JFFS2: - improve post-mount CRC scan efficiency General: - refactor bcm63xxpart parser, to later extend for NAND - add writebuf size parameter to mtdram Other minor code quality improvements" * tag 'for-linus-20160324' of git://git.infradead.org/linux-mtd: (72 commits) mtd: nand: remove kerneldoc for removed function parameter mtd: nand: Qualcomm NAND controller driver dt/bindings: qcom_nandc: Add DT bindings mtd: nand: don't select chip in nand_chip's block_bad op mtd: spi-nor: support lock/unlock for a few Winbond chips mtd: spi-nor: add TB (Top/Bottom) protect support mtd: spi-nor: add SPI_NOR_HAS_LOCK flag mtd: spi-nor: use BIT() for flash_info flags mtd: spi-nor: disallow further writes to SR if WP# is low mtd: spi-nor: make lock/unlock bounds checks more obvious and robust mtd: spi-nor: silently drop lock/unlock for already locked/unlocked region mtd: spi-nor: wait for SR_WIP to clear on initial unlock mtd: nand: simplify nand_bch_init() usage mtd: mtdswap: remove useless if (!mtd->ecclayout) test mtd: create an mtd_oobavail() helper and make use of it mtd: kill the ecclayout->oobavail field mtd: nand: check status before reporting timeout mtd: bcm63xxpart: give width specifier an 'int', not 'size_t' mtd: mtdram: Add parameter for setting writebuf size mtd: nand: pxa3xx_nand: kill unused field 'drcmr_cmd' ...
2 parents 8887566 + 6871c1b commit 8f40842

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

61 files changed

+3524
-592
lines changed

Documentation/devicetree/bindings/mtd/atmel-nand.txt

+18-13
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,10 @@
11
Atmel NAND flash
22

33
Required properties:
4-
- compatible : should be "atmel,at91rm9200-nand" or "atmel,sama5d4-nand".
4+
- compatible: The possible values are:
5+
"atmel,at91rm9200-nand"
6+
"atmel,sama5d2-nand"
7+
"atmel,sama5d4-nand"
58
- reg : should specify localbus address and size used for the chip,
69
and hardware ECC controller if available.
710
If the hardware ECC is PMECC, it should contain address and size for
@@ -21,26 +24,28 @@ Optional properties:
2124
- nand-ecc-mode : String, operation mode of the NAND ecc mode, soft by default.
2225
Supported values are: "none", "soft", "hw", "hw_syndrome", "hw_oob_first",
2326
"soft_bch".
24-
- atmel,has-pmecc : boolean to enable Programmable Multibit ECC hardware.
25-
Only supported by at91sam9x5 or later sam9 product.
27+
- atmel,has-pmecc : boolean to enable Programmable Multibit ECC hardware,
28+
capable of BCH encoding and decoding, on devices where it is present.
2629
- atmel,pmecc-cap : error correct capability for Programmable Multibit ECC
27-
Controller. Supported values are: 2, 4, 8, 12, 24.
30+
Controller. Supported values are: 2, 4, 8, 12, 24. If the compatible string
31+
is "atmel,sama5d2-nand", 32 is also valid.
2832
- atmel,pmecc-sector-size : sector size for ECC computation. Supported values
2933
are: 512, 1024.
3034
- atmel,pmecc-lookup-table-offset : includes two offsets of lookup table in ROM
3135
for different sector size. First one is for sector size 512, the next is for
3236
sector size 1024. If not specified, driver will build the table in runtime.
3337
- nand-bus-width : 8 or 16 bus width if not present 8
3438
- nand-on-flash-bbt: boolean to enable on flash bbt option if not present false
35-
- Nand Flash Controller(NFC) is a slave driver under Atmel nand flash
36-
- Required properties:
37-
- compatible : "atmel,sama5d3-nfc".
38-
- reg : should specify the address and size used for NFC command registers,
39-
NFC registers and NFC Sram. NFC Sram address and size can be absent
40-
if don't want to use it.
41-
- clocks: phandle to the peripheral clock
42-
- Optional properties:
43-
- atmel,write-by-sram: boolean to enable NFC write by sram.
39+
40+
Nand Flash Controller(NFC) is an optional sub-node
41+
Required properties:
42+
- compatible : "atmel,sama5d3-nfc" or "atmel,sama5d4-nfc".
43+
- reg : should specify the address and size used for NFC command registers,
44+
NFC registers and NFC SRAM. NFC SRAM address and size can be absent
45+
if don't want to use it.
46+
- clocks: phandle to the peripheral clock
47+
Optional properties:
48+
- atmel,write-by-sram: boolean to enable NFC write by SRAM.
4449

4550
Examples:
4651
nand0: nand@40000000,0 {

Documentation/devicetree/bindings/mtd/fsl-quadspi.txt

+4-1
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,9 @@
33
Required properties:
44
- compatible : Should be "fsl,vf610-qspi", "fsl,imx6sx-qspi",
55
"fsl,imx7d-qspi", "fsl,imx6ul-qspi",
6-
"fsl,ls1021-qspi"
6+
"fsl,ls1021a-qspi"
7+
or
8+
"fsl,ls2080a-qspi" followed by "fsl,ls1021a-qspi"
79
- reg : the first contains the register location and length,
810
the second contains the memory mapping address and length
911
- reg-names: Should contain the reg names "QuadSPI" and "QuadSPI-memory"
@@ -19,6 +21,7 @@ Optional properties:
1921
But if there are two NOR flashes connected to the
2022
bus, you should enable this property.
2123
(Please check the board's schematic.)
24+
- big-endian : That means the IP register is big endian
2225

2326
Example:
2427

Original file line numberDiff line numberDiff line change
@@ -0,0 +1,86 @@
1+
* Qualcomm NAND controller
2+
3+
Required properties:
4+
- compatible: should be "qcom,ipq806x-nand"
5+
- reg: MMIO address range
6+
- clocks: must contain core clock and always on clock
7+
- clock-names: must contain "core" for the core clock and "aon" for the
8+
always on clock
9+
- dmas: DMA specifier, consisting of a phandle to the ADM DMA
10+
controller node and the channel number to be used for
11+
NAND. Refer to dma.txt and qcom_adm.txt for more details
12+
- dma-names: must be "rxtx"
13+
- qcom,cmd-crci: must contain the ADM command type CRCI block instance
14+
number specified for the NAND controller on the given
15+
platform
16+
- qcom,data-crci: must contain the ADM data type CRCI block instance
17+
number specified for the NAND controller on the given
18+
platform
19+
- #address-cells: <1> - subnodes give the chip-select number
20+
- #size-cells: <0>
21+
22+
* NAND chip-select
23+
24+
Each controller may contain one or more subnodes to represent enabled
25+
chip-selects which (may) contain NAND flash chips. Their properties are as
26+
follows.
27+
28+
Required properties:
29+
- compatible: should contain "qcom,nandcs"
30+
- reg: a single integer representing the chip-select
31+
number (e.g., 0, 1, 2, etc.)
32+
- #address-cells: see partition.txt
33+
- #size-cells: see partition.txt
34+
- nand-ecc-strength: see nand.txt
35+
- nand-ecc-step-size: must be 512. see nand.txt for more details.
36+
37+
Optional properties:
38+
- nand-bus-width: see nand.txt
39+
40+
Each nandcs device node may optionally contain a 'partitions' sub-node, which
41+
further contains sub-nodes describing the flash partition mapping. See
42+
partition.txt for more detail.
43+
44+
Example:
45+
46+
nand@1ac00000 {
47+
compatible = "qcom,ebi2-nandc";
48+
reg = <0x1ac00000 0x800>;
49+
50+
clocks = <&gcc EBI2_CLK>,
51+
<&gcc EBI2_AON_CLK>;
52+
clock-names = "core", "aon";
53+
54+
dmas = <&adm_dma 3>;
55+
dma-names = "rxtx";
56+
qcom,cmd-crci = <15>;
57+
qcom,data-crci = <3>;
58+
59+
#address-cells = <1>;
60+
#size-cells = <0>;
61+
62+
nandcs@0 {
63+
compatible = "qcom,nandcs";
64+
reg = <0>;
65+
66+
nand-ecc-strength = <4>;
67+
nand-ecc-step-size = <512>;
68+
nand-bus-width = <8>;
69+
70+
partitions {
71+
compatible = "fixed-partitions";
72+
#address-cells = <1>;
73+
#size-cells = <1>;
74+
75+
partition@0 {
76+
label = "boot-nand";
77+
reg = <0 0x58a0000>;
78+
};
79+
80+
partition@58a0000 {
81+
label = "fs-nand";
82+
reg = <0x58a0000 0x4000000>;
83+
};
84+
};
85+
};
86+
};

arch/arm/plat-samsung/devs.c

-9
Original file line numberDiff line numberDiff line change
@@ -727,15 +727,6 @@ static int __init s3c_nand_copy_set(struct s3c2410_nand_set *set)
727727
return -ENOMEM;
728728
}
729729

730-
if (set->ecc_layout) {
731-
ptr = kmemdup(set->ecc_layout,
732-
sizeof(struct nand_ecclayout), GFP_KERNEL);
733-
set->ecc_layout = ptr;
734-
735-
if (!ptr)
736-
return -ENOMEM;
737-
}
738-
739730
return 0;
740731
}
741732

arch/mips/include/asm/mach-jz4740/jz4740_nand.h

-2
Original file line numberDiff line numberDiff line change
@@ -25,8 +25,6 @@ struct jz_nand_platform_data {
2525
int num_partitions;
2626
struct mtd_partition *partitions;
2727

28-
struct nand_ecclayout *ecc_layout;
29-
3028
unsigned char banks[JZ_NAND_NUM_BANKS];
3129

3230
void (*ident_callback)(struct platform_device *, struct nand_chip *,

drivers/memory/fsl_ifc.c

+1-1
Original file line numberDiff line numberDiff line change
@@ -260,7 +260,7 @@ static int fsl_ifc_ctrl_probe(struct platform_device *dev)
260260

261261
/* get the Controller level irq */
262262
fsl_ifc_ctrl_dev->irq = irq_of_parse_and_map(dev->dev.of_node, 0);
263-
if (fsl_ifc_ctrl_dev->irq == NO_IRQ) {
263+
if (fsl_ifc_ctrl_dev->irq == 0) {
264264
dev_err(&dev->dev, "failed to get irq resource "
265265
"for IFC\n");
266266
ret = -ENODEV;

drivers/mtd/Kconfig

+1-1
Original file line numberDiff line numberDiff line change
@@ -142,7 +142,7 @@ config MTD_AR7_PARTS
142142

143143
config MTD_BCM63XX_PARTS
144144
tristate "BCM63XX CFE partitioning support"
145-
depends on BCM63XX
145+
depends on BCM63XX || BMIPS_GENERIC || COMPILE_TEST
146146
select CRC32
147147
help
148148
This provides partions parsing for BCM63xx devices with CFE

drivers/mtd/bcm47xxpart.c

+24-18
Original file line numberDiff line numberDiff line change
@@ -66,11 +66,13 @@ static const char *bcm47xxpart_trx_data_part_name(struct mtd_info *master,
6666
{
6767
uint32_t buf;
6868
size_t bytes_read;
69+
int err;
6970

70-
if (mtd_read(master, offset, sizeof(buf), &bytes_read,
71-
(uint8_t *)&buf) < 0) {
72-
pr_err("mtd_read error while parsing (offset: 0x%X)!\n",
73-
offset);
71+
err = mtd_read(master, offset, sizeof(buf), &bytes_read,
72+
(uint8_t *)&buf);
73+
if (err && !mtd_is_bitflip(err)) {
74+
pr_err("mtd_read error while parsing (offset: 0x%X): %d\n",
75+
offset, err);
7476
goto out_default;
7577
}
7678

@@ -95,6 +97,7 @@ static int bcm47xxpart_parse(struct mtd_info *master,
9597
int trx_part = -1;
9698
int last_trx_part = -1;
9799
int possible_nvram_sizes[] = { 0x8000, 0xF000, 0x10000, };
100+
int err;
98101

99102
/*
100103
* Some really old flashes (like AT45DB*) had smaller erasesize-s, but
@@ -118,8 +121,8 @@ static int bcm47xxpart_parse(struct mtd_info *master,
118121
/* Parse block by block looking for magics */
119122
for (offset = 0; offset <= master->size - blocksize;
120123
offset += blocksize) {
121-
/* Nothing more in higher memory */
122-
if (offset >= 0x2000000)
124+
/* Nothing more in higher memory on BCM47XX (MIPS) */
125+
if (config_enabled(CONFIG_BCM47XX) && offset >= 0x2000000)
123126
break;
124127

125128
if (curr_part >= BCM47XXPART_MAX_PARTS) {
@@ -128,10 +131,11 @@ static int bcm47xxpart_parse(struct mtd_info *master,
128131
}
129132

130133
/* Read beginning of the block */
131-
if (mtd_read(master, offset, BCM47XXPART_BYTES_TO_READ,
132-
&bytes_read, (uint8_t *)buf) < 0) {
133-
pr_err("mtd_read error while parsing (offset: 0x%X)!\n",
134-
offset);
134+
err = mtd_read(master, offset, BCM47XXPART_BYTES_TO_READ,
135+
&bytes_read, (uint8_t *)buf);
136+
if (err && !mtd_is_bitflip(err)) {
137+
pr_err("mtd_read error while parsing (offset: 0x%X): %d\n",
138+
offset, err);
135139
continue;
136140
}
137141

@@ -254,10 +258,11 @@ static int bcm47xxpart_parse(struct mtd_info *master,
254258
}
255259

256260
/* Read middle of the block */
257-
if (mtd_read(master, offset + 0x8000, 0x4,
258-
&bytes_read, (uint8_t *)buf) < 0) {
259-
pr_err("mtd_read error while parsing (offset: 0x%X)!\n",
260-
offset);
261+
err = mtd_read(master, offset + 0x8000, 0x4, &bytes_read,
262+
(uint8_t *)buf);
263+
if (err && !mtd_is_bitflip(err)) {
264+
pr_err("mtd_read error while parsing (offset: 0x%X): %d\n",
265+
offset, err);
261266
continue;
262267
}
263268

@@ -277,10 +282,11 @@ static int bcm47xxpart_parse(struct mtd_info *master,
277282
}
278283

279284
offset = master->size - possible_nvram_sizes[i];
280-
if (mtd_read(master, offset, 0x4, &bytes_read,
281-
(uint8_t *)buf) < 0) {
282-
pr_err("mtd_read error while reading at offset 0x%X!\n",
283-
offset);
285+
err = mtd_read(master, offset, 0x4, &bytes_read,
286+
(uint8_t *)buf);
287+
if (err && !mtd_is_bitflip(err)) {
288+
pr_err("mtd_read error while reading (offset 0x%X): %d\n",
289+
offset, err);
284290
continue;
285291
}
286292

0 commit comments

Comments
 (0)