blob: a9e2d669acd81d4c7e2bb37c683d489ff6b4e203 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Richard Weinberger78d6d492014-11-10 18:21:51 +01002#ifndef UBI_WL_H
3#define UBI_WL_H
4#ifdef CONFIG_MTD_UBI_FASTMAP
Sascha Hauer889027b2017-11-24 12:14:06 +01005static int anchor_pebs_available(struct rb_root *root);
Richard Weinberger78d6d492014-11-10 18:21:51 +01006static void update_fastmap_work_fn(struct work_struct *wrk);
7static struct ubi_wl_entry *find_anchor_wl_entry(struct rb_root *root);
8static struct ubi_wl_entry *get_peb_for_wl(struct ubi_device *ubi);
9static void ubi_fastmap_close(struct ubi_device *ubi);
Richard Weinbergeracfda792014-10-28 17:07:06 +010010static inline void ubi_fastmap_init(struct ubi_device *ubi, int *count)
11{
12 /* Reserve enough LEBs to store two fastmaps. */
13 *count += (ubi->fm_size / ubi->leb_size) * 2;
14 INIT_WORK(&ubi->fm_work, update_fastmap_work_fn);
15}
Richard Weinberger2f84c2462014-10-29 10:31:41 +010016static struct ubi_wl_entry *may_reserve_for_fm(struct ubi_device *ubi,
17 struct ubi_wl_entry *e,
18 struct rb_root *root);
Richard Weinberger78d6d492014-11-10 18:21:51 +010019#else /* !CONFIG_MTD_UBI_FASTMAP */
20static struct ubi_wl_entry *get_peb_for_wl(struct ubi_device *ubi);
Richard Weinberger78d6d492014-11-10 18:21:51 +010021static inline void ubi_fastmap_close(struct ubi_device *ubi) { }
Richard Weinbergeracfda792014-10-28 17:07:06 +010022static inline void ubi_fastmap_init(struct ubi_device *ubi, int *count) { }
Richard Weinberger2f84c2462014-10-29 10:31:41 +010023static struct ubi_wl_entry *may_reserve_for_fm(struct ubi_device *ubi,
24 struct ubi_wl_entry *e,
25 struct rb_root *root) {
26 return e;
27}
Richard Weinberger78d6d492014-11-10 18:21:51 +010028#endif /* CONFIG_MTD_UBI_FASTMAP */
29#endif /* UBI_WL_H */