|
@@ -1446,19 +1446,6 @@ int ubi_update_fastmap(struct ubi_device *ubi)
|
|
}
|
|
}
|
|
|
|
|
|
new_fm->used_blocks = ubi->fm_size / ubi->leb_size;
|
|
new_fm->used_blocks = ubi->fm_size / ubi->leb_size;
|
|
-
|
|
|
|
- for (i = 0; i < new_fm->used_blocks; i++) {
|
|
|
|
- new_fm->e[i] = kmem_cache_alloc(ubi_wl_entry_slab, GFP_KERNEL);
|
|
|
|
- if (!new_fm->e[i]) {
|
|
|
|
- while (i--)
|
|
|
|
- kfree(new_fm->e[i]);
|
|
|
|
-
|
|
|
|
- kfree(new_fm);
|
|
|
|
- mutex_unlock(&ubi->fm_mutex);
|
|
|
|
- return -ENOMEM;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
old_fm = ubi->fm;
|
|
old_fm = ubi->fm;
|
|
ubi->fm = NULL;
|
|
ubi->fm = NULL;
|
|
|
|
|
|
@@ -1494,12 +1481,9 @@ int ubi_update_fastmap(struct ubi_device *ubi)
|
|
ubi_err(ubi, "could not erase old fastmap PEB");
|
|
ubi_err(ubi, "could not erase old fastmap PEB");
|
|
goto err;
|
|
goto err;
|
|
}
|
|
}
|
|
-
|
|
|
|
- new_fm->e[i]->pnum = old_fm->e[i]->pnum;
|
|
|
|
- new_fm->e[i]->ec = old_fm->e[i]->ec;
|
|
|
|
|
|
+ new_fm->e[i] = old_fm->e[i];
|
|
} else {
|
|
} else {
|
|
- new_fm->e[i]->pnum = tmp_e->pnum;
|
|
|
|
- new_fm->e[i]->ec = tmp_e->ec;
|
|
|
|
|
|
+ new_fm->e[i] = tmp_e;
|
|
|
|
|
|
if (old_fm)
|
|
if (old_fm)
|
|
ubi_wl_put_fm_peb(ubi, old_fm->e[i], i,
|
|
ubi_wl_put_fm_peb(ubi, old_fm->e[i], i,
|
|
@@ -1524,16 +1508,13 @@ int ubi_update_fastmap(struct ubi_device *ubi)
|
|
i, 0);
|
|
i, 0);
|
|
goto err;
|
|
goto err;
|
|
}
|
|
}
|
|
-
|
|
|
|
- new_fm->e[0]->pnum = old_fm->e[0]->pnum;
|
|
|
|
|
|
+ new_fm->e[0] = old_fm->e[0];
|
|
new_fm->e[0]->ec = ret;
|
|
new_fm->e[0]->ec = ret;
|
|
} else {
|
|
} else {
|
|
/* we've got a new anchor PEB, return the old one */
|
|
/* we've got a new anchor PEB, return the old one */
|
|
ubi_wl_put_fm_peb(ubi, old_fm->e[0], 0,
|
|
ubi_wl_put_fm_peb(ubi, old_fm->e[0], 0,
|
|
old_fm->to_be_tortured[0]);
|
|
old_fm->to_be_tortured[0]);
|
|
-
|
|
|
|
- new_fm->e[0]->pnum = tmp_e->pnum;
|
|
|
|
- new_fm->e[0]->ec = tmp_e->ec;
|
|
|
|
|
|
+ new_fm->e[0] = tmp_e;
|
|
}
|
|
}
|
|
} else {
|
|
} else {
|
|
if (!tmp_e) {
|
|
if (!tmp_e) {
|
|
@@ -1546,9 +1527,7 @@ int ubi_update_fastmap(struct ubi_device *ubi)
|
|
ret = -ENOSPC;
|
|
ret = -ENOSPC;
|
|
goto err;
|
|
goto err;
|
|
}
|
|
}
|
|
-
|
|
|
|
- new_fm->e[0]->pnum = tmp_e->pnum;
|
|
|
|
- new_fm->e[0]->ec = tmp_e->ec;
|
|
|
|
|
|
+ new_fm->e[0] = tmp_e;
|
|
}
|
|
}
|
|
|
|
|
|
down_write(&ubi->work_sem);
|
|
down_write(&ubi->work_sem);
|