博客
关于我
Minimum operating system with QEMU, but no debug
阅读量:579 次
发布时间:2019-03-10

本文共 2991 字,大约阅读时间需要 9 分钟。

1.Envirment:

(see appendix Envriment create)

2.source

; 文件名 boot.asm org 7c00h                     ; BIOS读入MBR后,从0x7c00h处开始执行 ; 下面部分和10h有关中断,10h中断用来显示字符mov ax, csmov es, axmov ax, msgmov bp, ax                    ; ES:BP表示显示字符串的地址mov cx, msgLen                ; CX存字符长度mov ax, 1301h                 ; AH=13h表示向TTY显示字符,AL=01h表示显示方式(字符串是否包含显示属性,01h表示不包含)mov bx, 000fh                 ; BH=00h表示页号,BL=0fh表示颜色mov dl, 0                     ; 列int 10h  msg: db "hello world, welcome to OS!"msgLen: equ $ - msg           ; 字符串长度times 510 - ($ - $$) db 0     ; 填充剩余部分dw 0aa55h                     ; 魔数,必须有这两个字节BIOS才确认是MBR

3.Compile

If till not install nasm, should install first.

nasm install on ubuntu

1.Download source code:

2.tar zxvf nasm-2.10.07.tar.gz

进入刚解压的目录

然后执行命令:./configure

make

sudo make install

NOTE: Using "apt install nasm" to install is failled.

nasm usage

If only want to run without debugging, only input bellow:

# nasm boot.asm -o boot.bin

If want gdb can regcnise the format, should do more, convert it into ELF file format.

# nasm -f elf -g boot.asm -o boot.o

# gcc -c boot.o -o boot

If the gcc is bit32, should install some lib, as bellow:

sudo apt-get install g++-multilib libc6-dev-i386

then

# gcc boot.o -o boot -m32

 

4.Command line Debug

NOTE: Must copy the linux 0.11 project to windows disk, cannot in samba server, or not can't debug.

QEMU version: Download latest version from official site.

Input command:

"C:\Program Files\qemu\qemu-system-x86_64.exe" boot.bin"C:\Program Files\qemu\qemu-system-x86_64.exe" -m 16M -boot a -fda boot.bin -s -S

-s              wait gdb connection to port 1234

'-S' means freeze CPU at startup (Can be remove to run directly), so you can debug step byt step.

After input the command, the linux 0.11 would be running succe

 

Open other cmd windows, then input:

F:\Linux-0.11-master>gdb Image

(gdb) target remote localhost:1234

(gdb) b *0x7c00

(gdb)c

(gdb)x /16b 0x7df0 //观察0x7DFE和0x7DFF的值是否为0x55,0xAA

(gdb)

Then you would see the linux 0.11 is running successfully.

Can using "Ctrl+C" to stop running.

 

Appendix 1 Envriment create

1.VM-Envriment:windown 7, vmware(ubuntu-18.04.1-live-server-amd64.iso), SecureCRT(ssh remote ubuntu), samba-server(see appendix samba-server create).

2.Destnation-machine: QEMU(download from official site),

3.Debug-method: TDMGCC(Using its GDB in command line debug).

 

Appendix 2 samba-server create

1 首先确认网络可以相互ping通。

2 终端输入:apt-get install samba

3 先备份 smb.conf 编辑配置,终端输入:

cd /etc/samba/  

ls

cp smb.conf smb.conf-201x-xx-xx

4 nano /etc/samba/smb.conf 编辑配置文件

  1. 找到[homes]browseable = no, 把no 改成 yes, 因为只有这样,windows下才能通 过“计算机”看到“homes”共享目录。----至此,您已经能看到samba共享的目录了。
  2. 当然,以方便调试为目的,所以我们不需要共享homes文件,而是要共享整个根目录。 所以在[homes]这一段下加入一段,不要在[homes]这一段改,否则出错,一定要在下面加,如下:

[all]

comment = /

path = /

read only = no

接着在终端输入:testparm 此命令不但能检查参数是否正确,还能使配置立即生效, 不需要重启。

5 还要创建用户,不然只能看到有共享却无法登录。在终端输入:

smbpasswd -a root 然后就会提示输入密码,其实这个名字可以任意,这里用root是为 了方便记忆,因为我会用最高权限。----到这一步,你就可以登录到samba共享文件里 了。

6 (可以不要这一步)重启samba,终端输入: /etc/init.d/samba restart

 

 

 

 

 

你可能感兴趣的文章
nginx:/usr/src/fastdfs-nginx-module/src/common.c:21:25:致命错误:fdfs_define.h:没有那个文件或目录 #include
查看>>
Nginx:NginxConfig可视化配置工具安装
查看>>
Nginx:现代Web服务器的瑞士军刀 | 文章末尾送典藏书籍
查看>>
ngModelController
查看>>
ngnix配置文件
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
ngrok内网穿透可以实现资源共享吗?快解析更加简洁
查看>>
ngrok内网穿透可以实现资源共享吗?快解析更加简洁
查看>>
NHibernate动态添加表
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
Nhibernate的第一个实例
查看>>
NHibernate示例
查看>>
nid修改oracle11gR2数据库名
查看>>
NIFI1.21.0/NIFI1.22.0/NIFI1.24.0/NIFI1.26.0_2024-06-11最新版本安装_采用HTTP方式_搭建集群_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_插入时如果目标表中已存在该数据则自动改为更新数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0058
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>