ltp测试套件-pthread_barrier_destroy_2-1分析记录

测试用例地址:

https://github.com/linux-test-project/ltp/blob/master/testcases/open_posix_testsuite/conformance/interfaces/pthread_barrier_destroy/1-1.c

(1)失败打印:
conformance/interfaces/pthread_barrier_destroy/pthread_barrier_destroy_2-1: execution: HUNG: Output: 


(2)问题原因与解决:
分析了用例源码,程序创建了2个线程,一个线程正在占用barrier时,主线程去destroy它,测试用例长时间阻塞不返回。

通过走查glibc2.18代码,发现该接口有返回Ebusy情况,但是测试用例并没有返回EBUSY,而是长时间阻塞。后来经过查看glibc的高版本代码,发现高版本已经对barrier系统调用进行了重写。

这个是glibc高版本问题,在glibc-2.23以后,pthread_barrier系列接口使用了新的算法。2.23版本之前destory不会导致阻塞,会返回EBUSY,ltp套件刚好就认为返回EBUSY才通过。

所以ltp套件也对此进行了更新,解决了这个问题。

https://github.com/linux-test-project/ltp/commit/ee50233bb329bcced8e63d73e0cd3790bd86a8a6

猜你喜欢

转载自blog.csdn.net/y33988979/article/details/82256604
今日推荐