diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/mtd/nand/nand_base.c | 82 |
1 files changed, 42 insertions, 40 deletions
diff --git a/drivers/mtd/nand/nand_base.c b/drivers/mtd/nand/nand_base.c index 4a5a329711c4..268c9a4317bd 100644 --- a/drivers/mtd/nand/nand_base.c +++ b/drivers/mtd/nand/nand_base.c | |||
@@ -1412,8 +1412,8 @@ static int nand_do_read_oob(struct mtd_info *mtd, loff_t from, | |||
1412 | int len; | 1412 | int len; |
1413 | uint8_t *buf = ops->oobbuf; | 1413 | uint8_t *buf = ops->oobbuf; |
1414 | 1414 | ||
1415 | DEBUG(MTD_DEBUG_LEVEL3, "nand_read_oob: from = 0x%08Lx, len = %i\n", | 1415 | DEBUG(MTD_DEBUG_LEVEL3, "%s: from = 0x%08Lx, len = %i\n", |
1416 | (unsigned long long)from, readlen); | 1416 | __func__, (unsigned long long)from, readlen); |
1417 | 1417 | ||
1418 | if (ops->mode == MTD_OOB_AUTO) | 1418 | if (ops->mode == MTD_OOB_AUTO) |
1419 | len = chip->ecc.layout->oobavail; | 1419 | len = chip->ecc.layout->oobavail; |
@@ -1421,8 +1421,8 @@ static int nand_do_read_oob(struct mtd_info *mtd, loff_t from, | |||
1421 | len = mtd->oobsize; | 1421 | len = mtd->oobsize; |
1422 | 1422 | ||
1423 | if (unlikely(ops->ooboffs >= len)) { | 1423 | if (unlikely(ops->ooboffs >= len)) { |
1424 | DEBUG(MTD_DEBUG_LEVEL0, "nand_read_oob: " | 1424 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Attempt to start read " |
1425 | "Attempt to start read outside oob\n"); | 1425 | "outside oob\n", __func__); |
1426 | return -EINVAL; | 1426 | return -EINVAL; |
1427 | } | 1427 | } |
1428 | 1428 | ||
@@ -1430,8 +1430,8 @@ static int nand_do_read_oob(struct mtd_info *mtd, loff_t from, | |||
1430 | if (unlikely(from >= mtd->size || | 1430 | if (unlikely(from >= mtd->size || |
1431 | ops->ooboffs + readlen > ((mtd->size >> chip->page_shift) - | 1431 | ops->ooboffs + readlen > ((mtd->size >> chip->page_shift) - |
1432 | (from >> chip->page_shift)) * len)) { | 1432 | (from >> chip->page_shift)) * len)) { |
1433 | DEBUG(MTD_DEBUG_LEVEL0, "nand_read_oob: " | 1433 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Attempt read beyond end " |
1434 | "Attempt read beyond end of device\n"); | 1434 | "of device\n", __func__); |
1435 | return -EINVAL; | 1435 | return -EINVAL; |
1436 | } | 1436 | } |
1437 | 1437 | ||
@@ -1505,8 +1505,8 @@ static int nand_read_oob(struct mtd_info *mtd, loff_t from, | |||
1505 | 1505 | ||
1506 | /* Do not allow reads past end of device */ | 1506 | /* Do not allow reads past end of device */ |
1507 | if (ops->datbuf && (from + ops->len) > mtd->size) { | 1507 | if (ops->datbuf && (from + ops->len) > mtd->size) { |
1508 | DEBUG(MTD_DEBUG_LEVEL0, "nand_read_oob: " | 1508 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Attempt read " |
1509 | "Attempt read beyond end of device\n"); | 1509 | "beyond end of device\n", __func__); |
1510 | return -EINVAL; | 1510 | return -EINVAL; |
1511 | } | 1511 | } |
1512 | 1512 | ||
@@ -1815,8 +1815,8 @@ static int nand_do_write_ops(struct mtd_info *mtd, loff_t to, | |||
1815 | 1815 | ||
1816 | /* reject writes, which are not page aligned */ | 1816 | /* reject writes, which are not page aligned */ |
1817 | if (NOTALIGNED(to) || NOTALIGNED(ops->len)) { | 1817 | if (NOTALIGNED(to) || NOTALIGNED(ops->len)) { |
1818 | printk(KERN_NOTICE "nand_write: " | 1818 | printk(KERN_NOTICE "%s: Attempt to write not " |
1819 | "Attempt to write not page aligned data\n"); | 1819 | "page aligned data\n", __func__); |
1820 | return -EINVAL; | 1820 | return -EINVAL; |
1821 | } | 1821 | } |
1822 | 1822 | ||
@@ -1943,8 +1943,8 @@ static int nand_do_write_oob(struct mtd_info *mtd, loff_t to, | |||
1943 | int chipnr, page, status, len; | 1943 | int chipnr, page, status, len; |
1944 | struct nand_chip *chip = mtd->priv; | 1944 | struct nand_chip *chip = mtd->priv; |
1945 | 1945 | ||
1946 | DEBUG(MTD_DEBUG_LEVEL3, "nand_write_oob: to = 0x%08x, len = %i\n", | 1946 | DEBUG(MTD_DEBUG_LEVEL3, "%s: to = 0x%08x, len = %i\n", |
1947 | (unsigned int)to, (int)ops->ooblen); | 1947 | __func__, (unsigned int)to, (int)ops->ooblen); |
1948 | 1948 | ||
1949 | if (ops->mode == MTD_OOB_AUTO) | 1949 | if (ops->mode == MTD_OOB_AUTO) |
1950 | len = chip->ecc.layout->oobavail; | 1950 | len = chip->ecc.layout->oobavail; |
@@ -1953,14 +1953,14 @@ static int nand_do_write_oob(struct mtd_info *mtd, loff_t to, | |||
1953 | 1953 | ||
1954 | /* Do not allow write past end of page */ | 1954 | /* Do not allow write past end of page */ |
1955 | if ((ops->ooboffs + ops->ooblen) > len) { | 1955 | if ((ops->ooboffs + ops->ooblen) > len) { |
1956 | DEBUG(MTD_DEBUG_LEVEL0, "nand_write_oob: " | 1956 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Attempt to write " |
1957 | "Attempt to write past end of page\n"); | 1957 | "past end of page\n", __func__); |
1958 | return -EINVAL; | 1958 | return -EINVAL; |
1959 | } | 1959 | } |
1960 | 1960 | ||
1961 | if (unlikely(ops->ooboffs >= len)) { | 1961 | if (unlikely(ops->ooboffs >= len)) { |
1962 | DEBUG(MTD_DEBUG_LEVEL0, "nand_do_write_oob: " | 1962 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Attempt to start " |
1963 | "Attempt to start write outside oob\n"); | 1963 | "write outside oob\n", __func__); |
1964 | return -EINVAL; | 1964 | return -EINVAL; |
1965 | } | 1965 | } |
1966 | 1966 | ||
@@ -1969,8 +1969,8 @@ static int nand_do_write_oob(struct mtd_info *mtd, loff_t to, | |||
1969 | ops->ooboffs + ops->ooblen > | 1969 | ops->ooboffs + ops->ooblen > |
1970 | ((mtd->size >> chip->page_shift) - | 1970 | ((mtd->size >> chip->page_shift) - |
1971 | (to >> chip->page_shift)) * len)) { | 1971 | (to >> chip->page_shift)) * len)) { |
1972 | DEBUG(MTD_DEBUG_LEVEL0, "nand_do_write_oob: " | 1972 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Attempt write beyond " |
1973 | "Attempt write beyond end of device\n"); | 1973 | "end of device\n", __func__); |
1974 | return -EINVAL; | 1974 | return -EINVAL; |
1975 | } | 1975 | } |
1976 | 1976 | ||
@@ -2025,8 +2025,8 @@ static int nand_write_oob(struct mtd_info *mtd, loff_t to, | |||
2025 | 2025 | ||
2026 | /* Do not allow writes past end of device */ | 2026 | /* Do not allow writes past end of device */ |
2027 | if (ops->datbuf && (to + ops->len) > mtd->size) { | 2027 | if (ops->datbuf && (to + ops->len) > mtd->size) { |
2028 | DEBUG(MTD_DEBUG_LEVEL0, "nand_write_oob: " | 2028 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Attempt write beyond " |
2029 | "Attempt write beyond end of device\n"); | 2029 | "end of device\n", __func__); |
2030 | return -EINVAL; | 2030 | return -EINVAL; |
2031 | } | 2031 | } |
2032 | 2032 | ||
@@ -2116,26 +2116,27 @@ int nand_erase_nand(struct mtd_info *mtd, struct erase_info *instr, | |||
2116 | unsigned int bbt_masked_page = 0xffffffff; | 2116 | unsigned int bbt_masked_page = 0xffffffff; |
2117 | loff_t len; | 2117 | loff_t len; |
2118 | 2118 | ||
2119 | DEBUG(MTD_DEBUG_LEVEL3, "nand_erase: start = 0x%012llx, len = %llu\n", | 2119 | DEBUG(MTD_DEBUG_LEVEL3, "%s: start = 0x%012llx, len = %llu\n", |
2120 | (unsigned long long)instr->addr, (unsigned long long)instr->len); | 2120 | __func__, (unsigned long long)instr->addr, |
2121 | (unsigned long long)instr->len); | ||
2121 | 2122 | ||
2122 | /* Start address must align on block boundary */ | 2123 | /* Start address must align on block boundary */ |
2123 | if (instr->addr & ((1 << chip->phys_erase_shift) - 1)) { | 2124 | if (instr->addr & ((1 << chip->phys_erase_shift) - 1)) { |
2124 | DEBUG(MTD_DEBUG_LEVEL0, "nand_erase: Unaligned address\n"); | 2125 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Unaligned address\n", __func__); |
2125 | return -EINVAL; | 2126 | return -EINVAL; |
2126 | } | 2127 | } |
2127 | 2128 | ||
2128 | /* Length must align on block boundary */ | 2129 | /* Length must align on block boundary */ |
2129 | if (instr->len & ((1 << chip->phys_erase_shift) - 1)) { | 2130 | if (instr->len & ((1 << chip->phys_erase_shift) - 1)) { |
2130 | DEBUG(MTD_DEBUG_LEVEL0, "nand_erase: " | 2131 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Length not block aligned\n", |
2131 | "Length not block aligned\n"); | 2132 | __func__); |
2132 | return -EINVAL; | 2133 | return -EINVAL; |
2133 | } | 2134 | } |
2134 | 2135 | ||
2135 | /* Do not allow erase past end of device */ | 2136 | /* Do not allow erase past end of device */ |
2136 | if ((instr->len + instr->addr) > mtd->size) { | 2137 | if ((instr->len + instr->addr) > mtd->size) { |
2137 | DEBUG(MTD_DEBUG_LEVEL0, "nand_erase: " | 2138 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Erase past end of device\n", |
2138 | "Erase past end of device\n"); | 2139 | __func__); |
2139 | return -EINVAL; | 2140 | return -EINVAL; |
2140 | } | 2141 | } |
2141 | 2142 | ||
@@ -2156,8 +2157,8 @@ int nand_erase_nand(struct mtd_info *mtd, struct erase_info *instr, | |||
2156 | 2157 | ||
2157 | /* Check, if it is write protected */ | 2158 | /* Check, if it is write protected */ |
2158 | if (nand_check_wp(mtd)) { | 2159 | if (nand_check_wp(mtd)) { |
2159 | DEBUG(MTD_DEBUG_LEVEL0, "nand_erase: " | 2160 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Device is write protected!!!\n", |
2160 | "Device is write protected!!!\n"); | 2161 | __func__); |
2161 | instr->state = MTD_ERASE_FAILED; | 2162 | instr->state = MTD_ERASE_FAILED; |
2162 | goto erase_exit; | 2163 | goto erase_exit; |
2163 | } | 2164 | } |
@@ -2182,8 +2183,8 @@ int nand_erase_nand(struct mtd_info *mtd, struct erase_info *instr, | |||
2182 | */ | 2183 | */ |
2183 | if (nand_block_checkbad(mtd, ((loff_t) page) << | 2184 | if (nand_block_checkbad(mtd, ((loff_t) page) << |
2184 | chip->page_shift, 0, allowbbt)) { | 2185 | chip->page_shift, 0, allowbbt)) { |
2185 | printk(KERN_WARNING "nand_erase: attempt to erase a " | 2186 | printk(KERN_WARNING "%s: attempt to erase a bad block " |
2186 | "bad block at page 0x%08x\n", page); | 2187 | "at page 0x%08x\n", __func__, page); |
2187 | instr->state = MTD_ERASE_FAILED; | 2188 | instr->state = MTD_ERASE_FAILED; |
2188 | goto erase_exit; | 2189 | goto erase_exit; |
2189 | } | 2190 | } |
@@ -2210,8 +2211,8 @@ int nand_erase_nand(struct mtd_info *mtd, struct erase_info *instr, | |||
2210 | 2211 | ||
2211 | /* See if block erase succeeded */ | 2212 | /* See if block erase succeeded */ |
2212 | if (status & NAND_STATUS_FAIL) { | 2213 | if (status & NAND_STATUS_FAIL) { |
2213 | DEBUG(MTD_DEBUG_LEVEL0, "nand_erase: " | 2214 | DEBUG(MTD_DEBUG_LEVEL0, "%s: Failed erase, " |
2214 | "Failed erase, page 0x%08x\n", page); | 2215 | "page 0x%08x\n", __func__, page); |
2215 | instr->state = MTD_ERASE_FAILED; | 2216 | instr->state = MTD_ERASE_FAILED; |
2216 | instr->fail_addr = | 2217 | instr->fail_addr = |
2217 | ((loff_t)page << chip->page_shift); | 2218 | ((loff_t)page << chip->page_shift); |
@@ -2271,9 +2272,9 @@ int nand_erase_nand(struct mtd_info *mtd, struct erase_info *instr, | |||
2271 | if (!rewrite_bbt[chipnr]) | 2272 | if (!rewrite_bbt[chipnr]) |
2272 | continue; | 2273 | continue; |
2273 | /* update the BBT for chip */ | 2274 | /* update the BBT for chip */ |
2274 | DEBUG(MTD_DEBUG_LEVEL0, "nand_erase_nand: nand_update_bbt " | 2275 | DEBUG(MTD_DEBUG_LEVEL0, "%s: nand_update_bbt " |
2275 | "(%d:0x%0llx 0x%0x)\n", chipnr, rewrite_bbt[chipnr], | 2276 | "(%d:0x%0llx 0x%0x)\n", __func__, chipnr, |
2276 | chip->bbt_td->pages[chipnr]); | 2277 | rewrite_bbt[chipnr], chip->bbt_td->pages[chipnr]); |
2277 | nand_update_bbt(mtd, rewrite_bbt[chipnr]); | 2278 | nand_update_bbt(mtd, rewrite_bbt[chipnr]); |
2278 | } | 2279 | } |
2279 | 2280 | ||
@@ -2291,7 +2292,7 @@ static void nand_sync(struct mtd_info *mtd) | |||
2291 | { | 2292 | { |
2292 | struct nand_chip *chip = mtd->priv; | 2293 | struct nand_chip *chip = mtd->priv; |
2293 | 2294 | ||
2294 | DEBUG(MTD_DEBUG_LEVEL3, "nand_sync: called\n"); | 2295 | DEBUG(MTD_DEBUG_LEVEL3, "%s: called\n", __func__); |
2295 | 2296 | ||
2296 | /* Grab the lock and see if the device is available */ | 2297 | /* Grab the lock and see if the device is available */ |
2297 | nand_get_device(chip, mtd, FL_SYNCING); | 2298 | nand_get_device(chip, mtd, FL_SYNCING); |
@@ -2355,8 +2356,8 @@ static void nand_resume(struct mtd_info *mtd) | |||
2355 | if (chip->state == FL_PM_SUSPENDED) | 2356 | if (chip->state == FL_PM_SUSPENDED) |
2356 | nand_release_device(mtd); | 2357 | nand_release_device(mtd); |
2357 | else | 2358 | else |
2358 | printk(KERN_ERR "nand_resume() called for a chip which is not " | 2359 | printk(KERN_ERR "%s called for a chip which is not " |
2359 | "in suspended state\n"); | 2360 | "in suspended state\n", __func__); |
2360 | } | 2361 | } |
2361 | 2362 | ||
2362 | /* | 2363 | /* |
@@ -2857,7 +2858,8 @@ int nand_scan(struct mtd_info *mtd, int maxchips) | |||
2857 | 2858 | ||
2858 | /* Many callers got this wrong, so check for it for a while... */ | 2859 | /* Many callers got this wrong, so check for it for a while... */ |
2859 | if (!mtd->owner && caller_is_module()) { | 2860 | if (!mtd->owner && caller_is_module()) { |
2860 | printk(KERN_CRIT "nand_scan() called with NULL mtd->owner!\n"); | 2861 | printk(KERN_CRIT "%s called with NULL mtd->owner!\n", |
2862 | __func__); | ||
2861 | BUG(); | 2863 | BUG(); |
2862 | } | 2864 | } |
2863 | 2865 | ||