首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | HR | 镜像
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
搜索中心 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>系统管理>内核技术>正文

Bochs 调试技术

http://www.oklinux.cn  2006-02-26  oklinux收集整理  jianpdl      会员收藏  游客收藏  【 】 
您查看的文章来源于http://www.oklinux.cn
  对于任何想尝试写自己的操作系统的朋友来说,我都要向你推荐Bochs。这个模拟器最大的好处就是可以单步调试。

  这里主要是讲述Bochs的调试命令,如何配置Bochs,请参考bochsrc-sample.txt,写一个自己的bochsrc.txt。Bochsrc-sample.txt的说明很详细,相信应该没有问题。这里是一个作者给FREOS所配置的例子,仅供参考。然后运行bochsdbg.exe(调试模式)。注意:bochs.exe是执行模式,不能调试的。调试模式将出现下列命令行:

bochs:1>


下面初步说明一下每条指令的用法:

执行控制命令
c 继续执行,遇到断点将停止
stepi [count] 执行count条指令, 默认为1条
si [count] stepi的缩写
step [count] 执行count条指令, 默认为1条
s [count] step的缩写
Ctrl-C 停止执行,返回命令行
Ctrl-D 执行完所有命令后,退出
quit 退出调试器
q quit缩写

设置断点
vbreak seg:off 在指定的虚拟地址(段+偏移)设置断点,在保护模式下也可以使用
vb seg:off

lbreak addr 在一个线性地址设置断点
lb addr

pbreak [*] addr 在一个物理地址设置断点
pb [*] addr
break [*] addr
b [*] addr

info break 显示所有断点状态
例如:
--------------------------------------
Num Type Disp Enb Address
1 pbreakpoint keep y 0x00007c00
表示在物理地址0x00007c00设置一个断点,该断点目前有效
---------------------------------------
delete n 删除一个断点
del n
d n

关于物理地址,线性地址和虚拟地址的区别,我只能凭我的理解简单说说,可能不准确。物理地址在什么时候都存在,但是在采用分页技术和虚拟内存技术后,你很难确定物理地址在那里,所以建议在实模式下采用物理地址和线性地址形式,这时候物理地址和线性地址其实是一致的。最常用的,比方说,计算机启动后的地址是0xfff0:0000,装载BIOS,然后转移到0x07C0:0000,所以总可以设置一个物理断点0x7C00,开始调试你的bootloader。
查看内存
x /nuf addr 查看一个线性地址的内存
xp /nuf addr 查看一个物理地址的内存
n 显示多少个单位的内存
u 内存单位大小,可以是
b 字节
h 字(2个字节)
w 双字(4个字节)
g 4字(8字节)
注意: 它们不太符合Intel字节命名格式,但是遵守GDB约定。
f 打印格式,可以是
x 16进制格式打印
d 10进制格式打印
u 无符号10进制格式打印
o 8进制格式打印
t 2进制格式打印

n,f,和u是可选参数。U和f默认为你最后使用的参数, 如果是第一次使用,u默认为w,f默认为x, n默认为1。如果没有指定nuf,那么/也可以不要。setpmem addr datasize val 设置物理地址addr,大小datasize的内存单元的值为val.

crc addr1 addr2 对物理地址范围addr1到addr2进行CRC校验?(没用过)info dirty 显示写过的页?(没用过)


Info
info program 查看程序的执行状态
info registers 列举CPU整型寄存器遗迹它们的内容
info break 显示当前断点信息
where 打印当前call stack

寄存器操作
set $reg = val 改变寄存器的内容。可改变的寄存器有:
eax, ecx, edx, ebx, esp, ebp, esi, edi.
不可改变的寄存器有:
eflags, cs, ss, ds, es, fs, gs.

例如 set $eax = 0x01234567
set $edx = 25

info registers 显示寄存器内容
dump_cpu 查看所有与CPU相关的寄存器状态
set_cpu 设置所有与CPU相关的寄存器状态
dump_cpu和set_cpu格式如下:
"eax:0x%x\n"
"ebx:0x%x\n"
"ecx:0x%x\n"
"edx:0x%x\n"
"ebp:0x%x\n"
"esi:0x%x\n"
"edi:0x%x\n"
"esp:0x%x\n"
"eflags:0x%x\n"
"eip:0x%x\n"
"cs:s=0x%x, dl=0x%x, dh=0x%x, valid=%u\n"
"ss:s=0x%x, dl=0x%x, dh=0x%x, valid=%u\n"
"ds:s=0x%x, dl=0x%x, dh=0x%x, valid=%u\n"
"es:s=0x%x, dl=0x%x, dh=0x%x, valid=%u\n"
"fs:s=0x%x, dl=0x%x, dh=0x%x, valid=%u\n"
"gs:s=0x%x, dl=0x%x, dh=0x%x, valid=%u\n"
"ldtr:s=0x%x, dl=0x%x, dh=0x%x, valid=%u\n"
"tr:s=0x%x, dl=0x%x, dh=0x%x, valid=%u\n"
"gdtr:base=0x%x, limit=0x%x\n"
"idtr:base=0x%x, limit=0x%x\n"
"dr0:0x%x\n"
"dr1:0x%x\n"
"dr2:0x%x\n"
"dr3:0x%x\n"
"dr4:0x%x\n"
"dr5:0x%x\n"
"dr6:0x%x\n"
"dr7:0x%x\n"
"tr3:0x%x\n"
"tr4:0x%x\n"
"tr5:0x%x\n"
"tr6:0x%x\n"
"tr7:0x%x\n"
"cr0:0x%x\n"
"cr1:0x%x\n"
"cr2:0x%x\n"
"cr3:0x%x\n"
"cr4:0x%x\n"
"inhibit_int:%u\n"
"done\n"


反汇编 disassemble start end 反汇编的地址范围 set $disassemble_size = n 告诉调试器,反汇编段的属性(16位或32位,默认32位)。上述的一些命令都是bochs常用的命令,是根据bochs自带的英文文档翻译的。

上一篇:Linux 编程之JAVA上加密算法的实现用例   下一篇:Linux发行版制作指南

收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·Linux发行版制作指南
·Linux常用C函数—接口处理篇
·Linux 编程之JAVA上加密算法的实现用例
·Linux 编程之MD5算法研究
·Linux下的软件开发
·Linux内核编程全集1
·Linux内核研究系列之可执行文件格式
·升级内核的一些重要体会
·Linux下插件开发应用案例
·剖析Linux平台下的开发工具
·嵌入式系统基础知识
·为Linux 应用程序编写 DLL
·LINUX动态链接库高级应用
·Linux内核编码风格
·搞开发的交流下
·在Linux中建立一个XML的开发环境
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·再来个源代码分析阅读器:LXR
·源代码阅读利器:Source Navigator
·Linux系统下的MySQL数据库开发技术
·Fedora在下一代用户群鼓励使用和参与开
·centos5.1下编译Linux内核
·Suse Linux系统下JAVA AWT界面乱码问题
·在Linux下发布程序需要注意版本的软件
·使用initrd文件系统 U-boot引导Linux方
·Linux系统下后台执行程序
·Linux如何在系统运行过程中修改内核参
·Linux系统进程的几个用户ID及其转换方
·Linux系统下安装phpmyadmin方法介绍
  阅读排行
· 深入理解LINUX内核中文版下载地址
·Linux操作系统源代码详细分析(一)
· Linux下通用线程池的创建与使用(上)
·基于S3C44B0微处理器的uClinux内核引导
·软件产品发布流程
·Linux操作系统源代码详细分析(二)
·Linux操作系统的内核编译内幕详解
· Linux内核编程实战经验谈
·Linux系统线程同步:互斥量(mutex)
·Kernel command using Linux system ca
·linux 内核版本号
·推荐:Linux用户态与内核态的交互
·Linux 2.6内核的编译步骤及模块的动态
·解析Linux中的VFS文件系统机制
·源代码阅读利器:Source Navigator
网摘收藏: