diff options
Diffstat (limited to 'drivers/mtd')
-rw-r--r-- | drivers/mtd/ubi/build.c | 2 | ||||
-rw-r--r-- | drivers/mtd/ubi/cdev.c | 22 | ||||
-rw-r--r-- | drivers/mtd/ubi/ubi.h | 8 | ||||
-rw-r--r-- | drivers/mtd/ubi/upd.c | 8 | ||||
-rw-r--r-- | drivers/mtd/ubi/vmt.c | 6 |
5 files changed, 23 insertions, 23 deletions
diff --git a/drivers/mtd/ubi/build.c b/drivers/mtd/ubi/build.c index e0e8f47f1674..5d8fda1bda7f 100644 --- a/drivers/mtd/ubi/build.c +++ b/drivers/mtd/ubi/build.c | |||
@@ -806,7 +806,7 @@ int ubi_attach_mtd_dev(struct mtd_info *mtd, int ubi_num, int vid_hdr_offset) | |||
806 | 806 | ||
807 | mutex_init(&ubi->buf_mutex); | 807 | mutex_init(&ubi->buf_mutex); |
808 | mutex_init(&ubi->ckvol_mutex); | 808 | mutex_init(&ubi->ckvol_mutex); |
809 | mutex_init(&ubi->volumes_mutex); | 809 | mutex_init(&ubi->device_mutex); |
810 | spin_lock_init(&ubi->volumes_lock); | 810 | spin_lock_init(&ubi->volumes_lock); |
811 | 811 | ||
812 | ubi_msg("attaching mtd%d to ubi%d", mtd->index, ubi_num); | 812 | ubi_msg("attaching mtd%d to ubi%d", mtd->index, ubi_num); |
diff --git a/drivers/mtd/ubi/cdev.c b/drivers/mtd/ubi/cdev.c index 8087b0462771..1024c106c899 100644 --- a/drivers/mtd/ubi/cdev.c +++ b/drivers/mtd/ubi/cdev.c | |||
@@ -558,7 +558,7 @@ static long vol_cdev_ioctl(struct file *file, unsigned int cmd, | |||
558 | break; | 558 | break; |
559 | } | 559 | } |
560 | 560 | ||
561 | /* Set volume property command*/ | 561 | /* Set volume property command */ |
562 | case UBI_IOCSETPROP: | 562 | case UBI_IOCSETPROP: |
563 | { | 563 | { |
564 | struct ubi_set_prop_req req; | 564 | struct ubi_set_prop_req req; |
@@ -571,9 +571,9 @@ static long vol_cdev_ioctl(struct file *file, unsigned int cmd, | |||
571 | } | 571 | } |
572 | switch (req.property) { | 572 | switch (req.property) { |
573 | case UBI_PROP_DIRECT_WRITE: | 573 | case UBI_PROP_DIRECT_WRITE: |
574 | mutex_lock(&ubi->volumes_mutex); | 574 | mutex_lock(&ubi->device_mutex); |
575 | desc->vol->direct_writes = !!req.value; | 575 | desc->vol->direct_writes = !!req.value; |
576 | mutex_unlock(&ubi->volumes_mutex); | 576 | mutex_unlock(&ubi->device_mutex); |
577 | break; | 577 | break; |
578 | default: | 578 | default: |
579 | err = -EINVAL; | 579 | err = -EINVAL; |
@@ -810,7 +810,9 @@ static int rename_volumes(struct ubi_device *ubi, | |||
810 | re->desc->vol->vol_id, re->desc->vol->name); | 810 | re->desc->vol->vol_id, re->desc->vol->name); |
811 | } | 811 | } |
812 | 812 | ||
813 | mutex_lock(&ubi->device_mutex); | ||
813 | err = ubi_rename_volumes(ubi, &rename_list); | 814 | err = ubi_rename_volumes(ubi, &rename_list); |
815 | mutex_unlock(&ubi->device_mutex); | ||
814 | 816 | ||
815 | out_free: | 817 | out_free: |
816 | list_for_each_entry_safe(re, re1, &rename_list, list) { | 818 | list_for_each_entry_safe(re, re1, &rename_list, list) { |
@@ -854,9 +856,9 @@ static long ubi_cdev_ioctl(struct file *file, unsigned int cmd, | |||
854 | if (err) | 856 | if (err) |
855 | break; | 857 | break; |
856 | 858 | ||
857 | mutex_lock(&ubi->volumes_mutex); | 859 | mutex_lock(&ubi->device_mutex); |
858 | err = ubi_create_volume(ubi, &req); | 860 | err = ubi_create_volume(ubi, &req); |
859 | mutex_unlock(&ubi->volumes_mutex); | 861 | mutex_unlock(&ubi->device_mutex); |
860 | if (err) | 862 | if (err) |
861 | break; | 863 | break; |
862 | 864 | ||
@@ -885,9 +887,9 @@ static long ubi_cdev_ioctl(struct file *file, unsigned int cmd, | |||
885 | break; | 887 | break; |
886 | } | 888 | } |
887 | 889 | ||
888 | mutex_lock(&ubi->volumes_mutex); | 890 | mutex_lock(&ubi->device_mutex); |
889 | err = ubi_remove_volume(desc, 0); | 891 | err = ubi_remove_volume(desc, 0); |
890 | mutex_unlock(&ubi->volumes_mutex); | 892 | mutex_unlock(&ubi->device_mutex); |
891 | 893 | ||
892 | /* | 894 | /* |
893 | * The volume is deleted (unless an error occurred), and the | 895 | * The volume is deleted (unless an error occurred), and the |
@@ -924,9 +926,9 @@ static long ubi_cdev_ioctl(struct file *file, unsigned int cmd, | |||
924 | pebs = div_u64(req.bytes + desc->vol->usable_leb_size - 1, | 926 | pebs = div_u64(req.bytes + desc->vol->usable_leb_size - 1, |
925 | desc->vol->usable_leb_size); | 927 | desc->vol->usable_leb_size); |
926 | 928 | ||
927 | mutex_lock(&ubi->volumes_mutex); | 929 | mutex_lock(&ubi->device_mutex); |
928 | err = ubi_resize_volume(desc, pebs); | 930 | err = ubi_resize_volume(desc, pebs); |
929 | mutex_unlock(&ubi->volumes_mutex); | 931 | mutex_unlock(&ubi->device_mutex); |
930 | ubi_close_volume(desc); | 932 | ubi_close_volume(desc); |
931 | break; | 933 | break; |
932 | } | 934 | } |
@@ -950,9 +952,7 @@ static long ubi_cdev_ioctl(struct file *file, unsigned int cmd, | |||
950 | break; | 952 | break; |
951 | } | 953 | } |
952 | 954 | ||
953 | mutex_lock(&ubi->volumes_mutex); | ||
954 | err = rename_volumes(ubi, req); | 955 | err = rename_volumes(ubi, req); |
955 | mutex_unlock(&ubi->volumes_mutex); | ||
956 | kfree(req); | 956 | kfree(req); |
957 | break; | 957 | break; |
958 | } | 958 | } |
diff --git a/drivers/mtd/ubi/ubi.h b/drivers/mtd/ubi/ubi.h index 485c73f850c1..76ec79b156a1 100644 --- a/drivers/mtd/ubi/ubi.h +++ b/drivers/mtd/ubi/ubi.h | |||
@@ -305,9 +305,9 @@ struct ubi_wl_entry; | |||
305 | * @vtbl_slots: how many slots are available in the volume table | 305 | * @vtbl_slots: how many slots are available in the volume table |
306 | * @vtbl_size: size of the volume table in bytes | 306 | * @vtbl_size: size of the volume table in bytes |
307 | * @vtbl: in-RAM volume table copy | 307 | * @vtbl: in-RAM volume table copy |
308 | * @volumes_mutex: protects on-flash volume table and serializes volume | 308 | * @device_mutex: protects on-flash volume table and serializes volume |
309 | * changes, like creation, deletion, update, re-size, | 309 | * creation, deletion, update, re-size, re-name and set |
310 | * re-name and set property | 310 | * property |
311 | * | 311 | * |
312 | * @max_ec: current highest erase counter value | 312 | * @max_ec: current highest erase counter value |
313 | * @mean_ec: current mean erase counter value | 313 | * @mean_ec: current mean erase counter value |
@@ -388,7 +388,7 @@ struct ubi_device { | |||
388 | int vtbl_slots; | 388 | int vtbl_slots; |
389 | int vtbl_size; | 389 | int vtbl_size; |
390 | struct ubi_vtbl_record *vtbl; | 390 | struct ubi_vtbl_record *vtbl; |
391 | struct mutex volumes_mutex; | 391 | struct mutex device_mutex; |
392 | 392 | ||
393 | int max_ec; | 393 | int max_ec; |
394 | /* Note, mean_ec is not updated run-time - should be fixed */ | 394 | /* Note, mean_ec is not updated run-time - should be fixed */ |
diff --git a/drivers/mtd/ubi/upd.c b/drivers/mtd/ubi/upd.c index 6b4d1ae891ae..dce1d92d8e9d 100644 --- a/drivers/mtd/ubi/upd.c +++ b/drivers/mtd/ubi/upd.c | |||
@@ -68,9 +68,9 @@ static int set_update_marker(struct ubi_device *ubi, struct ubi_volume *vol) | |||
68 | sizeof(struct ubi_vtbl_record)); | 68 | sizeof(struct ubi_vtbl_record)); |
69 | vtbl_rec.upd_marker = 1; | 69 | vtbl_rec.upd_marker = 1; |
70 | 70 | ||
71 | mutex_lock(&ubi->volumes_mutex); | 71 | mutex_lock(&ubi->device_mutex); |
72 | err = ubi_change_vtbl_record(ubi, vol->vol_id, &vtbl_rec); | 72 | err = ubi_change_vtbl_record(ubi, vol->vol_id, &vtbl_rec); |
73 | mutex_unlock(&ubi->volumes_mutex); | 73 | mutex_unlock(&ubi->device_mutex); |
74 | vol->upd_marker = 1; | 74 | vol->upd_marker = 1; |
75 | return err; | 75 | return err; |
76 | } | 76 | } |
@@ -109,9 +109,9 @@ static int clear_update_marker(struct ubi_device *ubi, struct ubi_volume *vol, | |||
109 | vol->last_eb_bytes = vol->usable_leb_size; | 109 | vol->last_eb_bytes = vol->usable_leb_size; |
110 | } | 110 | } |
111 | 111 | ||
112 | mutex_lock(&ubi->volumes_mutex); | 112 | mutex_lock(&ubi->device_mutex); |
113 | err = ubi_change_vtbl_record(ubi, vol->vol_id, &vtbl_rec); | 113 | err = ubi_change_vtbl_record(ubi, vol->vol_id, &vtbl_rec); |
114 | mutex_unlock(&ubi->volumes_mutex); | 114 | mutex_unlock(&ubi->device_mutex); |
115 | vol->upd_marker = 0; | 115 | vol->upd_marker = 0; |
116 | return err; | 116 | return err; |
117 | } | 117 | } |
diff --git a/drivers/mtd/ubi/vmt.c b/drivers/mtd/ubi/vmt.c index df5483562b7a..328c1242920e 100644 --- a/drivers/mtd/ubi/vmt.c +++ b/drivers/mtd/ubi/vmt.c | |||
@@ -198,7 +198,7 @@ static void volume_sysfs_close(struct ubi_volume *vol) | |||
198 | * %UBI_VOL_NUM_AUTO, this function automatically assign ID to the new volume | 198 | * %UBI_VOL_NUM_AUTO, this function automatically assign ID to the new volume |
199 | * and saves it in @req->vol_id. Returns zero in case of success and a negative | 199 | * and saves it in @req->vol_id. Returns zero in case of success and a negative |
200 | * error code in case of failure. Note, the caller has to have the | 200 | * error code in case of failure. Note, the caller has to have the |
201 | * @ubi->volumes_mutex locked. | 201 | * @ubi->device_mutex locked. |
202 | */ | 202 | */ |
203 | int ubi_create_volume(struct ubi_device *ubi, struct ubi_mkvol_req *req) | 203 | int ubi_create_volume(struct ubi_device *ubi, struct ubi_mkvol_req *req) |
204 | { | 204 | { |
@@ -403,7 +403,7 @@ out_unlock: | |||
403 | * | 403 | * |
404 | * This function removes volume described by @desc. The volume has to be opened | 404 | * This function removes volume described by @desc. The volume has to be opened |
405 | * in "exclusive" mode. Returns zero in case of success and a negative error | 405 | * in "exclusive" mode. Returns zero in case of success and a negative error |
406 | * code in case of failure. The caller has to have the @ubi->volumes_mutex | 406 | * code in case of failure. The caller has to have the @ubi->device_mutex |
407 | * locked. | 407 | * locked. |
408 | */ | 408 | */ |
409 | int ubi_remove_volume(struct ubi_volume_desc *desc, int no_vtbl) | 409 | int ubi_remove_volume(struct ubi_volume_desc *desc, int no_vtbl) |
@@ -485,7 +485,7 @@ out_unlock: | |||
485 | * | 485 | * |
486 | * This function re-sizes the volume and returns zero in case of success, and a | 486 | * This function re-sizes the volume and returns zero in case of success, and a |
487 | * negative error code in case of failure. The caller has to have the | 487 | * negative error code in case of failure. The caller has to have the |
488 | * @ubi->volumes_mutex locked. | 488 | * @ubi->device_mutex locked. |
489 | */ | 489 | */ |
490 | int ubi_resize_volume(struct ubi_volume_desc *desc, int reserved_pebs) | 490 | int ubi_resize_volume(struct ubi_volume_desc *desc, int reserved_pebs) |
491 | { | 491 | { |