Extracting vmlinux from BzImage

msh1307·2023년 1월 27일
0

Kernel

목록 보기
3/9

zImage, BzImage

저장공간을 아끼고, 로딩 시간을 줄이기 위해서 커널에 대한 정보를 담고 있는 압축 파일, 즉 커널 이미지를 사용한다.
zImage, BzImage가 있다.
둘다 gzip으로 압축되어있다.

Extract BzImage

일반적으로 BzImage가 주어진다.
정적 링크된 ELF 파일인 vmlinux를 추출해서 분석시 활용할 수 있다.
https://raw.githubusercontent.com/torvalds/linux/master/scripts/extract-vmlinux
extract-vmlinux 스크립트를 활용해서 추출해주면 된다.

#!/bin/sh
# SPDX-License-Identifier: GPL-2.0-only
# ----------------------------------------------------------------------
# extract-vmlinux - Extract uncompressed vmlinux from a kernel image
#
# Inspired from extract-ikconfig
# (c) 2009,2010 Dick Streefland <dick@streefland.net>
#
# (c) 2011      Corentin Chary <corentin.chary@gmail.com>
#
# ----------------------------------------------------------------------

check_vmlinux()
{
	# Use readelf to check if it's a valid ELF
	# TODO: find a better to way to check that it's really vmlinux
	#       and not just an elf
	readelf -h $1 > /dev/null 2>&1 || return 1

	cat $1
	exit 0
}

try_decompress()
{
	# The obscure use of the "tr" filter is to work around older versions of
	# "grep" that report the byte offset of the line instead of the pattern.

	# Try to find the header ($1) and decompress from here
	for	pos in `tr "$1\n$2" "\n$2=" < "$img" | grep -abo "^$2"`
	do
		pos=${pos%%:*}
		tail -c+$pos "$img" | $3 > $tmp 2> /dev/null
		check_vmlinux $tmp
	done
}

# Check invocation:
me=${0##*/}
img=$1
if	[ $# -ne 1 -o ! -s "$img" ]
then
	echo "Usage: $me <kernel-image>" >&2
	exit 2
fi

# Prepare temp files:
tmp=$(mktemp /tmp/vmlinux-XXX)
trap "rm -f $tmp" 0

# That didn't work, so retry after decompression.
try_decompress '\037\213\010' xy    gunzip
try_decompress '\3757zXZ\000' abcde unxz
try_decompress 'BZh'          xy    bunzip2
try_decompress '\135\0\0\0'   xxx   unlzma
try_decompress '\211\114\132' xy    'lzop -d'
try_decompress '\002!L\030'   xxx   'lz4 -d'
try_decompress '(\265/\375'   xxx   unzstd

# Finally check for uncompressed images or objects:
check_vmlinux $img

# Bail out:
echo "$me: Cannot find vmlinux." >&2

다음과 같이 뽑아주면 된다.

wget https://raw.githubusercontent.com/torvalds/linux/master/scripts/extract-vmlinux; 
./extract-vmlinux ./bzImage > ./vmlinux 

뽑힌 vmlinux로 편하게 분석할 수 있다.

https://github.com/marin-m/vmlinux-to-elf
이것도 쓰면 좋다.

profile
https://msh1307.kr

0개의 댓글