调试X Server
发现错误
运行X之后出现了错误:
Program received signal SIGSEGV, Segmentation fault.
0x00007fbc3336fb63 in ?? () from /lib/x86_64-linux-gnu/libc.so.6
(gdb) bt
#0 0x00007fbc3336fb63 in ?? () from /lib/x86_64-linux-gnu/libc.so.6
#1 0x00007fbc35785087 in RegisterExtensionNames ()
#2 0x00007fbc35775599 in AddExtension ()
#3 0x00007fbc31501b62 in ?? () from /usr/lib/xorg/modules/extensions/libglx.so
#4 0x00007fbc35775720 in ?? ()
#5 0x0000000000000168 in ?? ()
#6 0x00007fbc35b07600 in ?? ()
#7 0x0000000000000000 in ?? ()
查看RegisterExtensionNames
出错的位置
- 先查看X进行PID信息
ps aux|grep X
root 570 0.0 0.1 54100 20976 pts/1 S+ 19:16 0:00 gdb /usr/bin/X
root 670 0.1 0.2 144108 31652 tty8 ts+ 19:17 0:00 /usr/bin/X
root 17519 0.0 0.0 22492 1084 pts/0 S+ 19:20 0:00 grep X
- 再查看670的maps
cat /proc/670/maps
...
7fbc35711000-7fbc358f8000 r-xp 00000000 00:01 117964 /usr/bin/Xorg
7fbc35af7000-7fbc35afa000 r--p 001e6000 00:01 117964 /usr/bin/Xorg
7fbc35afa000-7fbc35b05000 rw-p 001e9000 00:01 117964 /usr/bin/Xorg
7fbc35b05000-7fbc35b15000 rw-p 00000000 00:00 0
7fbc35dea000-7fbc35e9f000 rw-p 00000000 00:00 0 [heap]
7fff642d4000-7fff64330000 rw-p 00000000 00:00 0 [stack]
7fff643fe000-7fff64400000 r-xp 00000000 00:00 0 [vdso]
ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0 [vsyscall]
...
其中 0x00007fbc35785087
就包含在了7fbc35711000-7fbc358f8000 r-xp 00000000 00:01 117964 /usr/bin/Xorg
里边,说明出错位置在Xorg程序里边
编译与调试Xorg
下载源码:
apt-get source xserver-xorg-core
下载依赖:
apt-get build-dep xserver-xorg-core
生成Makefile:
./autogen.sh
修改Makefile,使之可以GDB调试:
vim Makefile,把CFLAGS
和CCASFLAGS
选项修改为
CCASFLAGS = -g -O0
CFLAGS = -g -O0
编译并进行安装
make -j4 install
安装的位置是/usr/local/bin/Xorg
,所以启动的时候需要把startx的路径指向于这里,同时还需要把一些库链接过来:
mv /usr/local/lib/xorg /usr/local/lib/xorg.org
ln -svf /usr/lib/xorg /usr/local/lib/xorg
ln -svf /usr/bin/xkb* /usr/local/bin/
注意,如果修改了Xorg的代码,再编译安装的话,安装之前需要把 /usr/local/lib/Xorg 这个链接删掉,避免覆盖了原有的文件
或者手工拷贝替换的文件,比如make -j4 && cp hw/xfree86/Xorg /usr/local/bin/Xorg
,这样子就可以继续测试了;
调试:
cgdb /usr/local/bin/Xorg
run
bt
发现问题出现在了 strtol里边,接着调试glibc;
先不调试glibc,因为它不太可能出现Bug,问题现在定位到是GLX初始化时出现的错误
b RegisterExtensionNames if strcmp(extEntry->name, "GLX") == 0
修改全部的Makefile文件,让它们可以进行debug
find . -name Makefile -print -exec sed -i 's/-g -O2/-g -O0/g' {} \;
最后找丁技术确认了这个安装这个GLX时,libglx.so可能会去修改寄存器fs(或者是说它的进入初始化的姿势不太一样?)的内容,这个libglx.so是由NVIDIA提供的,暂时无法修改.
调试X Server的更多相关文章
- 使用WinDbg调试SQL Server查询
上一篇文章我给你介绍了WinDbg的入门,还有你如何能附加到SQL Server.今天的文章,我们继续往前一步,我会向你展示使用WinDbg调试SQL Server查询需要的步骤.听起来很有意思?我们 ...
- 使用WinDbg调试SQL Server——入门
这篇文章我想探究下SQL Server里完全不同的领域:如果使用WinDbg(来自针对Windows的调试工具)调试SQL Server.在我们进入枯涩细节之前,我想详细解释下为什么选择这样晦涩的话题 ...
- Eclipse调试cas server 3.5.2.1
由于在配置CAS+LDAP总是报错,决定Eclipse调试cas server,跟踪问题出在哪里? ================================================== ...
- 如何设断点????-----使用WinDbg调试SQL Server查询
http://www.cnblogs.com/woodytu/p/4665427.html http://www.sqlservercentral.com/blogs/aschenbrenner/20 ...
- VS调试SQL Server存储过程
1.打开VS,视图-->SQL Server对象资源管理器.(我用的是VS2012) 2.添加链接,连接到数据库. 3.选择要调试的存储过程,右键,选择调试过程或者执行过程. 4.填写存储过程所 ...
- Visual Studio 2017 调试 windows server 2016 Docker Container
网上很多文章都是在win10下,用Docker for windows工具进行Docker的安装部署的.用知道windows server 2016已经原生支持Docker了,其windows Con ...
- 调试SQL Server的存储过程及用户定义函数
分类: 数据库管理 2005-06-03 13:57 9837人阅读 评论(5) 收藏 举报 sql server存储vb.net服务器sql语言 1.在查询分析器中调试 查询分析器中调试的步骤如下: ...
- IDEA远程调试Ambari Server
1.配置端口 Ambari Server默认配置了服务端的debug参数,端口为5005.如果要修改端口,可以在/usr/sbin/ambari_server_main.py文件中对应地方修改,直接改 ...
- VS 调试Window Server方法
在需要调试的地方加 Debugger.Launch();然后在本机安装服务并启动即可进入
随机推荐
- css3的学习笔记1
一. 边框 1. border-color border-color是设置边框的颜色.包括border-top-color,border-left-color,border-right-colo ...
- OpenLayers中的图层
OpenLayers有多个不同的图层类,每一个都可以连接到不同的地图服务器.例如通过Layer.WMS类可以连接到WMS地图服务器,通过Layer.Google类可以连接到谷歌地图服务器.OpenLa ...
- C++ set使用
C++ set使用 实际上c++ STL中的set是的实现和C++ STL中的map的实现的底层数据结构是一样的,如果我们不在考虑红黑树中的卫星数据,而只是关键字,那么同样不允许key值得重复,那么就 ...
- day4----装饰器
装饰器本质是函数,装饰其他函数,就是为其他函数添加附加功能. 原则:1.不能修改被装饰的函数的源代码 2.不能修改被装饰的函数的调用方式 实现装饰器 知识储备 1.函数即“变量 ...
- hdu 4648 - Magic Pen 6(“水”题)
摘自题解: 题意转化一下就是: 给出一列数a[1]...a[n],求长度最长的一段连续的数,使得这些数的和能被M整除. 分析: 设这列数前i项和为s[i], 则一段连续的数的和 a[i]+a[i+1] ...
- [MSSQL2005]再看CTE
个人认为CTE最大的做点是可以处理树状存储的数据了 例如类似这样设计的数据表,ID,ParentID这样的设计使用CTE就非常方便,原因就是CTE可以自引用,达到类似递归的效果 那么问题来了,如何使用 ...
- SQLSERVER--定期清理维护作业的历史记录
刚删除一个数据库时,在清理数据库备份历史记录时,执行超过近10分钟还未完成,随时查了下,吓死宝宝啦,逻辑读操作竟然高达8000万次以上! 通过UI进行删除数据库时,会默认勾选上“删除数据库备份和还原历 ...
- javascript中的splice方法介绍&示例
javascript 中的 splice 方法很强大,它可以用于插入.删除或替换数组的元素. 下面来一一介绍! 删除:用于删除元素,两个参数,第一个参数(要删除第一项的位置),第二个参数(要删除的项数 ...
- 杂记 C中的volatile
volatile 就象大家更熟悉的const一样,volatile是一个类型修饰符(type specifier).它是被设计用来修饰被不同线程访问和修改的变量.如果没有volatile,基本上会导致 ...
- HTML5实战与剖析之原生拖拽(四可拖动dragable属性和其他成员)
可拖动dragable属性 之前我们已经为大家介绍过几篇有关HTML5中原生拖拽的相关知识了.今天为大家介绍HTML5拖拽中的其他一些小东东,闲话不多说赶快一起看看吧. 在默认情况下,链接.文本和图像 ...