免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3107 | 回复: 5
打印 上一主题 下一主题

[Linux] 在信号处理函数中调用backtrace来打印调用栈 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-06-27 16:29 |只看该作者 |倒序浏览
在信号处理函数中调用backtrace来打印调用栈,存在安全问题吗,比如可重入问题、阻塞问题等

论坛徽章:
0
2 [报告]
发表于 2013-06-28 11:12 |只看该作者
存在安全隐患,但不一定会导致问题,因为backtrace 向I/O输出前,可能有其它线程也向该I/O输出,如果该I/O的写访问是互斥的,而其它线程正在输出时被backtrace 挂起,则会导致backtrace 被阻塞,如果backtrace 被阻塞,则可能导致重入

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
3 [报告]
发表于 2013-06-28 11:20 |只看该作者
随便用, buffer是用户提供的, 没有线程安全问题.

论坛徽章:
0
4 [报告]
发表于 2013-07-13 16:20 |只看该作者
那么如果I/O不是阻塞的话,就没任何问题了吗
回复 2# 卖萌犯法


   

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
5 [报告]
发表于 2013-07-13 23:00 |只看该作者
回复 1# cxm240


    其实所有的问题本质上只是一个“Async-Signal-Safe Function”调用问题,你要保证你在signal handler中调用函数都是“Async-Signal-Safe Function”的,这将保证不会有错误(否则会发生死锁等状况,但毕竟调用会被中断不能保证逻辑上的正确性,比如说字符输出了一半等)。根据你设置signal handler的不同,“Async-Signal-Safe Function”将具有不同的行为。使用signal设置signal handler默认设置了SA_RESTART标志位。这个标志位可以使用sigaction修改。如果设置了SA_RESTART那么在signal handler中的阻塞调用被另一个信号中断时将重启,否则返回EINTR。由于glibc中的自己会作信号处理,所以调用printf这样的函数将会导至不确定性。也就是说如果你想保证输出backtrace安全,不能调用printf这样的glibc中的函数,而应该调用符合“Async-Signal-Safe Function”标准系统函数write向终端中输出,虽然也不能保证输出完整性,但可以保证程序不会出现错误。如果要做的更完善那么可以把可以阻塞的信号都阻塞掉来尽量保证输出的完整性。但这样的意义已经不太大了。

论坛徽章:
0
6 [报告]
发表于 2013-07-14 00:55 |只看该作者
回复 4# cxm240


    理论上是的,没有试验过,不确定
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP