Commit e7f35da2 authored by Christophe JAILLET's avatar Christophe JAILLET Committed by Richard Weinberger

ubi: fastmap: Use the bitmap API to allocate bitmaps

Use bitmap_zalloc()/bitmap_free() instead of hand-writing them.

It is less verbose and it improves the semantic.
Signed-off-by: default avatarChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Reviewed-by: default avatarZhihao Cheng <chengzhihao1@huawei.com>
Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
parent a0c51565
...@@ -20,8 +20,7 @@ static inline unsigned long *init_seen(struct ubi_device *ubi) ...@@ -20,8 +20,7 @@ static inline unsigned long *init_seen(struct ubi_device *ubi)
if (!ubi_dbg_chk_fastmap(ubi)) if (!ubi_dbg_chk_fastmap(ubi))
return NULL; return NULL;
ret = kcalloc(BITS_TO_LONGS(ubi->peb_count), sizeof(unsigned long), ret = bitmap_zalloc(ubi->peb_count, GFP_KERNEL);
GFP_KERNEL);
if (!ret) if (!ret)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
...@@ -34,7 +33,7 @@ static inline unsigned long *init_seen(struct ubi_device *ubi) ...@@ -34,7 +33,7 @@ static inline unsigned long *init_seen(struct ubi_device *ubi)
*/ */
static inline void free_seen(unsigned long *seen) static inline void free_seen(unsigned long *seen)
{ {
kfree(seen); bitmap_free(seen);
} }
/** /**
...@@ -1108,8 +1107,7 @@ int ubi_fastmap_init_checkmap(struct ubi_volume *vol, int leb_count) ...@@ -1108,8 +1107,7 @@ int ubi_fastmap_init_checkmap(struct ubi_volume *vol, int leb_count)
if (!ubi->fast_attach) if (!ubi->fast_attach)
return 0; return 0;
vol->checkmap = kcalloc(BITS_TO_LONGS(leb_count), sizeof(unsigned long), vol->checkmap = bitmap_zalloc(leb_count, GFP_KERNEL);
GFP_KERNEL);
if (!vol->checkmap) if (!vol->checkmap)
return -ENOMEM; return -ENOMEM;
...@@ -1118,7 +1116,7 @@ int ubi_fastmap_init_checkmap(struct ubi_volume *vol, int leb_count) ...@@ -1118,7 +1116,7 @@ int ubi_fastmap_init_checkmap(struct ubi_volume *vol, int leb_count)
void ubi_fastmap_destroy_checkmap(struct ubi_volume *vol) void ubi_fastmap_destroy_checkmap(struct ubi_volume *vol)
{ {
kfree(vol->checkmap); bitmap_free(vol->checkmap);
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment