diff options
-rw-r--r-- | drivers/mtd/mtd_blkdevs.c | 6 | ||||
-rw-r--r-- | drivers/mtd/mtdblock.c | 1 | ||||
-rw-r--r-- | drivers/mtd/nand/r852.c | 6 | ||||
-rw-r--r-- | drivers/mtd/sm_ftl.c | 17 |
4 files changed, 18 insertions, 12 deletions
diff --git a/drivers/mtd/mtd_blkdevs.c b/drivers/mtd/mtd_blkdevs.c index 9dd23d6acbb6..e32c49cb4005 100644 --- a/drivers/mtd/mtd_blkdevs.c +++ b/drivers/mtd/mtd_blkdevs.c | |||
@@ -380,9 +380,11 @@ int add_mtd_blktrans_dev(struct mtd_blktrans_dev *new) | |||
380 | 380 | ||
381 | add_disk(gd); | 381 | add_disk(gd); |
382 | 382 | ||
383 | if (new->disk_attributes) | 383 | if (new->disk_attributes) { |
384 | sysfs_create_group(&disk_to_dev(gd)->kobj, | 384 | ret = sysfs_create_group(&disk_to_dev(gd)->kobj, |
385 | new->disk_attributes); | 385 | new->disk_attributes); |
386 | WARN_ON(ret); | ||
387 | } | ||
386 | return 0; | 388 | return 0; |
387 | error4: | 389 | error4: |
388 | module_put(tr->owner); | 390 | module_put(tr->owner); |
diff --git a/drivers/mtd/mtdblock.c b/drivers/mtd/mtdblock.c index 7ce30a239ada..e6edbec609fd 100644 --- a/drivers/mtd/mtdblock.c +++ b/drivers/mtd/mtdblock.c | |||
@@ -354,7 +354,6 @@ static void mtdblock_add_mtd(struct mtd_blktrans_ops *tr, struct mtd_info *mtd) | |||
354 | 354 | ||
355 | static void mtdblock_remove_dev(struct mtd_blktrans_dev *dev) | 355 | static void mtdblock_remove_dev(struct mtd_blktrans_dev *dev) |
356 | { | 356 | { |
357 | struct mtdblk_dev *mtdblk = container_of(dev, struct mtdblk_dev, mbd); | ||
358 | del_mtd_blktrans_dev(dev); | 357 | del_mtd_blktrans_dev(dev); |
359 | } | 358 | } |
360 | 359 | ||
diff --git a/drivers/mtd/nand/r852.c b/drivers/mtd/nand/r852.c index 9307a88e5229..7a616a926ee9 100644 --- a/drivers/mtd/nand/r852.c +++ b/drivers/mtd/nand/r852.c | |||
@@ -654,7 +654,9 @@ int r852_register_nand_device(struct r852_device *dev) | |||
654 | if (sm_register_device(dev->mtd)) | 654 | if (sm_register_device(dev->mtd)) |
655 | goto error2; | 655 | goto error2; |
656 | 656 | ||
657 | device_create_file(&dev->mtd->dev, &dev_attr_media_type); | 657 | if (device_create_file(&dev->mtd->dev, &dev_attr_media_type)) |
658 | message("can't create media type sysfs attribute"); | ||
659 | |||
658 | dev->card_registred = 1; | 660 | dev->card_registred = 1; |
659 | return 0; | 661 | return 0; |
660 | error2: | 662 | error2: |
@@ -838,7 +840,7 @@ int r852_probe(struct pci_dev *pci_dev, const struct pci_device_id *id) | |||
838 | 840 | ||
839 | pci_set_master(pci_dev); | 841 | pci_set_master(pci_dev); |
840 | 842 | ||
841 | error = pci_set_dma_mask(pci_dev, DMA_32BIT_MASK); | 843 | error = pci_set_dma_mask(pci_dev, DMA_BIT_MASK(32)); |
842 | if (error) | 844 | if (error) |
843 | goto error2; | 845 | goto error2; |
844 | 846 | ||
diff --git a/drivers/mtd/sm_ftl.c b/drivers/mtd/sm_ftl.c index a59ebb48cae1..9fb56c76ae89 100644 --- a/drivers/mtd/sm_ftl.c +++ b/drivers/mtd/sm_ftl.c | |||
@@ -228,7 +228,7 @@ static int sm_read_sector(struct sm_ftl *ftl, | |||
228 | struct mtd_info *mtd = ftl->trans->mtd; | 228 | struct mtd_info *mtd = ftl->trans->mtd; |
229 | struct mtd_oob_ops ops; | 229 | struct mtd_oob_ops ops; |
230 | struct sm_oob tmp_oob; | 230 | struct sm_oob tmp_oob; |
231 | int ret; | 231 | int ret = -EIO; |
232 | int try = 0; | 232 | int try = 0; |
233 | 233 | ||
234 | /* FTL can contain -1 entries that are by default filled with bits */ | 234 | /* FTL can contain -1 entries that are by default filled with bits */ |
@@ -753,6 +753,7 @@ static int sm_init_zone(struct sm_ftl *ftl, int zone_num) | |||
753 | uint16_t block; | 753 | uint16_t block; |
754 | int lba; | 754 | int lba; |
755 | int i = 0; | 755 | int i = 0; |
756 | int len; | ||
756 | 757 | ||
757 | dbg("initializing zone %d", zone_num); | 758 | dbg("initializing zone %d", zone_num); |
758 | 759 | ||
@@ -856,7 +857,9 @@ static int sm_init_zone(struct sm_ftl *ftl, int zone_num) | |||
856 | i %= (kfifo_len(&zone->free_sectors) / 2); | 857 | i %= (kfifo_len(&zone->free_sectors) / 2); |
857 | 858 | ||
858 | while (i--) { | 859 | while (i--) { |
859 | kfifo_out(&zone->free_sectors, (unsigned char *)&block, 2); | 860 | len = kfifo_out(&zone->free_sectors, |
861 | (unsigned char *)&block, 2); | ||
862 | WARN_ON(len != 2); | ||
860 | kfifo_in(&zone->free_sectors, (const unsigned char *)&block, 2); | 863 | kfifo_in(&zone->free_sectors, (const unsigned char *)&block, 2); |
861 | } | 864 | } |
862 | return 0; | 865 | return 0; |
@@ -947,17 +950,17 @@ restart: | |||
947 | 950 | ||
948 | if (ftl->unstable) | 951 | if (ftl->unstable) |
949 | return -EIO; | 952 | return -EIO; |
950 | /* No spare blocks */ | 953 | |
951 | /* We could still continue by erasing the current block, | 954 | /* If there are no spare blocks, */ |
955 | /* we could still continue by erasing/writing the current block, | ||
952 | but for such worn out media it doesn't worth the trouble, | 956 | but for such worn out media it doesn't worth the trouble, |
953 | and the dangers */ | 957 | and the dangers */ |
954 | 958 | if (kfifo_out(&zone->free_sectors, | |
955 | if (!kfifo_len(&zone->free_sectors)) { | 959 | (unsigned char *)&write_sector, 2) != 2) { |
956 | dbg("no free sectors for write!"); | 960 | dbg("no free sectors for write!"); |
957 | return -EIO; | 961 | return -EIO; |
958 | } | 962 | } |
959 | 963 | ||
960 | kfifo_out(&zone->free_sectors, (unsigned char *)&write_sector, 2); | ||
961 | 964 | ||
962 | if (sm_write_block(ftl, ftl->cache_data, zone_num, write_sector, | 965 | if (sm_write_block(ftl, ftl->cache_data, zone_num, write_sector, |
963 | ftl->cache_block, ftl->cache_data_invalid_bitmap)) | 966 | ftl->cache_block, ftl->cache_data_invalid_bitmap)) |