123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- uid=`id -u`
- if [ ! $uid == "0" ];then
- echo "请以sudo权限运行"
- exit
- fi
- if [ ! "$1" == "--nobuild" ]; then
- echo "开始构建..."
- make all
- make clean
- fi
- bins[0]=bin/bootloader/boot.bin
- bins[1]=bin/bootloader/loader.bin
- bins[2]=bin/boot.img
- bins[3]=bin/kernel/kernel.bin
- for file in ${bins[*]};do
- if [ ! -x $file ]; then
- echo "$file 不存在!"
- exit
- fi
- done
- dd if=bin/bootloader/boot.bin of=bin/boot.img bs=512 count=1 conv=notrunc
- if [ ! -d "tmp/" ]; then
- mkdir tmp/
- echo "创建了tmp文件夹"
- fi
- mkdir tmp/boot
- mount bin/boot.img tmp/boot -t vfat -o loop
-
- if mountpoint -q tmp/boot
- then
- echo "成功挂载 boot.img 到 tmp/boot"
-
- cp bin/bootloader/loader.bin tmp/boot
-
- cp bin/kernel/kernel.bin tmp/boot
- sync
-
- umount tmp/boot
- else
- echo "挂载 boot.img 失败!"
- fi
- rm -rf tmp
- flag_can_run=0
- if [ -d "tmp/" ]; then
- flag_can_run=0
- echo "tmp文件夹未删除!"
- else
- flag_can_run=1
- fi
- if [ $flag_can_run -eq 1 ]; then
- qemu-system-x86_64 -s -S -m 2048 -fda bin/boot.img
- else
- echo "不满足运行条件"
- fi
|