bochs使用(linux下搭建操作系统调试环境)zt
BOoRFGOnZ
|
1#
BOoRFGOnZ 发表于 2006-10-21 10:05
bochs使用(linux下搭建操作系统调试环境)zt
1.说明:工具链,调试器,其他工具及对x86的理解,使得开发操作系统十分困难,
本文章试图从环境入手,和大家一起讨论操作系统的开发,文档将陆续编写,有关 保护模式,图形界面等等。欢迎爱好者加入。作者:jingle,转载请保留版权 (http://www.ctag.cn),如有不清楚的地方可以加我msn讨论:jinglexy@yahoo.com.cn, 文档可能会有补充和改动,请到我的网站,进入blog区查看(有问题也在这里提出,便于集中答复) 2.安装 ./configure --with-all-libs --enable-vbe --enable-debugger make make install #需要声卡加--enable-sb16,需要网卡加--enable-ne2000, #64位机使用--enable-x86-64,mmx和sse, smp默认不支持 3.文件说明 /usr/bin/bximage,创建磁盘映象,相当于dd命令 /usr/local/share/doc/bochs/bochsrc-sample.txt,bochs配置参考文件 /usr/local/share/doc/bochs/index.html,bochs手册(用户和开发手册) /usr/local/share/bochs/BIOS-bochs-latest,rom biso映象 /usr/local/share/bochs/VGABIOS-lgpl-latest,vga bios映象,通常用VGABIOS-elpin-2.40映象 4.bochs执行需要的文件 rom,vga及磁盘映象,加bochs配置文件 5.bochs配置文件 先拷贝一个bochsrc-sample.txt配置文档,以下没提到的都用默认 romimage:路径修改为正确的BIOS-bochs-latest,不要使用BXSHARE环境变量 vgaromimage:使用VGABIOS-elpin-2.40 floppya: 1_44=a.img, status=inserted不需要软盘则注释掉 floppyb: 注释掉 ata0-master: type=disk, mode=flat, path="30M.sample", cylinders=615, heads=16, spt=63 说明:type和mode如上,cylinders为柱面数根据磁盘大小配置,heads和spt磁道和扇区数固定为16和63 bximage创建磁盘也是512*16*63参数 ata0-slave: type=cdrom, path=/dev/cdrom, status=inserted需要光盘加这个,也可能是/dev/cdwriter文件 boot: cdrom, floppy, disk在前为先启动 6.创建磁盘映象 (1)如创建1.44兆软盘,可以用bximage向导,也可以用下面的命令 dd if=/dev/zero of=teaching.img bs=512 count=2880 (2)如创建10兆硬盘: dd if=/dev/zero of=teaching.img bs=512 count=(计算:16*63*20) 则配置文件为: ata0-master: type=disk, path="test.img", mode=flat, cylinders=20, heads=16, spt=63 (说明:7,8,9一般很少使用,可以不看) 6.mtools配置(建议只分一个区,这样比较简单) drive c: file="path/filename.img" partition=1 drive d: file="path/filename.img" partition=2 7.分区磁盘 可以用光盘引导img文件,然后用fdisk命令;或者用mtools mpartition -I -s 63 -t 20 -h 16 c: mpartition -cpv -s 63 -t 20 -h 16 c: mformat c: 或者: losetup /dev/loop1 hardisk.img fdisk /dev/loop1 8.mtools使用 linux下运行mtools会列出可用的mtools命令,具体的命令用法查找google 9.另一种修改映象文件内容的方法(前提:已分区且格式化) mount test.img /mnt/floppy -o loop mount test.img /mnt/disk_c -o loop -t msdos 10.另一种方法(使用回环设备,linux内核需要加入该项编译): (1) losetup /dev/loop0 floppya.img losetup /dev/loop0 hard10meg.img -o 32256 说明:如loop0不行则用1,或2......7 硬盘需要32256参数,表示分区起始地址,例如分区在一个磁道的大小处:即512字节 * 63扇区; 一般为512,表示第2个扇区处 (2) 卸载回环设备: losetup -d /dev/loop0 (3) mkfs.vfat /dev/loop0格式化成fat32 (4) 挂载回环设备文件到目录 mount /dev/loop0 -o loop /mnt/floppy,硬盘也是一样的命令 11.常用的bochs调试命令 c 继续执行 s count 单步执行,count为指令数量 vb segff 例如vb 0x0000:0x7c00(虚拟地址断点) lb addr 线性地址断点 pb 物理地址断点 info break 断点相关信息 x /10 从当前地址执行10条指令 info cpu info r 寄存器 12.安装msdos6.22(google, 下载软盘或光盘映象安装文档) (说明:安装映象可以在我的网站上下载http://www.ctag.cn/download, 如有版权冲突,请通知我删除谢谢) (1)创建磁盘映象,50兆磁盘 dd bs=512 if=/dev/zero of=dos622disk.img count=100800 (2)配置bochsrc.txt文件 floppya: 1_44=1.flp, status=inserted ata0-master: type=disk, mode=flat, path="dos622disk.img", cylinders=400, heads=16, spt=63 boot: floppy (3)分区映象,msdos安装程序会自动分区 (3)安装,用bochs启动 安装的过程中会切换软盘,先删除1.flp,再将2.flp命名为1.flp,然后点击bochs窗口的软盘a为叉,在点击叉为可用 (4)安装完后修改bochsrc.txt文件为硬盘启动,用bochs启动它即可进入dos (5)mount磁盘映象文件,把nasm拷贝进去,顺便也在vim的官方网站下载一个vi的dos版本 losetup -d /dev/loop7 losetup -o 32256 /dev/loop7 dos622disk.img(32256=512*63,是第一个分区所在的地方) 软盘要将32256换成512 mount -o loop -t msdos /dev/loop7 /mnt/dos622 cp nasm.exe /mnt/dos622 umount /mnt/dos622 losetup -d /dev/loop7 (6)每次写文档到img文件时,关掉bochs,写完文件后,卸载mount文档,卸载loop7文档,然后再启动bochs (7)一个简单的脚本,拷贝文件到img映象 #!/bin/bash # # write by: jingle 2006.3.26 http://www.ctag.cn # first, copy file 2 the dir "file_copy" # sencond, run "./copy" bash, and file will copy to the img # # notes:the img disk param must be:512 * 63 * 16 * cylinders # [ -d temp_mount_xxxx ] || mkdir -p temp_mount_xxxx losetup -d /dev/loop7 2>/dev/null losetup -o 32256 /dev/loop7 *.img mount -o loop -t msdos /dev/loop7 temp_mount_xxxx [ -d temp_mount_xxxx/test ] || mkdir -p temp_mount_xxxx/test rm temp_mount_xxxx/test/* -fr mv file_copy/* temp_mount_xxxx/test/ -f 2>/dev/null umount temp_mount_xxxx losetup -d /dev/loop7 echo "**************************" echo "succ copy......" rm -fr temp_mount_xxxx [ -d temp_mount_xxxx ] && rm -fr temp_mount_xxxx 13.bochs的缺点: (1)运行速度和virtual pc不是一个等级,这点bochs的作者kevin也说过 (如果觉得慢,可以尝试qemu,不过qemu的加速模块目前还不开源) (2)文件共享操作麻烦 14.bochs的优点: 调试操作系统,尚无其他工具可与之比较,^_^ |