发现错误

运行X之后出现了错误:

  1. Program received signal SIGSEGV, Segmentation fault.
  2. 0x00007fbc3336fb63 in ?? () from /lib/x86_64-linux-gnu/libc.so.6
  3. (gdb) bt
  4. #0 0x00007fbc3336fb63 in ?? () from /lib/x86_64-linux-gnu/libc.so.6
  5. #1 0x00007fbc35785087 in RegisterExtensionNames ()
  6. #2 0x00007fbc35775599 in AddExtension ()
  7. #3 0x00007fbc31501b62 in ?? () from /usr/lib/xorg/modules/extensions/libglx.so
  8. #4 0x00007fbc35775720 in ?? ()
  9. #5 0x0000000000000168 in ?? ()
  10. #6 0x00007fbc35b07600 in ?? ()
  11. #7 0x0000000000000000 in ?? ()

查看RegisterExtensionNames出错的位置

  1. 先查看X进行PID信息
  1. ps aux|grep X
  2. root 570 0.0 0.1 54100 20976 pts/1 S+ 19:16 0:00 gdb /usr/bin/X
  3. root 670 0.1 0.2 144108 31652 tty8 ts+ 19:17 0:00 /usr/bin/X
  4. root 17519 0.0 0.0 22492 1084 pts/0 S+ 19:20 0:00 grep X
  1. 再查看670的maps
  1. cat /proc/670/maps
  2. ...
  3. 7fbc35711000-7fbc358f8000 r-xp 00000000 00:01 117964 /usr/bin/Xorg
  4. 7fbc35af7000-7fbc35afa000 r--p 001e6000 00:01 117964 /usr/bin/Xorg
  5. 7fbc35afa000-7fbc35b05000 rw-p 001e9000 00:01 117964 /usr/bin/Xorg
  6. 7fbc35b05000-7fbc35b15000 rw-p 00000000 00:00 0
  7. 7fbc35dea000-7fbc35e9f000 rw-p 00000000 00:00 0 [heap]
  8. 7fff642d4000-7fff64330000 rw-p 00000000 00:00 0 [stack]
  9. 7fff643fe000-7fff64400000 r-xp 00000000 00:00 0 [vdso]
  10. ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0 [vsyscall]
  11. ...

其中 0x00007fbc35785087 就包含在了7fbc35711000-7fbc358f8000 r-xp 00000000 00:01 117964 /usr/bin/Xorg里边,说明出错位置在Xorg程序里边

编译与调试Xorg

下载源码:

  1. apt-get source xserver-xorg-core

下载依赖:

  1. apt-get build-dep xserver-xorg-core

生成Makefile:

  1. ./autogen.sh

修改Makefile,使之可以GDB调试:

vim Makefile,把CFLAGSCCASFLAGS选项修改为

  1. CCASFLAGS = -g -O0
  2. CFLAGS = -g -O0

编译并进行安装

  1. make -j4 install

安装的位置是/usr/local/bin/Xorg,所以启动的时候需要把startx的路径指向于这里,同时还需要把一些库链接过来:

  1. mv /usr/local/lib/xorg /usr/local/lib/xorg.org
  2. ln -svf /usr/lib/xorg /usr/local/lib/xorg
  3. ln -svf /usr/bin/xkb* /usr/local/bin/

注意,如果修改了Xorg的代码,再编译安装的话,安装之前需要把 /usr/local/lib/Xorg 这个链接删掉,避免覆盖了原有的文件

或者手工拷贝替换的文件,比如make -j4 && cp hw/xfree86/Xorg /usr/local/bin/Xorg,这样子就可以继续测试了;

调试:

  1. cgdb /usr/local/bin/Xorg
  2. run
  3. bt

发现问题出现在了 strtol里边,接着调试glibc;

先不调试glibc,因为它不太可能出现Bug,问题现在定位到是GLX初始化时出现的错误

  1. b RegisterExtensionNames if strcmp(extEntry->name, "GLX") == 0

修改全部的Makefile文件,让它们可以进行debug

  1. find . -name Makefile -print -exec sed -i 's/-g -O2/-g -O0/g' {} \;

最后找丁技术确认了这个安装这个GLX时,libglx.so可能会去修改寄存器fs(或者是说它的进入初始化的姿势不太一样?)的内容,这个libglx.so是由NVIDIA提供的,暂时无法修改.

调试X Server的更多相关文章

  1. 使用WinDbg调试SQL Server查询

    上一篇文章我给你介绍了WinDbg的入门,还有你如何能附加到SQL Server.今天的文章,我们继续往前一步,我会向你展示使用WinDbg调试SQL Server查询需要的步骤.听起来很有意思?我们 ...

  2. 使用WinDbg调试SQL Server——入门

    这篇文章我想探究下SQL Server里完全不同的领域:如果使用WinDbg(来自针对Windows的调试工具)调试SQL Server.在我们进入枯涩细节之前,我想详细解释下为什么选择这样晦涩的话题 ...

  3. Eclipse调试cas server 3.5.2.1

    由于在配置CAS+LDAP总是报错,决定Eclipse调试cas server,跟踪问题出在哪里? ================================================== ...

  4. 如何设断点????-----使用WinDbg调试SQL Server查询

    http://www.cnblogs.com/woodytu/p/4665427.html http://www.sqlservercentral.com/blogs/aschenbrenner/20 ...

  5. VS调试SQL Server存储过程

    1.打开VS,视图-->SQL Server对象资源管理器.(我用的是VS2012) 2.添加链接,连接到数据库. 3.选择要调试的存储过程,右键,选择调试过程或者执行过程. 4.填写存储过程所 ...

  6. Visual Studio 2017 调试 windows server 2016 Docker Container

    网上很多文章都是在win10下,用Docker for windows工具进行Docker的安装部署的.用知道windows server 2016已经原生支持Docker了,其windows Con ...

  7. 调试SQL Server的存储过程及用户定义函数

    分类: 数据库管理 2005-06-03 13:57 9837人阅读 评论(5) 收藏 举报 sql server存储vb.net服务器sql语言 1.在查询分析器中调试 查询分析器中调试的步骤如下: ...

  8. IDEA远程调试Ambari Server

    1.配置端口 Ambari Server默认配置了服务端的debug参数,端口为5005.如果要修改端口,可以在/usr/sbin/ambari_server_main.py文件中对应地方修改,直接改 ...

  9. VS 调试Window Server方法

    在需要调试的地方加 Debugger.Launch();然后在本机安装服务并启动即可进入

随机推荐

  1. Servlet深层知识

    一.ServletContext实现请求转发1.得到请求分发器:RequestDispatcherServletContext.getRequestDispatcher(String path):pa ...

  2. Android之Fragment学习总结(1)

    对于Fragment的学习: 近日初步学习了Fragment这以特殊的组件,其依托与一个Activity,与Activity的生命周期息息相关,为其设置的视图只有当其关联到一个Activity才会起效 ...

  3. 占位符(placeholder text)

    占位符(placeholder text)是用户在input(输入)框输入任何东西之前放置在input(输入)框中的预定义文本. 你可以用如下方式创建占位符: <input type=" ...

  4. Magicodes.WeiChat——后台JS框架封装

    Magicodes.WeiChat同时也致力于提高后台开发效率,因此对在后台前端这块也做了一定的封装.我们先来说说主要的框架JS——mwc.js和mwc_elements.js.这两个JS文件位于Sc ...

  5. centos6.4 无法进入图形界面的问题及解决

    在安装了ngnix及pcre.openssl.zlib.lua等模块之后,进不了图形界面. 解决的方法如下: Ctrl+Alt+F5,输入账号和密码 vim /etc/inittab #将等级5改为等 ...

  6. C#设计模式(18)——中介者模式(Mediator Pattern)

    一.引言 在现实生活中,有很多中介者模式的身影,例如QQ游戏平台,聊天室.QQ群和短信平台,这些都是中介者模式在现实生活中的应用,下面就具体分享下我对中介者模式的理解. 二. 中介者模式的介绍 2.1 ...

  7. WebApi 服务监控

    本文主要介绍在请求WebApi时,监控Action执行的时间,及Action传递的参数值,以及Http请求头信息.采用log4net记录监控日志,通过日志记录的时间方便我们定位哪一个Action执行的 ...

  8. jQuery document window load ready 区别详解

    用过JavaScript的童鞋,应该知道window对象和document对象,也应该听说过load事件和ready事件,小菜当然也知道,而且自认为很了解,直到最近出了问题,才知道事情并不是那么简单. ...

  9. struts2学习笔记之四:多配置文件支持和常用配置参数

    struts2支持可以按照不同模块分类的方式拆分配置文件,支持多人分工合作,各自维护自己的配置文件,但是所有配置文件中包名和action的名称不能重复   struts2的配置文件方式有两种,stru ...

  10. js围绕屏幕转圈的方块

    点击运动按钮后,方块会挨着浏览器的边,从左到右,从上到下转一圈. 这个我居然写了几天,我也是不想说什么咯. 完成代码一: <!-- Author: XiaoWen Create a file: ...