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.4Smartintsan_available_archs() 301.1Skamil{ 311.4Smartin atf_set "require.arch" "x86_64" 321.1Skamil} 331.1Skamil 341.1Skamilatf_test_case data_race 351.1Skamildata_race_head() { 361.1Skamil atf_set "descr" "Test thread sanitizer for data race condition" 371.1Skamil atf_set "require.progs" "c++ paxctl" 381.4Smartin tsan_available_archs 391.1Skamil} 401.1Skamil 411.1Skamilatf_test_case data_race_profile 421.1Skamildata_race_profile_head() { 431.1Skamil atf_set "descr" "Test thread sanitizer for data race with profiling option" 441.1Skamil atf_set "require.progs" "c++ paxctl" 451.4Smartin tsan_available_archs 461.1Skamil} 471.1Skamilatf_test_case data_race_pic 481.1Skamildata_race_pic_head() { 491.1Skamil atf_set "descr" "Test thread sanitizer for data race with position independent code (PIC) flag" 501.1Skamil atf_set "require.progs" "c++ paxctl" 511.4Smartin tsan_available_archs 521.1Skamil} 531.1Skamilatf_test_case data_race_pie 541.1Skamildata_race_pie_head() { 551.1Skamil atf_set "descr" "Test thread sanitizer for data race with position independent execution (PIE) flag" 561.1Skamil atf_set "require.progs" "c++ paxctl" 571.4Smartin tsan_available_archs 581.1Skamil} 591.1Skamil 601.1Skamildata_race_body(){ 611.1Skamil cat > test.cc << EOF 621.1Skamil#include <pthread.h> 631.1Skamilint GlobalData; pthread_barrier_t barrier; 641.1Skamilvoid *Thread(void *a) { pthread_barrier_wait(&barrier); GlobalData = 42; return 0; } 651.1Skamilint main() { 661.1Skamil pthread_t t; 671.1Skamil pthread_barrier_init(&barrier, NULL, 2); 681.1Skamil pthread_create(&t, NULL, Thread, NULL); 691.1Skamil pthread_barrier_wait(&barrier); 701.1Skamil GlobalData = 43; 711.1Skamil pthread_join(t, NULL); 721.1Skamil return 0; 731.1Skamil} 741.1SkamilEOF 751.1Skamil 761.1Skamil c++ -fsanitize=thread -o test test.cc 771.1Skamil paxctl +a test 781.1Skamil atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: data race " ./test 791.1Skamil} 801.1Skamil 811.1Skamildata_race_profile_body(){ 821.5Sgson atf_expect_fail "PR toolchain/55760" 831.1Skamil cat > test.cc << EOF 841.1Skamil#include <pthread.h> 851.1Skamilint GlobalData; pthread_barrier_t barrier; 861.1Skamilvoid *Thread(void *a) { pthread_barrier_wait(&barrier); GlobalData = 42; return 0; } 871.1Skamilint main() { 881.1Skamil pthread_t t; 891.1Skamil pthread_barrier_init(&barrier, NULL, 2); 901.1Skamil pthread_create(&t, NULL, Thread, NULL); 911.1Skamil pthread_barrier_wait(&barrier); 921.1Skamil GlobalData = 43; 931.1Skamil pthread_join(t, NULL); 941.1Skamil return 0; 951.1Skamil} 961.1SkamilEOF 971.1Skamil 981.7Sskrll c++ -fsanitize=thread -static -o test -pg test.cc 991.1Skamil paxctl +a test 1001.1Skamil atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: data race " ./test 1011.1Skamil} 1021.1Skamil 1031.1Skamildata_race_pic_body(){ 1041.1Skamil cat > test.cc << EOF 1051.1Skamil#include <stdio.h> 1061.1Skamil#include <stdlib.h> 1071.1Skamilint help(int); 1081.1Skamilint main(int argc, char **argv) {return help(argc);} 1091.1SkamilEOF 1101.1Skamil 1111.1Skamil cat > pic.cc << EOF 1121.1Skamil#include <pthread.h> 1131.1Skamilint GlobalData; pthread_barrier_t barrier; 1141.1Skamilvoid *Thread(void *a) { pthread_barrier_wait(&barrier); GlobalData = 42; return 0; } 1151.1Skamilint help(int argc) { 1161.1Skamil pthread_t t; 1171.1Skamil pthread_barrier_init(&barrier, NULL, 2); 1181.1Skamil pthread_create(&t, NULL, Thread, NULL); 1191.1Skamil pthread_barrier_wait(&barrier); 1201.1Skamil GlobalData = 43; 1211.1Skamil pthread_join(t, NULL); 1221.1Skamil return 0; 1231.1Skamil} 1241.1SkamilEOF 1251.1Skamil 1261.1Skamil c++ -fsanitize=thread -fPIC -shared -o libtest.so pic.cc 1271.1Skamil c++ -o test test.cc -fsanitize=thread -L. -ltest 1281.1Skamil paxctl +a test 1291.1Skamil 1301.1Skamil export LD_LIBRARY_PATH=. 1311.1Skamil atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: data race " ./test 1321.1Skamil} 1331.1Skamildata_race_pie_body(){ 1341.6Sskrll 1351.1Skamil #check whether -pie flag is supported on this architecture 1361.6Sskrll if ! c++ -pie -dM -E - < /dev/null 2>/dev/null >/dev/null; then 1371.1Skamil atf_set_skip "c++ -pie not supported on this architecture" 1381.1Skamil fi 1391.1Skamil cat > test.cc << EOF 1401.1Skamil#include <pthread.h> 1411.1Skamilint GlobalData; pthread_barrier_t barrier; 1421.1Skamilvoid *Thread(void *a) { pthread_barrier_wait(&barrier); GlobalData = 42; return 0; } 1431.1Skamilint main() { 1441.1Skamil pthread_t t; 1451.1Skamil pthread_barrier_init(&barrier, NULL, 2); 1461.1Skamil pthread_create(&t, NULL, Thread, NULL); 1471.1Skamil pthread_barrier_wait(&barrier); 1481.1Skamil GlobalData = 43; 1491.1Skamil pthread_join(t, NULL); 1501.1Skamil return 0; 1511.1Skamil} 1521.1SkamilEOF 1531.1Skamil 1541.1Skamil c++ -fsanitize=thread -o test -fpie -pie test.cc 1551.1Skamil paxctl +a test 1561.1Skamil atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: data race " ./test 1571.1Skamil} 1581.1Skamil 1591.1Skamilatf_init_test_cases() 1601.1Skamil{ 1611.1Skamil atf_add_test_case data_race 1621.1Skamil atf_add_test_case data_race_profile 1631.1Skamil atf_add_test_case data_race_pie 1641.1Skamil atf_add_test_case data_race_pic 1651.1Skamil} 166