Lines Matching refs:mtd

63 	struct mtd_info *mtd;  member
89 struct mtd_info *mtd = cxt->mtd; in mtdoops_erase_block() local
90 u32 start_page_offset = mtd_div_by_eb(offset, mtd) * mtd->erasesize; in mtdoops_erase_block()
92 u32 erase_pages = mtd->erasesize / record_size; in mtdoops_erase_block()
98 erase.len = mtd->erasesize; in mtdoops_erase_block()
100 ret = mtd_erase(mtd, &erase); in mtdoops_erase_block()
138 struct mtd_info *mtd = cxt->mtd; in mtdoops_workfunc_erase() local
142 if (!mtd) in mtdoops_workfunc_erase()
145 mod = (cxt->nextpage * record_size) % mtd->erasesize; in mtdoops_workfunc_erase()
147 cxt->nextpage = cxt->nextpage + ((mtd->erasesize - mod) / record_size); in mtdoops_workfunc_erase()
152 while ((ret = mtd_block_isbad(mtd, cxt->nextpage * record_size)) > 0) { in mtdoops_workfunc_erase()
157 cxt->nextpage = cxt->nextpage + (mtd->erasesize / record_size); in mtdoops_workfunc_erase()
160 if (i == cxt->oops_pages / (mtd->erasesize / record_size)) { in mtdoops_workfunc_erase()
181 ret = mtd_block_markbad(mtd, cxt->nextpage * record_size); in mtdoops_workfunc_erase()
192 struct mtd_info *mtd = cxt->mtd; in mtdoops_write() local
203 ret = mtd_panic_write(mtd, cxt->nextpage * record_size, in mtdoops_write()
210 ret = mtd_write(mtd, cxt->nextpage * record_size, in mtdoops_write()
232 struct mtd_info *mtd = cxt->mtd; in find_next_position() local
238 if (mtd_block_isbad(mtd, page * record_size)) in find_next_position()
242 ret = mtd_read(mtd, page * record_size, MTDOOPS_HEADER_SIZE, in find_next_position()
304 static void mtdoops_notify_add(struct mtd_info *mtd) in mtdoops_notify_add() argument
307 u64 mtdoops_pages = div_u64(mtd->size, record_size); in mtdoops_notify_add()
310 if (!strcmp(mtd->name, mtddev)) in mtdoops_notify_add()
311 cxt->mtd_index = mtd->index; in mtdoops_notify_add()
313 if (mtd->index != cxt->mtd_index || cxt->mtd_index < 0) in mtdoops_notify_add()
316 if (mtd->size < mtd->erasesize * 2) { in mtdoops_notify_add()
318 mtd->index); in mtdoops_notify_add()
321 if (mtd->erasesize < record_size) { in mtdoops_notify_add()
323 mtd->index); in mtdoops_notify_add()
326 if (mtd->size > MTDOOPS_MAX_MTD_SIZE) { in mtdoops_notify_add()
328 mtd->index, MTDOOPS_MAX_MTD_SIZE / 1024 / 1024); in mtdoops_notify_add()
352 cxt->mtd = mtd; in mtdoops_notify_add()
353 cxt->oops_pages = (int)mtd->size / record_size; in mtdoops_notify_add()
355 printk(KERN_INFO "mtdoops: Attached to MTD device %d\n", mtd->index); in mtdoops_notify_add()
358 static void mtdoops_notify_remove(struct mtd_info *mtd) in mtdoops_notify_remove() argument
362 if (mtd->index != cxt->mtd_index || cxt->mtd_index < 0) in mtdoops_notify_remove()
368 cxt->mtd = NULL; in mtdoops_notify_remove()