[U-Boot] Problem with attaching UBI partition
Bakhvalov, Denis (Nokia - PL/Wroclaw)
denis.bakhvalov at nokia.com
Mon Feb 22 15:17:27 CET 2016
Dear U-Boot support,
I have problems while running following commands in U-Boot:
U-Boot => sf probe 0 0 0
SF: Detected S25FL512S with page size 512, total: 67108864
U-Boot => mtdparts
device nor0 <snor0>, # parts = 4
#: name size offset mask_flags
0: boot 0x00100000 0x00000000 0
1: bootenv 0x00080000 0x00100000 0
2: SomeInfo 0x01980000 0x00180000 0
3: ubifspart 0x02500000 0x01b00000 0
U-Boot => ubi part ubifspart
mtd: Giving out device 1 to mtd=3
ubi0: attaching mtd1
UBI DBG gen (pid 1): sizeof(struct ubi_ainf_peb) 48
UBI DBG gen (pid 1): sizeof(struct ubi_wl_entry) 20
UBI DBG gen (pid 1): min_io_size 1
UBI DBG gen (pid 1): max_write_size 512
UBI DBG gen (pid 1): hdrs_min_io_size 1
UBI DBG gen (pid 1): ec_hdr_alsize 64
UBI DBG gen (pid 1): vid_hdr_alsize 64
UBI DBG gen (pid 1): vid_hdr_offset 64
UBI DBG gen (pid 1): vid_hdr_aloffset 64
UBI DBG gen (pid 1): vid_hdr_shift 0
UBI DBG gen (pid 1): leb_start 128
UBI DBG gen (pid 1): max_erroneous 16
UBI DBG gen (pid 1): process PEB 0
UBI DBG bld (pid 1): scan PEB 0
UBI DBG io (pid 1): read EC header from PEB 0
UBI DBG io (pid 1): read 64 bytes from PEB 0:0
ubi0 warning: ubi_io_read_ec_hdr: bad magic number at PEB 0: ff554249 instead of 55424923
Erase counter header dump:
magic 0xff554249
version 35
ec 0
vid_hdr_offset 16777216
data_offset 1073741824
image_seq -2142856561
hdr_crc 0xe046ed
erase counter header hexdump:
UBI DBG bld (pid 1): bad magic number at PEB 0: ff554249 instead of 55424923
UBI DBG io (pid 1): read VID header from PEB 0
UBI DBG io (pid 1): read 64 bytes from PEB 0:64
UBI DBG bld (pid 1): no VID header found at PEB 0, only 0xFF bytes
UBI DBG bld (pid 1): add to erase: PEB 0, EC -1
... // this warning goes for all PEBs from 1 to 147
ubi0: scanning is finished
UBI DBG gen (pid 1): max. sequence number: 0
ubi0 error: ubi_read_volume_table: the layout volume was not found
ubi0 error: ubi_attach_mtd_dev: failed to attach mtd1, error -22
UBI error: cannot attach mtd1
UBI error: cannot initialize UBI, error -22
UBI init error 22
UBI init error 22
For me it looks like this magic number is shifted one byte right, although I can't understand why.
Here is how I create UBI partition in Linux env:
Linux Env #> mtdinfo -a
mtd5
Name: data
Type: nor
Eraseblock size: 262144 bytes, 256.0 KiB
Amount of eraseblocks: 148 (38797312 bytes, 37.0 MiB)
Minimum input/output unit size: 1 byte
Sub-page size: 1 byte
Character device major/minor: 90:10
Bad blocks are allowed: false
Device is writable: true
Linux Env #> ubiformat /dev/mtd5
ubiformat: mtd5 (nor), size 38797312 bytes (37.0 MiB), 148 eraseblocks of 262144 bytes (256.0 KiB), min. I/O size 1 bytes
libscan: scanning eraseblock 147 -- 100 % complete
ubiformat: 148 eraseblocks are supposedly empty
ubiformat: formatting eraseblock 147 -- 100 % complete 797312
Linux Env #> ubiattach -m 5 /dev/ubi_ctrl
UBI: attaching mtd5 to ubi0
UBI: scanning is finished
UBI: attached mtd5 (name "part5", size 37 MiB) to ubi0
UBI: PEB size: 262144 bytes (256 KiB), LEB size: 262016 bytes
UBI: min./max. I/O unit sizes: 1/256, sub-page size 1
UBI: VID header offset: 64 (aligned 64), data offset: 128
UBI: good PEBs: 148, bad PEBs: 0, corrupted PEBs: 0
UBI: user volume: 0, internal volumes: 1, max. volumes count: 128
UBI: max/mean erase counter: 2/1, WL threshold: 4096, image sequence number: 1371523162
UBI: available PEBs: 144, total reserved PEBs: 4, PEBs reserved for bad PEB handling: 0
UBI: background thread "ubi_bgt0d" started, PID 1003
Linux Env #> ubimkvol -N data -m /dev/ubi0
Linux Env #> mount -t ubifs ubi0:data /mnt
Linux Env #> mount -t ubifs ubi0:data /mnt
UBIFS: default file-system created
UBIFS: background thread "ubifs_bgt0_0" started, PID 1010
UBIFS: mounted UBI device 0, volume 0, name "data"
UBIFS: LEB size: 262016 bytes (255 KiB), min./max. I/O unit sizes: 8 bytes/256 bytes
UBIFS: FS size: 35110144 bytes (33 MiB, 134 LEBs), journal size 2096129 bytes (1 MiB, 7 LEBs)
UBIFS: reserved for root: 1658338 bytes (1619 KiB)
UBIFS: media format: w4/r0 (latest is w4/r0), UUID 696FFD7B-1957-4ABD-9FDC-ED0EEB674D9D, small LPT model
It's perfectly working from Linux env, however U-Boot don't want to attach UBI partition.
Please help me identify the problem!
Best regards,
Denis Bakhvalov
More information about the U-Boot
mailing list