Lines Matching refs:mtd
9 #include <linux/mtd/mtd.h>
16 #define to_efx_mtd_partition(mtd) \
17 container_of(mtd, struct efx_mtd_partition, mtd)
21 static int efx_mtd_erase(struct mtd_info *mtd, struct erase_info *erase)
23 struct efx_nic *efx = mtd->priv;
25 return efx->type->mtd_erase(mtd, erase->addr, erase->len);
28 static void efx_mtd_sync(struct mtd_info *mtd)
30 struct efx_mtd_partition *part = to_efx_mtd_partition(mtd);
31 struct efx_nic *efx = mtd->priv;
34 rc = efx->type->mtd_sync(mtd);
45 rc = mtd_device_unregister(&part->mtd);
64 part->mtd.writesize = 1;
66 if (!(part->mtd.flags & MTD_NO_ERASE))
67 part->mtd.flags |= MTD_WRITEABLE;
69 part->mtd.owner = THIS_MODULE;
70 part->mtd.priv = efx;
71 part->mtd.name = part->name;
72 part->mtd._erase = efx_mtd_erase;
73 part->mtd._read = efx->type->mtd_read;
74 part->mtd._write = efx->type->mtd_write;
75 part->mtd._sync = efx_mtd_sync;
79 if (mtd_device_register(&part->mtd, NULL, 0))