本帖最后由 sz_hiter 于 2010-09-05 15:07:33 编辑
如题。
本程序有7个线程,其中一个线程(简称sys线程把。。)每秒会调用几次system函数(例如system("df -h > /tmp/tmpFlashInfo.file"),用于检查Flash的占用情况)。
我主要做了如下的测试:
1、屏蔽sys线程后,其他线程一直运行,正常。
2、打开sys线程后,在调用system函数前,printf一句start,在调用system函数后,printf一句end,然后通过主板运行,串口打印的方式,发现每次出现崩溃的时候(时间不定,少则几分钟,多则几小时),都是打印了start之后,但没有end打印。同时通过core文件分析的崩溃原因是:
Program terminated with signal 11, Segmentation fault.
#0 0x00989680 in ?? ()
(gdb) bt
#0 0x00989680 in ?? ()
#1 0x4002ce6c in ?? () from /lib/libpthread.so.0
(gdb)
看不懂到底是什么问题。。。!
2、屏蔽sys线程中的相关的system函数。(例如检测flash的/tmp/tmpFlashInfo.file用手工创建好后不再删除),7个线程一直运行,正常。
3、由1、2的测试得出在system调用的时候使得程序崩溃(gdb调试core文件说是信号11->段错误,但是程序中信号都捕捉不到。。)
4、将sys线