Qt主线程卡死,竟然与X11 的 _XReply() 有关

在ubuntu系统下运行Qt程序

Qt的程序就相当于X11的一个客户端,受X11的限制

 

近期,在处理一起离奇事件,发现UI的qt界面已经卡死了,无鼠标键盘任何反应

但程序是运行的,比如与其他设备通信是正常的,说明程序本身没有死掉。

通过断点,发现所有的槽均失效了

 

如果重启应用程序,可以恢复正常的。

出现的概率不大,但总能出来,总的来说是没有找到规律。

 

一开始,一直怀疑程序本身代码出现出现,比如槽函数里出现死循环等,因为这样比较适合解释现象。

 

当出现问题的时候,通过GDB调试,发现x11卡在某个函数地方

 

 

 

提示:libX11.so.6  _XReply()

 

百思不得其解

 

难不成X11的bug?

从现象看,的确存在漏洞,x11会出现死等的情况

 

因此,解决办法:

1. 去x11网站看看,有没有类似问题,的确也有,已经在下一个版本上解决了,正好,拿来编译下,替换掉原先的,发现问题的确再也不出现了

2. 自己修改x11的源码,也是可以的,就是把wait那个地方改成不要死等,就可以了

 

mark一下

 另外,最近也一直在处理linux的疑难杂症,特别是涉及到两起UI相关

也花了点时间,了解下linux一些机制。

 

Linux是开源的,因此,就各大帮派林立,除了内核还相对纯洁,其他真的五花八门,

而实际项目,也或多或少受到核心板开发商的影响(一般来说,某款核心板,可以使用哪个系统,哪个版本的内核,都是有一定限制,

如果换版本,换系统都比较麻烦,一般核心板供应也不会技术支持)

 

因此,碰到类似“系统”级别的问题,往往束手无策,当出现概率又比较低的时候,更是头疼,这就需要解决人员的很高的要求(说实在的,

每每在解决问题的时候,总感觉自己是新手)

 

以下这张图蛮好的,mark。不幸的是,一个月内,处理了图中的两个地方的bug!好在结局还算顺利

 

 

posted @ 2020-12-29 14:56  小刚学长  阅读(909)  评论(0编辑  收藏  举报