11.1Skamil# Copyright (c) 2018 The NetBSD Foundation, Inc. 21.1Skamil# All rights reserved. 31.1Skamil# 41.1Skamil# This code is derived from software contributed to The NetBSD Foundation 51.1Skamil# by Yang Zheng. 61.1Skamil# 71.1Skamil# Redistribution and use in source and binary forms, with or without 81.1Skamil# modification, are permitted provided that the following conditions 91.1Skamil# are met: 101.1Skamil# 1. Redistributions of source code must retain the above copyright 111.1Skamil# notice, this list of conditions and the following disclaimer. 121.1Skamil# 2. Redistributions in binary form must reproduce the above copyright 131.1Skamil# notice, this list of conditions and the following disclaimer in the 141.1Skamil# documentation and/or other materials provided with the distribution. 151.1Skamil# 161.1Skamil# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 171.1Skamil# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 181.1Skamil# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 191.1Skamil# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 201.1Skamil# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 211.1Skamil# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 221.1Skamil# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 231.1Skamil# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 241.1Skamil# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 251.1Skamil# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 261.1Skamil# POSSIBILITY OF SUCH DAMAGE. 271.1Skamil# 281.1Skamil 291.4Smartin 301.4Smartintsan_available_archs() 311.1Skamil{ 321.4Smartin atf_set "require.arch" "x86_64" 331.1Skamil} 341.1Skamil 351.1Skamilatf_test_case lock_order_inversion 361.1Skamillock_order_inversion_head() { 371.1Skamil atf_set "descr" "Test thread sanitizer for lock order inversion condition" 381.1Skamil atf_set "require.progs" "c++ paxctl" 391.4Smartin tsan_available_archs 401.1Skamil} 411.1Skamil 421.1Skamilatf_test_case lock_order_inversion_profile 431.1Skamillock_order_inversion_profile_head() { 441.1Skamil atf_set "descr" "Test thread sanitizer for lock order inversion with profiling option" 451.1Skamil atf_set "require.progs" "c++ paxctl" 461.4Smartin tsan_available_archs 471.1Skamil} 481.1Skamilatf_test_case lock_order_inversion_pic 491.1Skamillock_order_inversion_pic_head() { 501.1Skamil atf_set "descr" "Test thread sanitizer for lock order inversion with position independent code (PIC) flag" 511.1Skamil atf_set "require.progs" "c++ paxctl" 521.4Smartin tsan_available_archs 531.1Skamil} 541.1Skamilatf_test_case lock_order_inversion_pie 551.1Skamillock_order_inversion_pie_head() { 561.1Skamil atf_set "descr" "Test thread sanitizer for lock order inversion with position independent execution (PIE) flag" 571.1Skamil atf_set "require.progs" "c++ paxctl" 581.4Smartin tsan_available_archs 591.1Skamil} 601.1Skamil 611.1Skamillock_order_inversion_body(){ 621.1Skamil cat > test.cc << EOF 631.1Skamil#include <pthread.h> 641.1Skamil 651.1Skamilpthread_mutex_t l1, l2; 661.1Skamilint main() { 671.1Skamil pthread_mutex_init(&l1, NULL); 681.1Skamil pthread_mutex_init(&l2, NULL); 691.1Skamil pthread_mutex_lock(&l2); 701.1Skamil pthread_mutex_lock(&l1); 711.1Skamil pthread_mutex_unlock(&l1); 721.1Skamil pthread_mutex_unlock(&l2); 731.1Skamil 741.1Skamil pthread_mutex_lock(&l1); 751.1Skamil pthread_mutex_lock(&l2); 761.1Skamil pthread_mutex_unlock(&l2); 771.1Skamil pthread_mutex_unlock(&l1); 781.1Skamil return 0; 791.1Skamil} 801.1SkamilEOF 811.1Skamil 821.1Skamil c++ -fsanitize=thread -o test test.cc 831.1Skamil paxctl +a test 841.1Skamil atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: lock-order-inversion" ./test 851.1Skamil} 861.1Skamil 871.1Skamillock_order_inversion_profile_body(){ 881.5Sgson atf_expect_fail "PR toolchain/55760" 891.1Skamil cat > test.cc << EOF 901.1Skamil#include <pthread.h> 911.1Skamil 921.1Skamilpthread_mutex_t l1, l2; 931.1Skamilint main() { 941.1Skamil pthread_mutex_init(&l1, NULL); 951.1Skamil pthread_mutex_init(&l2, NULL); 961.1Skamil pthread_mutex_lock(&l2); 971.1Skamil pthread_mutex_lock(&l1); 981.1Skamil pthread_mutex_unlock(&l1); 991.1Skamil pthread_mutex_unlock(&l2); 1001.1Skamil 1011.1Skamil pthread_mutex_lock(&l1); 1021.1Skamil pthread_mutex_lock(&l2); 1031.1Skamil pthread_mutex_unlock(&l2); 1041.1Skamil pthread_mutex_unlock(&l1); 1051.1Skamil return 0; 1061.1Skamil} 1071.1SkamilEOF 1081.1Skamil 1091.7Sskrll c++ -fsanitize=thread -static -o test -pg test.cc 1101.1Skamil paxctl +a test 1111.1Skamil atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: lock-order-inversion" ./test 1121.1Skamil} 1131.1Skamil 1141.1Skamillock_order_inversion_pic_body(){ 1151.1Skamil cat > test.cc << EOF 1161.1Skamil#include <stdio.h> 1171.1Skamil#include <stdlib.h> 1181.1Skamilint help(int); 1191.1Skamilint main(int argc, char **argv) {return help(argc);} 1201.1SkamilEOF 1211.1Skamil 1221.1Skamil cat > pic.cc << EOF 1231.1Skamil#include <pthread.h> 1241.1Skamil 1251.1Skamilpthread_mutex_t l1, l2; 1261.1Skamilint help(int argc) { 1271.1Skamil pthread_mutex_init(&l1, NULL); 1281.1Skamil pthread_mutex_init(&l2, NULL); 1291.1Skamil pthread_mutex_lock(&l2); 1301.1Skamil pthread_mutex_lock(&l1); 1311.1Skamil pthread_mutex_unlock(&l1); 1321.1Skamil pthread_mutex_unlock(&l2); 1331.1Skamil 1341.1Skamil pthread_mutex_lock(&l1); 1351.1Skamil pthread_mutex_lock(&l2); 1361.1Skamil pthread_mutex_unlock(&l2); 1371.1Skamil pthread_mutex_unlock(&l1); 1381.1Skamil return 0; 1391.1Skamil} 1401.1SkamilEOF 1411.1Skamil 1421.1Skamil c++ -fsanitize=thread -fPIC -shared -o libtest.so pic.cc 1431.1Skamil c++ -o test test.cc -fsanitize=thread -L. -ltest 1441.1Skamil paxctl +a test 1451.1Skamil 1461.1Skamil export LD_LIBRARY_PATH=. 1471.1Skamil atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: lock-order-inversion" ./test 1481.1Skamil} 1491.1Skamillock_order_inversion_pie_body(){ 1501.6Sskrll 1511.1Skamil #check whether -pie flag is supported on this architecture 1521.6Sskrll if ! c++ -pie -dM -E - < /dev/null 2>/dev/null >/dev/null; then 1531.1Skamil atf_set_skip "c++ -pie not supported on this architecture" 1541.1Skamil fi 1551.1Skamil cat > test.cc << EOF 1561.1Skamil#include <pthread.h> 1571.1Skamil 1581.1Skamilpthread_mutex_t l1, l2; 1591.1Skamilint main() { 1601.1Skamil pthread_mutex_init(&l1, NULL); 1611.1Skamil pthread_mutex_init(&l2, NULL); 1621.1Skamil pthread_mutex_lock(&l2); 1631.1Skamil pthread_mutex_lock(&l1); 1641.1Skamil pthread_mutex_unlock(&l1); 1651.1Skamil pthread_mutex_unlock(&l2); 1661.1Skamil 1671.1Skamil pthread_mutex_lock(&l1); 1681.1Skamil pthread_mutex_lock(&l2); 1691.1Skamil pthread_mutex_unlock(&l2); 1701.1Skamil pthread_mutex_unlock(&l1); 1711.1Skamil return 0; 1721.1Skamil} 1731.1SkamilEOF 1741.1Skamil 1751.1Skamil c++ -fsanitize=thread -o test -fpie -pie test.cc 1761.1Skamil paxctl +a test 1771.1Skamil atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: lock-order-inversion" ./test 1781.1Skamil} 1791.1Skamil 1801.1Skamilatf_init_test_cases() 1811.1Skamil{ 1821.1Skamil atf_add_test_case lock_order_inversion 1831.1Skamil atf_add_test_case lock_order_inversion_profile 1841.1Skamil atf_add_test_case lock_order_inversion_pie 1851.1Skamil atf_add_test_case lock_order_inversion_pic 1861.1Skamil} 187