123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- /* SPDX-License-Identifier: GPL 2.0+ OR BSD-3-Clause */
- /*
- * Copyright (c) Thomas Gleixner <tglx@linutronix.de>
- */
- #ifndef _UBOOT_MTD_UBISPL_H
- #define _UBOOT_MTD_UBISPL_H
- #include "../ubi/ubi-media.h"
- #include "ubi-wrapper.h"
- /*
- * The maximum number of volume ids we scan. So you can load volume id
- * 0 to (CONFIG_SPL_UBI_VOL_ID_MAX - 1)
- */
- #define UBI_SPL_VOL_IDS CONFIG_SPL_UBI_VOL_IDS
- /*
- * The size of the read buffer for the fastmap blocks. In theory up to
- * UBI_FM_MAX_BLOCKS * CONFIG_SPL_MAX_PEB_SIZE. In practice today
- * one or two blocks.
- */
- #define UBI_FM_BUF_SIZE (UBI_FM_MAX_BLOCKS*CONFIG_SPL_UBI_MAX_PEB_SIZE)
- /*
- * The size of the bitmaps for the attach/ scan
- */
- #define UBI_FM_BM_SIZE ((CONFIG_SPL_UBI_MAX_PEBS / BITS_PER_LONG) + 1)
- /*
- * The maximum number of logical erase blocks per loadable volume
- */
- #define UBI_MAX_VOL_LEBS CONFIG_SPL_UBI_MAX_VOL_LEBS
- /*
- * The bitmap size for the above to denote the found blocks inside the volume
- */
- #define UBI_VOL_BM_SIZE ((UBI_MAX_VOL_LEBS / BITS_PER_LONG) + 1)
- /**
- * struct ubi_vol_info - UBISPL internal volume represenation
- * @last_block: The last block (highest LEB) found for this volume
- * @found: Bitmap to mark found LEBS
- * @lebs_to_pebs: LEB to PEB translation table
- */
- struct ubi_vol_info {
- u32 last_block;
- unsigned long found[UBI_VOL_BM_SIZE];
- u32 lebs_to_pebs[UBI_MAX_VOL_LEBS];
- };
- /**
- * struct ubi_scan_info - UBISPL internal data for FM attach and full scan
- *
- * @read: Read function to access the flash provided by the caller
- * @peb_count: Number of physical erase blocks in the UBI FLASH area
- * aka MTD partition.
- * @peb_offset: Offset of PEB0 in the UBI FLASH area (aka MTD partition)
- * to the real start of the FLASH in erase blocks.
- * @fsize_mb: Size of the scanned FLASH area in MB (stats only)
- * @vid_offset: Offset from the start of a PEB to the VID header
- * @leb_start: Offset from the start of a PEB to the data area
- * @leb_size: Size of the data area
- *
- * @fastmap_pebs: Counter of PEBs "attached" by fastmap
- * @fastmap_anchor: The anchor PEB of the fastmap
- * @fm_sb: The fastmap super block data
- * @fm_vh: The fastmap VID header
- * @fm: Pointer to the fastmap layout
- * @fm_layout: The fastmap layout itself
- * @fm_pool: The pool of PEBs to scan at fastmap attach time
- * @fm_wl_pool: The pool of PEBs scheduled for wearleveling
- *
- * @fm_enabled: Indicator whether fastmap attachment is enabled.
- * @fm_used: Bitmap to indicate the PEBS covered by fastmap
- * @scanned: Bitmap to indicate the PEBS of which the VID header
- * hase been physically scanned.
- * @corrupt: Bitmap to indicate corrupt blocks
- * @toload: Bitmap to indicate the volumes which should be loaded
- *
- * @blockinfo: The vid headers of the scanned blocks
- * @volinfo: The volume information of the interesting (toload)
- * volumes
- *
- * @fm_buf: The large fastmap attach buffer
- */
- struct ubi_scan_info {
- ubispl_read_flash read;
- unsigned int fsize_mb;
- unsigned int peb_count;
- unsigned int peb_offset;
- unsigned long vid_offset;
- unsigned long leb_start;
- unsigned long leb_size;
- /* Fastmap: The upstream required fields */
- int fastmap_pebs;
- int fastmap_anchor;
- size_t fm_size;
- struct ubi_fm_sb fm_sb;
- struct ubi_vid_hdr fm_vh;
- struct ubi_fastmap_layout *fm;
- struct ubi_fastmap_layout fm_layout;
- struct ubi_fm_pool fm_pool;
- struct ubi_fm_pool fm_wl_pool;
- /* Fastmap: UBISPL specific data */
- int fm_enabled;
- unsigned long fm_used[UBI_FM_BM_SIZE];
- unsigned long scanned[UBI_FM_BM_SIZE];
- unsigned long corrupt[UBI_FM_BM_SIZE];
- unsigned long toload[UBI_FM_BM_SIZE];
- /* Data for storing the VID and volume information */
- struct ubi_vol_info volinfo[UBI_SPL_VOL_IDS];
- struct ubi_vid_hdr blockinfo[CONFIG_SPL_UBI_MAX_PEBS];
- /* The large buffer for the fastmap */
- uint8_t fm_buf[UBI_FM_BUF_SIZE];
- };
- #ifdef CFG_DEBUG
- #define ubi_dbg(fmt, ...) printf("UBI: debug:" fmt "\n", ##__VA_ARGS__)
- #else
- #define ubi_dbg(fmt, ...)
- #endif
- #ifdef CONFIG_UBI_SILENCE_MSG
- #define ubi_msg(fmt, ...)
- #else
- #define ubi_msg(fmt, ...) printf("UBI: " fmt "\n", ##__VA_ARGS__)
- #endif
- /* UBI warning messages */
- #define ubi_warn(fmt, ...) printf("UBI warning: " fmt "\n", ##__VA_ARGS__)
- /* UBI error messages */
- #define ubi_err(fmt, ...) printf("UBI error: " fmt "\n", ##__VA_ARGS__)
- #endif
|