也谈ReactOS调试(转载)
reactos吧
全部回复
仅看楼主
level 6
fros 楼主
2009年04月09日 05点04分 1
level 6
fros 楼主
总觉得不好使......自己尝试着瞎整..还真找出了点路子.(鉴于是自己瞎整,错误的概率也就很大,此文的目的是为调试reactos提供一个方向)
在reactos 的论坛上搜"调试"的时候知道源码中有个fDebug是好像是用来调试的.所以我就找了先下fDebug的的代码.在D:\ReactOS\ ReactOS_src\boot\freeldr\fdebug这个目录下.这里我啰嗦下.源代码的路径别放到目录中有空格的文件夹中,有时会导致不能编译.例如,以前我把源码放在了D:\Program Files\ReactOS_src\boot\freeldr\fdebug这个目录下,在编译时可能会发生错误.(至于为什么?我就不啰嗦了)
好了,回到正题.接下来就是编译fDebug...,看了下fDebug的模块名(怎么看?打开fDebug下的 fDebug.rbuild文件里面有个module name=的字样,后面的就是)当时我随手打开了编译环境,输入"makex freeldr_fdebug",可是提示,mingw32-make: *** No rule to make target `fDebug'. Stop.,没有次模块,打开配置文件D:\ReactOS\ReactOS_src\boot\freeldr\freeldr.rbuild,发现并没有fDebug,那我们自己填,怎么填?嗯是个问题,
follow me:来到这个模块所在的主目录下也就是D:\Program Files\ReactOS_src\boot\freeldr\,找到freeldr.rebuild文件打开添加下面的:
2009年04月09日 05点04分 3
level 6
fros 楼主
Copy code
 <directory name="fdebug">
 <xi:include href="fdebug/fdebug.rbuild" />
 </directory>
然后在编译环境下再次输入: makex freeldr_fdebug.等了会,出现
Copy code
 [LD] output-i386\boot\freeldr\fdebug\fdebug.exe
 [RSYM] output-i386\boot\freeldr\fdebug\fdebug.exe
2009年04月09日 05点04分 4
level 6
fros 楼主
的字样OK编译好了,我们在运行下:
这里有两个问题:
1,在哪运行呀?
2,文件在哪呀?
答:(1)在 windows下,因为我们要在windows下用fDebug和虚拟机调试,可能还会有人问兼容嘛?由于reactos设计的宗旨就是兼容 windows,所以,reactos的应用程序几乎都能在windows下运行!,而相反就不一定了,毕竟还在开发中嘛..
(2)文件在哪?正如编译环境给你列出来的D:\ ReactOS \ReactOS_src\ output-i386\boot\freeldr\fdebug\fdebug.exe下就能找到
编译好了,我们来调试吧,先啰嗦下,调试环境,我类似于windbg + Vmware, 首先在虚拟机中装ReactOS,怎么装我就不再啰嗦了,他的老家的论坛上有,然后打开虚拟机的设置->添加硬件-->串口使用命名管道..其余默认就行..
呵呵,开始调试喽,打开虚拟机.以调试模式运行Reactos(就是一进系统有好几个选项我们选第二个(即 ReactOS (Debug))),打开fDebug,如图:
唉,白呀,打开”文件””Connect”,在端口那输入” \\.\pipe\com_1”下面默认,确定
提示
2009年04月09日 05点04分 5
level 6
fros 楼主
晕,怎么回事?用windbg就可以啦.打开源码看看,(有源代码就是好,^_^);这个程序的代码很少.
看到这,就知道怎么回事了(注意这段在D:\ReactOS\ReactOS_src\boot\freeldr\fdebug\rs232.c文件中):
Copy code
 _stprintf(PortName, TEXT("\\\\.\\%s"), CommPort);
 hPortHandle = CreateFile(PortName,
 GENERIC_READ|GENERIC_WRITE,
 0,
 0,
 OPEN_EXISTING,
 0,
 0);
马上将port名改成pipe\com_1,可是又出错了:
2009年04月09日 05点04分 6
level 6
fros 楼主
接着看代码,这里(在同目录下的fDebug.c中):
Copy code
 _stprintf(String, TEXT("%s,n,8,1"), strBaudRate);
 if (!Rs232ConfigurePortWin32(String))
 {
 MessageBox(hMainWnd, TEXT("Error configuring port!"), TEXT("Error"), MB_OK|MB_ICONSTOP);
 bConnected = FALSE;
 return;
 }
接着看看这个函数Rs232ConfigurePortWin32(同目录下的rs232.c中):
Copy code
 BOOL Rs232ConfigurePortWin32(TCHAR* DeviceControlString)
 {
 DCB dcb;
 DWORD ErrorCode;
 memset(&dcb, 0, sizeof(DCB));
 dcb.DCBlength = sizeof(dcb);
 if (!BuildCommDCB(DeviceControlString, &dcb))
 {
 ErrorCode = GetLastError();
 _tprintf(TEXT("BuildCommDCB() failed. GetLastError() = %lu.\n"), ErrorCode);
 return FALSE;
 }
 if (!SetCommState(hPortHandle, &dcb))
 {
 ErrorCode = GetLastError();
 _tprintf(TEXT("SetCommState() failed. GetLastError() = %lu.\n"), ErrorCode);
 return FALSE;
 }
 // Set the timeouts
 if (!Rs232SetCommunicationTimeoutsWin32(MAXDWORD, 0, 0, 0, 0))
 {
 return FALSE;
 }
 return TRUE;
 }
2009年04月09日 05点04分 7
level 6
fros 楼主
查了下msdn没多大用,(有兴趣的自己看),去掉.将fDebug.c中的那段去掉.
这里也说下:这个程序的作者也真够马虎的点”connect”后出错了,也不知道将disConnect变为禁用将connect变为可用,害的我每次还得重新运行下程序,我们改过来:
在连接失败的地方加上
Copy code
 EnableFileMenuItemByID(IDM_FILE_DISCONNECT, FALSE);
 EnableFileMenuItemByID(IDM_FILE_CONNECT, TRUE);
就行了
赶紧试了下….成功了:
如下:
2009年04月09日 05点04分 8
level 6
fros 楼主
呵呵.接着去他老家的论坛看了看Kernel_Debug的用法,wiki上都有我就不多说了.
在这里: http://www.reactos.org/wiki/index.php/Kdbg
对了这里按Tab + K 键中断进行调试,和softice似的,输命令的时候必须将窗口切入到ReactOS中再输入,虽然不是在fDebug中输入的加上鼠标什么的都不管事但是ReactOS会将命令通过串口传过来.
我们试试查看寄存器:
输入:regs
显示如图:
2009年04月09日 05点04分 9
level 6
fros 楼主
注意:调试必须是内核带调试的版本,怎么编译调试版本,WIKI上都说了,大家可以参考
结束语:这里仅仅是指名了个方向,具体还要大家慢慢的研究,探索…..
2009年04月09日 05点04分 10
level 6
fros 楼主
2009年04月09日 05点04分 11
level 0
若整系统调试,用bochs虚拟机软件来整,应该不错。
:)
2009年04月10日 23点04分 12
level 0
虽然这个虚拟机软件内运行系统速度比较慢。
比其它的虚拟机软件还要慢的。
:)
2009年04月10日 23点04分 13
1