Lines Matching refs:flash
71 static int sst25l_status(struct sst25l_flash *flash, int *status) in sst25l_status() argument
87 err = spi_sync(flash->spi, &m); in sst25l_status()
95 static int sst25l_write_enable(struct sst25l_flash *flash, int enable) in sst25l_write_enable() argument
101 err = spi_write(flash->spi, command, 1); in sst25l_write_enable()
106 err = spi_write(flash->spi, command, 1); in sst25l_write_enable()
112 err = spi_write(flash->spi, command, 2); in sst25l_write_enable()
117 err = sst25l_status(flash, &status); in sst25l_write_enable()
127 static int sst25l_wait_till_ready(struct sst25l_flash *flash) in sst25l_wait_till_ready() argument
134 err = sst25l_status(flash, &status); in sst25l_wait_till_ready()
146 static int sst25l_erase_sector(struct sst25l_flash *flash, uint32_t offset) in sst25l_erase_sector() argument
151 err = sst25l_write_enable(flash, 1); in sst25l_erase_sector()
159 err = spi_write(flash->spi, command, 4); in sst25l_erase_sector()
163 err = sst25l_wait_till_ready(flash); in sst25l_erase_sector()
167 return sst25l_write_enable(flash, 0); in sst25l_erase_sector()
172 struct sst25l_flash *flash = to_sst25l_flash(mtd); in sst25l_erase() local
186 mutex_lock(&flash->lock); in sst25l_erase()
188 err = sst25l_wait_till_ready(flash); in sst25l_erase()
190 mutex_unlock(&flash->lock); in sst25l_erase()
195 err = sst25l_erase_sector(flash, addr); in sst25l_erase()
197 mutex_unlock(&flash->lock); in sst25l_erase()
199 dev_err(&flash->spi->dev, "Erase failed\n"); in sst25l_erase()
206 mutex_unlock(&flash->lock); in sst25l_erase()
216 struct sst25l_flash *flash = to_sst25l_flash(mtd); in sst25l_read() local
238 mutex_lock(&flash->lock); in sst25l_read()
241 ret = sst25l_wait_till_ready(flash); in sst25l_read()
243 mutex_unlock(&flash->lock); in sst25l_read()
247 spi_sync(flash->spi, &message); in sst25l_read()
252 mutex_unlock(&flash->lock); in sst25l_read()
259 struct sst25l_flash *flash = to_sst25l_flash(mtd); in sst25l_write() local
266 mutex_lock(&flash->lock); in sst25l_write()
268 ret = sst25l_write_enable(flash, 1); in sst25l_write()
273 ret = sst25l_wait_till_ready(flash); in sst25l_write()
283 ret = spi_write(flash->spi, command, 5); in sst25l_write()
294 ret = sst25l_wait_till_ready(flash); in sst25l_write()
299 ret = spi_write(flash->spi, command, 2); in sst25l_write()
306 ret = sst25l_write_enable(flash, 0); in sst25l_write()
311 mutex_unlock(&flash->lock); in sst25l_write()
358 struct sst25l_flash *flash; in sst25l_probe() local
366 flash = devm_kzalloc(&spi->dev, sizeof(*flash), GFP_KERNEL); in sst25l_probe()
367 if (!flash) in sst25l_probe()
370 flash->spi = spi; in sst25l_probe()
371 mutex_init(&flash->lock); in sst25l_probe()
372 spi_set_drvdata(spi, flash); in sst25l_probe()
376 flash->mtd.name = data->name; in sst25l_probe()
378 flash->mtd.dev.parent = &spi->dev; in sst25l_probe()
379 flash->mtd.type = MTD_NORFLASH; in sst25l_probe()
380 flash->mtd.flags = MTD_CAP_NORFLASH; in sst25l_probe()
381 flash->mtd.erasesize = flash_info->erase_size; in sst25l_probe()
382 flash->mtd.writesize = flash_info->page_size; in sst25l_probe()
383 flash->mtd.writebufsize = flash_info->page_size; in sst25l_probe()
384 flash->mtd.size = flash_info->page_size * flash_info->nr_pages; in sst25l_probe()
385 flash->mtd._erase = sst25l_erase; in sst25l_probe()
386 flash->mtd._read = sst25l_read; in sst25l_probe()
387 flash->mtd._write = sst25l_write; in sst25l_probe()
390 (long long)flash->mtd.size >> 10); in sst25l_probe()
394 flash->mtd.name, in sst25l_probe()
395 (long long)flash->mtd.size, (long long)(flash->mtd.size >> 20), in sst25l_probe()
396 flash->mtd.erasesize, flash->mtd.erasesize / 1024, in sst25l_probe()
397 flash->mtd.numeraseregions); in sst25l_probe()
400 ret = mtd_device_parse_register(&flash->mtd, NULL, NULL, in sst25l_probe()
411 struct sst25l_flash *flash = spi_get_drvdata(spi); in sst25l_remove() local
413 return mtd_device_unregister(&flash->mtd); in sst25l_remove()