Lines Matching full:mtd
3 * OPAL PNOR flash MTD abstraction
16 #include <linux/mtd/mtd.h>
17 #include <linux/mtd/partitions.h>
26 * This driver creates the a Linux MTD abstraction for platform PNOR flash
31 struct mtd_info mtd; member
42 * Don't return -ERESTARTSYS if we can't get a token, the MTD core
46 static int powernv_flash_async_op(struct mtd_info *mtd, enum flash_op op, in powernv_flash_async_op() argument
49 struct powernv_flash *info = (struct powernv_flash *)mtd->priv; in powernv_flash_async_op()
50 struct device *dev = &mtd->dev; in powernv_flash_async_op()
87 * If we return the mtd core will free the in powernv_flash_async_op()
94 * done. However, because the MTD core sends in powernv_flash_async_op()
130 * @mtd: the device
138 static int powernv_flash_read(struct mtd_info *mtd, loff_t from, size_t len, in powernv_flash_read() argument
141 return powernv_flash_async_op(mtd, FLASH_OP_READ, from, in powernv_flash_read()
147 * @mtd: the device
155 static int powernv_flash_write(struct mtd_info *mtd, loff_t to, size_t len, in powernv_flash_write() argument
158 return powernv_flash_async_op(mtd, FLASH_OP_WRITE, to, in powernv_flash_write()
164 * @mtd: the device
168 static int powernv_flash_erase(struct mtd_info *mtd, struct erase_info *erase) in powernv_flash_erase() argument
172 rc = powernv_flash_async_op(mtd, FLASH_OP_ERASE, erase->addr, in powernv_flash_erase()
183 * @mtd: The structure to fill
186 struct mtd_info *mtd) in powernv_flash_set_driver_info() argument
209 mtd->name = devm_kasprintf(dev, GFP_KERNEL, "%pOFP", dev->of_node); in powernv_flash_set_driver_info()
210 if (!mtd->name) in powernv_flash_set_driver_info()
213 mtd->type = MTD_NORFLASH; in powernv_flash_set_driver_info()
214 mtd->flags = MTD_WRITEABLE; in powernv_flash_set_driver_info()
215 mtd->size = size; in powernv_flash_set_driver_info()
216 mtd->erasesize = erase_size; in powernv_flash_set_driver_info()
217 mtd->writebufsize = mtd->writesize = 1; in powernv_flash_set_driver_info()
218 mtd->owner = THIS_MODULE; in powernv_flash_set_driver_info()
219 mtd->_erase = powernv_flash_erase; in powernv_flash_set_driver_info()
220 mtd->_read = powernv_flash_read; in powernv_flash_set_driver_info()
221 mtd->_write = powernv_flash_write; in powernv_flash_set_driver_info()
222 mtd->dev.parent = dev; in powernv_flash_set_driver_info()
223 mtd_set_of_node(mtd, dev->of_node); in powernv_flash_set_driver_info()
243 data->mtd.priv = data; in powernv_flash_probe()
251 ret = powernv_flash_set_driver_info(dev, &data->mtd); in powernv_flash_probe()
262 return mtd_device_register(&data->mtd, NULL, 0); in powernv_flash_probe()
276 WARN_ON(mtd_device_unregister(&data->mtd)); in powernv_flash_release()
298 MODULE_DESCRIPTION("MTD abstraction for OPAL flash");