Lines Matching full:adr

97 static int get_chip(struct map_info *map, struct flchip *chip, unsigned long adr, int mode);
98 static void put_chip(struct map_info *map, struct flchip *chip, unsigned long adr);
130 unsigned long adr) in cfi_check_err_status() argument
140 status = map_read(map, adr); in cfi_check_err_status()
558 unsigned long adr) in cfi_fixup_m29ew_erase_suspend() argument
563 map_write(map, CMD(0xF0), adr); in cfi_fixup_m29ew_erase_suspend()
639 __u16 adr = primary?cfi->cfiq->P_ADR:cfi->cfiq->A_ADR; in cfi_cmdset_0002() local
642 extp = (struct cfi_pri_amdstd*)cfi_read_pri(map, adr, sizeof(*extp), "Amd/Fujitsu"); in cfi_cmdset_0002()
873 static int get_chip(struct map_info *map, struct flchip *chip, unsigned long adr, int mode) in get_chip() argument
887 if (chip_ready(map, chip, adr, NULL)) in get_chip()
914 if ((adr & chip->in_progress_block_mask) == in get_chip()
926 if (chip_ready(map, chip, adr, NULL)) in get_chip()
935 put_chip(map, chip, adr); in get_chip()
979 static void put_chip(struct map_info *map, struct flchip *chip, unsigned long adr) in put_chip() argument
1021 unsigned long adr) in xip_disable() argument
1024 (void) map_read(map, adr); /* ensure mmu mapping is up to date */ in xip_disable()
1029 unsigned long adr) in xip_enable() argument
1034 map_write(map, CMD(0xf0), adr); in xip_enable()
1037 (void) map_read(map, adr); in xip_enable()
1056 unsigned long adr, int usec) in xip_udelay() argument
1079 map_write(map, CMD(0xb0), adr); in xip_udelay()
1092 status = map_read(map, adr); in xip_udelay()
1101 map_write(map, CMD(0xf0), adr); in xip_udelay()
1102 (void) map_read(map, adr); in xip_udelay()
1129 cfi_fixup_m29ew_erase_suspend(map, adr); in xip_udelay()
1131 map_write(map, cfi->sector_erase_cmd, adr); in xip_udelay()
1142 status = map_read(map, adr); in xip_udelay()
1147 #define UDELAY(map, chip, adr, usec) xip_udelay(map, chip, adr, usec) argument
1159 #define INVALIDATE_CACHE_UDELAY(map, chip, adr, len, usec) \ argument
1160 UDELAY(map, chip, adr, usec)
1181 #define xip_disable(map, chip, adr) argument
1182 #define xip_enable(map, chip, adr) argument
1185 #define UDELAY(map, chip, adr, usec) \ argument
1192 #define INVALIDATE_CACHE_UDELAY(map, chip, adr, len, usec) \ argument
1195 INVALIDATE_CACHED_RANGE(map, adr, len); \
1202 static inline int do_read_onechip(struct map_info *map, struct flchip *chip, loff_t adr, size_t len… in do_read_onechip() argument
1208 adr += chip->start; in do_read_onechip()
1211 cmd_addr = adr & ~(map_bankwidth(map)-1); in do_read_onechip()
1225 map_copy_from(map, buf, adr, len); in do_read_onechip()
1272 loff_t adr, size_t len, u_char *buf, size_t grouplen);
1275 loff_t adr, size_t len) in otp_enter() argument
1286 INVALIDATE_CACHED_RANGE(map, chip->start + adr, len); in otp_enter()
1290 loff_t adr, size_t len) in otp_exit() argument
1303 INVALIDATE_CACHED_RANGE(map, chip->start + adr, len); in otp_exit()
1307 struct flchip *chip, loff_t adr, in do_read_secsi_onechip() argument
1328 adr += chip->start; in do_read_secsi_onechip()
1332 otp_enter(map, chip, adr, len); in do_read_secsi_onechip()
1333 map_copy_from(map, buf, adr, len); in do_read_secsi_onechip()
1334 otp_exit(map, chip, adr, len); in do_read_secsi_onechip()
1382 unsigned long adr, map_word datum,
1385 static int do_otp_write(struct map_info *map, struct flchip *chip, loff_t adr, in do_otp_write() argument
1390 unsigned long bus_ofs = adr & ~(map_bankwidth(map)-1); in do_otp_write()
1391 int gap = adr - bus_ofs; in do_otp_write()
1407 adr += n; in do_otp_write()
1415 static int do_otp_lock(struct map_info *map, struct flchip *chip, loff_t adr, in do_otp_lock() argument
1424 if ((adr != 0) || (len != grouplen)) in do_otp_lock()
1457 if (chip_ready(map, chip, adr, NULL)) in do_otp_lock()
1645 unsigned long adr, map_word datum, in do_write_oneword_once() argument
1664 map_write(map, datum, adr); in do_write_oneword_once()
1668 adr, map_bankwidth(map), in do_write_oneword_once()
1693 !chip_good(map, chip, adr, &datum)) { in do_write_oneword_once()
1694 xip_enable(map, chip, adr); in do_write_oneword_once()
1696 xip_disable(map, chip, adr); in do_write_oneword_once()
1701 if (chip_good(map, chip, adr, &datum)) { in do_write_oneword_once()
1702 if (cfi_check_err_status(map, chip, adr)) in do_write_oneword_once()
1708 UDELAY(map, chip, adr, 1); in do_write_oneword_once()
1716 unsigned long adr, int mode) in do_write_oneword_start() argument
1722 ret = get_chip(map, chip, adr, mode); in do_write_oneword_start()
1729 otp_enter(map, chip, adr, map_bankwidth(map)); in do_write_oneword_start()
1736 unsigned long adr, int mode) in do_write_oneword_done() argument
1739 otp_exit(map, chip, adr, map_bankwidth(map)); in do_write_oneword_done()
1743 put_chip(map, chip, adr); in do_write_oneword_done()
1750 unsigned long adr, map_word datum, in do_write_oneword_retry() argument
1764 oldd = map_read(map, adr); in do_write_oneword_retry()
1770 XIP_INVAL_CACHED_RANGE(map, adr, map_bankwidth(map)); in do_write_oneword_retry()
1772 xip_disable(map, chip, adr); in do_write_oneword_retry()
1775 ret = do_write_oneword_once(map, chip, adr, datum, mode, cfi); in do_write_oneword_retry()
1784 xip_enable(map, chip, adr); in do_write_oneword_retry()
1790 unsigned long adr, map_word datum, in do_write_oneword() argument
1795 adr += chip->start; in do_write_oneword()
1797 pr_debug("MTD %s(): WRITE 0x%.8lx(0x%.8lx)\n", __func__, adr, in do_write_oneword()
1800 ret = do_write_oneword_start(map, chip, adr, mode); in do_write_oneword()
1804 ret = do_write_oneword_retry(map, chip, adr, datum, mode); in do_write_oneword()
1806 do_write_oneword_done(map, chip, adr, mode); in do_write_oneword()
1937 struct flchip *chip, unsigned long adr, in do_write_buffer_wait() argument
1971 !chip_good(map, chip, adr, &datum)) { in do_write_buffer_wait()
1973 __func__, adr); in do_write_buffer_wait()
1978 if (chip_good(map, chip, adr, &datum)) { in do_write_buffer_wait()
1979 if (cfi_check_err_status(map, chip, adr)) in do_write_buffer_wait()
1985 UDELAY(map, chip, adr, 1); in do_write_buffer_wait()
2017 unsigned long adr, const u_char *buf, in do_write_buffer() argument
2026 adr += chip->start; in do_write_buffer()
2027 cmd_adr = adr; in do_write_buffer()
2030 ret = get_chip(map, chip, adr, FL_WRITING); in do_write_buffer()
2039 __func__, adr, datum.x[0]); in do_write_buffer()
2041 XIP_INVAL_CACHED_RANGE(map, adr, len); in do_write_buffer()
2060 map_write(map, datum, adr + z); in do_write_buffer()
2067 adr += z; in do_write_buffer()
2074 adr, map_bankwidth(map), in do_write_buffer()
2077 ret = do_write_buffer_wait(map, chip, adr, datum); in do_write_buffer()
2081 xip_enable(map, chip, adr); in do_write_buffer()
2085 put_chip(map, chip, adr); in do_write_buffer()
2177 unsigned long adr) in cfi_amdstd_panic_wait() argument
2187 if (chip->state == FL_READY && chip_ready(map, chip, adr, NULL)) in cfi_amdstd_panic_wait()
2204 if (chip_ready(map, chip, adr, NULL)) in cfi_amdstd_panic_wait()
2229 unsigned long adr, map_word datum) in do_panic_write_oneword() argument
2238 adr += chip->start; in do_panic_write_oneword()
2240 ret = cfi_amdstd_panic_wait(map, chip, adr); in do_panic_write_oneword()
2245 __func__, adr, datum.x[0]); in do_panic_write_oneword()
2253 oldd = map_read(map, adr); in do_panic_write_oneword()
2265 map_write(map, datum, adr); in do_panic_write_oneword()
2268 if (chip_ready(map, chip, adr, NULL)) in do_panic_write_oneword()
2274 if (!chip_ready(map, chip, adr, &datum) || in do_panic_write_oneword()
2275 cfi_check_err_status(map, chip, adr)) { in do_panic_write_oneword()
2412 unsigned long int adr; in do_erase_chip() local
2418 adr = cfi->addr_unlock1; in do_erase_chip()
2421 ret = get_chip(map, chip, adr, FL_ERASING); in do_erase_chip()
2430 XIP_INVAL_CACHED_RANGE(map, adr, map->size); in do_erase_chip()
2432 xip_disable(map, chip, adr); in do_erase_chip()
2444 chip->in_progress_block_addr = adr; in do_erase_chip()
2448 adr, map->size, in do_erase_chip()
2471 if (chip_ready(map, chip, adr, &datum)) { in do_erase_chip()
2472 if (cfi_check_err_status(map, chip, adr)) in do_erase_chip()
2485 UDELAY(map, chip, adr, 1000000/HZ); in do_erase_chip()
2500 xip_enable(map, chip, adr); in do_erase_chip()
2502 put_chip(map, chip, adr); in do_erase_chip()
2509 static int __xipram do_erase_oneblock(struct map_info *map, struct flchip *chip, unsigned long adr,… in do_erase_oneblock() argument
2518 adr += chip->start; in do_erase_oneblock()
2521 ret = get_chip(map, chip, adr, FL_ERASING); in do_erase_oneblock()
2528 __func__, adr); in do_erase_oneblock()
2530 XIP_INVAL_CACHED_RANGE(map, adr, len); in do_erase_oneblock()
2532 xip_disable(map, chip, adr); in do_erase_oneblock()
2540 map_write(map, cfi->sector_erase_cmd, adr); in do_erase_oneblock()
2544 chip->in_progress_block_addr = adr; in do_erase_oneblock()
2548 adr, len, in do_erase_oneblock()
2571 if (chip_ready(map, chip, adr, &datum)) { in do_erase_oneblock()
2572 if (cfi_check_err_status(map, chip, adr)) in do_erase_oneblock()
2585 UDELAY(map, chip, adr, 1000000/HZ); in do_erase_oneblock()
2600 xip_enable(map, chip, adr); in do_erase_oneblock()
2602 put_chip(map, chip, adr); in do_erase_oneblock()
2630 unsigned long adr, int len, void *thunk) in do_atmel_lock() argument
2636 ret = get_chip(map, chip, adr + chip->start, FL_LOCKING); in do_atmel_lock()
2641 pr_debug("MTD %s(): LOCK 0x%08lx len %d\n", __func__, adr, len); in do_atmel_lock()
2653 map_write(map, CMD(0x40), chip->start + adr); in do_atmel_lock()
2656 put_chip(map, chip, adr + chip->start); in do_atmel_lock()
2665 unsigned long adr, int len, void *thunk) in do_atmel_unlock() argument
2671 ret = get_chip(map, chip, adr + chip->start, FL_UNLOCKING); in do_atmel_unlock()
2676 pr_debug("MTD %s(): LOCK 0x%08lx len %d\n", __func__, adr, len); in do_atmel_unlock()
2680 map_write(map, CMD(0x70), adr); in do_atmel_unlock()
2683 put_chip(map, chip, adr + chip->start); in do_atmel_unlock()
2707 unsigned long adr; member
2717 unsigned long adr, int len, void *thunk) in do_ppb_xxlock() argument
2723 adr += chip->start; in do_ppb_xxlock()
2725 ret = get_chip(map, chip, adr, FL_LOCKING); in do_ppb_xxlock()
2731 pr_debug("MTD %s(): XXLOCK 0x%08lx len %d\n", __func__, adr, len); in do_ppb_xxlock()
2743 map_write(map, CMD(0xA0), adr); in do_ppb_xxlock()
2744 map_write(map, CMD(0x00), adr); in do_ppb_xxlock()
2756 ret = !cfi_read_query(map, adr); in do_ppb_xxlock()
2765 if (chip_ready(map, chip, adr, NULL)) in do_ppb_xxlock()
2774 UDELAY(map, chip, adr, 1); in do_ppb_xxlock()
2782 put_chip(map, chip, adr); in do_ppb_xxlock()
2802 unsigned long adr; in cfi_ppb_unlock() local
2831 adr = 0; in cfi_ppb_unlock()
2846 sect[sectors].adr = adr; in cfi_ppb_unlock()
2848 map, &cfi->chips[chipnum], adr, 0, in cfi_ppb_unlock()
2852 adr += size; in cfi_ppb_unlock()
2859 if (adr >> cfi->chipshift) { in cfi_ppb_unlock()
2862 adr = 0; in cfi_ppb_unlock()
2892 do_ppb_xxlock(map, sect[i].chip, sect[i].adr, 0, in cfi_ppb_unlock()