run_in_qemu.sh 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. # ======检查是否以sudo运行=================
  2. uid=`id -u`
  3. if [ ! $uid == "0" ];then
  4. echo "请以sudo权限运行"
  5. exit
  6. fi
  7. # 第一个参数如果是--notbuild 那就不构建,直接运行
  8. if [ ! "$1" == "--notbuild" ]; then
  9. echo "开始构建..."
  10. make all
  11. make clean
  12. fi
  13. # ==============检查文件是否齐全================
  14. if [ ! -x "bin/bootloader/boot.bin" ]; then
  15. echo "bin/bootloader/boot.bin 不存在!"
  16. exit
  17. fi
  18. if [ ! -x "bin/bootloader/loader.bin" ]; then
  19. echo "bin/bootloader/loader.bin 不存在!"
  20. exit
  21. fi
  22. if [ ! -x "bin/boot.img" ]; then
  23. echo "bin/boot.img 不存在!"
  24. exit
  25. fi
  26. # ===============文件检查完毕===================
  27. # =========将引导程序写入boot.img=============
  28. dd if=bin/bootloader/boot.bin of=bin/boot.img bs=512 count=1 conv=notrunc
  29. # =========创建临时文件夹==================
  30. # 判断临时文件夹是否存在,若不存在则创建新的
  31. if [ ! -d "tmp/" ]; then
  32. mkdir tmp/
  33. echo "创建了tmp文件夹"
  34. fi
  35. # ==============挂载boot.img=============
  36. mkdir tmp/boot
  37. mount bin/boot.img tmp/boot -t vfat -o loop
  38. # 检查是否挂载成功
  39. if mountpoint -q tmp/boot
  40. then
  41. echo "成功挂载 boot.img 到 tmp/boot"
  42. # ========把loader.bin复制到boot.img==========
  43. cp bin/bootloader/loader.bin tmp/boot
  44. # ========把内核程序复制到boot.img======
  45. cp bin/kernel/kernel.bin tmp/boot
  46. sync
  47. # 卸载磁盘
  48. umount tmp/boot
  49. else
  50. echo "挂载 boot.img 失败!"
  51. fi
  52. # 运行结束后删除tmp文件夹
  53. rm -rf tmp
  54. # 进行启动前检查
  55. flag_can_run=0
  56. if [ -d "tmp/" ]; then
  57. flag_can_run=0
  58. echo "tmp文件夹未删除!"
  59. else
  60. flag_can_run=1
  61. fi
  62. if [ $flag_can_run -eq 1 ]; then
  63. qemu-system-x86_64 -s -S -m 2048 -fda bin/boot.img
  64. else
  65. echo "不满足运行条件"
  66. fi