![U-Boot boot.scr.uimg를 boot.scr로 압축 해제(압축 해제)하는 방법은 무엇입니까?](https://linux55.com/image/158189/U-Boot%20boot.scr.uimg%EB%A5%BC%20boot.scr%EB%A1%9C%20%EC%95%95%EC%B6%95%20%ED%95%B4%EC%A0%9C(%EC%95%95%EC%B6%95%20%ED%95%B4%EC%A0%9C)%ED%95%98%EB%8A%94%20%EB%B0%A9%EB%B2%95%EC%9D%80%20%EB%AC%B4%EC%97%87%EC%9E%85%EB%8B%88%EA%B9%8C%3F.png)
저는 ARM 개발 보드(STM32MP157A-DK1)를 가지고 있고 Linux 이미지가 어떻게 구축되는지 살펴보고 있습니다.
boot.scr.uimg
부팅 파티션에 파일이 있습니다 . 내가 아는 한 boot.scr.uimg
그것은 압축된 버전이다 boot.scr
.
원본 파일의 압축을 풀거나 추출할 수 있는 방법이 있습니까 boot.scr
?boot.scr.uimg
결과는 다음과 같습니다 file boot.scr.uimg
.
boot.scr.uimg: u-boot legacy uImage, , Linux/ARM, Script File (Not compressed), 1489 bytes, Thu Jan 1 00:00:00 1970, Load Address: 0x00000000, Entry Point: 0x00000000, Header CRC: 0xC80D8B27, Data CRC: 0x62B32EA2
printenv
U-Boot CLI 결과:
STM32MP> printenv
altbootcmd=run bootcmd
arch=arm
autoload=no
baudrate=115200
board=stm32mp1
board_name=stm32mp157c-dk2
boot_a_script=load ${devtype} ${devnum}:${distro_bootpart} ${scriptaddr} ${prefix}${script}; source ${scriptaddr}
boot_device=mmc
boot_extlinux=sysboot ${devtype} ${devnum}:${distro_bootpart} any ${scriptaddr} ${prefix}extlinux/extlinux.conf
boot_instance=0
boot_net_usb_start=true
boot_prefixes=/ /boot/
boot_script_dhcp=boot.scr.uimg
boot_scripts=boot.scr.uimg boot.scr
boot_targets=mmc0
bootcmd=run distro_bootcmd
bootcmd_mmc0=setenv devnum 0; run mmc_boot
bootcmd_mmc1=setenv devnum 1; run mmc_boot
bootcmd_mmc2=setenv devnum 2; run mmc_boot
bootcmd_pxe=run boot_net_usb_start; dhcp; if pxe get; then pxe boot; fi
bootcmd_ubifs0=setenv devnum 0; run ubifs_boot
bootcount=2
bootdelay=1
bootlimit=0
cpu=armv7
distro_bootcmd=for target in ${boot_targets}; do run bootcmd_${target}; done
ethaddr=00:80:e1:42:5d:63
fdt_addr_r=0xc4000000
fdt_high=0xffffffff
fdtcontroladdr=ddc3c4f8
initrd_high=0xffffffff
kernel_addr_r=0xc2000000
mmc_boot=if mmc dev ${devnum}; then setenv devtype mmc; run scan_dev_for_boot_part; fi
mtdparts_nand0=2m(fsbl),2m(ssbl1),2m(ssbl2),-(UBI)
mtdparts_nor0=256k(fsbl1),256k(fsbl2),2m(ssbl),256k(logo),-(nor_user)
preboot=echo "Boot over ${boot_device}${boot_instance}!"; if test ${boot_device} = serial; then stm32prog serial ${boot_instance}; else if test ${boot_device} = usb; then stm32prog usb ${boot_instance}; else if test ${boot_device} = mmc; then env set boot;
pxefile_addr_r=0xc4200000
ramdisk_addr_r=0xc4400000
scan_dev_for_boot=echo Scanning ${devtype} ${devnum}:${distro_bootpart}...; for prefix in ${boot_prefixes}; do run scan_dev_for_extlinux; run scan_dev_for_scripts; done;
scan_dev_for_boot_part=part list ${devtype} ${devnum} -bootable devplist; env exists devplist || setenv devplist 1; for distro_bootpart in ${devplist}; do if fstype ${devtype} ${devnum}:${distro_bootpart} bootfstype; then run scan_dev_for_boot; fi; done
scan_dev_for_extlinux=if test -e ${devtype} ${devnum}:${distro_bootpart} ${prefix}extlinux/extlinux.conf; then echo Found ${prefix}extlinux/extlinux.conf; run boot_extlinux; echo SCRIPT FAILED: continuing...; fi
scan_dev_for_scripts=for script in ${boot_scripts}; do if test -e ${devtype} ${devnum}:${distro_bootpart} ${prefix}${script}; then echo Found U-Boot script ${prefix}${script}; run boot_a_script; echo SCRIPT FAILED: continuing...; fi; done
scriptaddr=0xc4100000
serial#=0038001A3338510A39303435
serverip=192.168.1.1
soc=stm32mp
splashimage=0xc4300000
stderr=serial
stdin=serial
stdout=serial
ubifs_boot=env exists bootubipart || env set bootubipart UBI; env exists bootubivol || env set bootubivol boot; if ubi part ${bootubipart} && ubifsmount ubi${devnum}:${bootubivol}; then setenv devtype ubi; run scan_dev_for_boot; fi
usb_boot=usb start; if usb dev ${devnum}; then setenv devtype usb; run scan_dev_for_boot_part; fi
usb_pgood_delay=2000
vendor=st
Environment size: 3053/4092 bytes
STM32MP>
아직 U-Boot에 대한 경험이 많지 않아서 관련이 있는지 잘 모르겠습니다 . boot.scr
U-Boot CLI에 액세스하지 않고 boot.scr
추출하는 방법을 알고 싶습니다.boot.scr.uimg
답변1
설치하다 u-boot-tools
:
$ sudo apt install u-boot-tools
이미지 제목을 확인하세요.
$ dumpimage -l boot.scr.uimg
Image Name:
Created: Wed Dec 31 16:00:00 1969
Image Type: ARM Linux Script (uncompressed)
Data Size: 1489 Bytes = 1.45 KiB = 0.00 MiB
Load Address: 00000000
Entry Point: 00000000
Contents:
Image 0: 1481 Bytes = 1.45 KiB = 0.00 MiB
boot.scr
이미지에서 파일을 추출합니다.
$ dumpimage -i boot.scr.uimg boot.scr
추출된 파일은 Contents
헤더의 표에 표시된 것보다 8바이트 더 큽니다(예상된 1481바이트 대비 1489바이트). 원하는 경우 다음을 사용하여 이러한 바이트를 잘라낼 수 있습니다.
tail -c+8 boot.scr > $$; mv $$ boot.scr
편집하다:OP @Bumsik Kim 및 전문 리뷰어 @Kusalananda와 관련하여 dumpimage
구문을 다음과 같이 변경하는 것이 좋습니다.
dumpimage -o boot.scr boot.scr.uimg
누군가에게 도움이 될 경우를 대비해 여기에 이 메모를 추가하겠습니다. 하지만 Ubuntu 18.04 시스템에서는 명령이 성공하지만 아무 작업도 수행하지 않습니다.
# ls -l
total 4
-rw------- 1 root root 1553 Aug 7 11:30 boot.scr.uimg
# dumpimage -o boot.scr boot.scr.uimg && ls -l
total 4
-rw------- 1 root root 1553 Aug 7 11:30 boot.scr.uimg
위의 원래 구문은 Ubuntu 18에서 작동합니다.
$ dumpimage -i boot.scr.uimg boot.scr && ls -l
total 8
-rw------- 1 root root 1489 Aug 9 10:51 boot.scr
-rw------- 1 root root 1553 Aug 7 11:30 boot.scr.uimg
그럼에도 불구하고 제안된 구문이 포함되고 인정되기를 바랍니다.