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.5Smartin 301.1Skamiltest_target() 311.1Skamil{ 321.5Smartin atf_set "require.arch" "x86_64" 331.1Skamil} 341.1Skamil 351.1Skamilatf_test_case vptr_race 361.1Skamilvptr_race_head() { 371.1Skamil atf_set "descr" "Test thread sanitizer for vptr race condition" 381.1Skamil atf_set "require.progs" "c++ paxctl" 391.5Smartin test_target 401.1Skamil} 411.1Skamil 421.1Skamilatf_test_case vptr_race_profile 431.1Skamilvptr_race_profile_head() { 441.1Skamil atf_set "descr" "Test thread sanitizer for vptr race with profiling option" 451.1Skamil atf_set "require.progs" "c++ paxctl" 461.5Smartin test_target 471.1Skamil} 481.1Skamilatf_test_case vptr_race_pic 491.1Skamilvptr_race_pic_head() { 501.1Skamil atf_set "descr" "Test thread sanitizer for vptr race with position independent code (PIC) flag" 511.1Skamil atf_set "require.progs" "c++ paxctl" 521.5Smartin test_target 531.1Skamil} 541.1Skamilatf_test_case vptr_race_pie 551.1Skamilvptr_race_pie_head() { 561.1Skamil atf_set "descr" "Test thread sanitizer for vptr race with position independent execution (PIE) flag" 571.1Skamil atf_set "require.progs" "c++ paxctl" 581.5Smartin test_target 591.1Skamil} 601.1Skamil 611.1Skamilvptr_race_body(){ 621.1Skamil cat > test.cc << EOF 631.1Skamil#include <pthread.h> 641.1Skamilpthread_barrier_t barrier; 651.1Skamilstruct A { 661.1Skamil volatile bool done; 671.1Skamil A(): done(false) { } 681.1Skamil virtual void Done() { done = true; } 691.1Skamil virtual ~A() { while (!done) ; } 701.1Skamil}; 711.1Skamilstruct B: A {}; 721.1SkamilA *obj = new B; 731.1Skamilvoid *Thread1(void *x) { 741.1Skamil pthread_barrier_wait(&barrier); 751.1Skamil obj->Done(); 761.1Skamil return NULL; 771.1Skamil} 781.1Skamilint main() { 791.1Skamil pthread_barrier_init(&barrier, NULL, 2); 801.1Skamil pthread_t t; 811.1Skamil pthread_create(&t, NULL, Thread1, NULL); 821.1Skamil pthread_barrier_wait(&barrier); 831.1Skamil delete obj; 841.1Skamil pthread_join(t, NULL); 851.1Skamil return 0; 861.1Skamil} 871.1SkamilEOF 881.1Skamil 891.1Skamil c++ -fsanitize=thread -o test test.cc 901.1Skamil paxctl +a test 911.8Schristos atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: data race" ./test 921.1Skamil} 931.1Skamil 941.1Skamilvptr_race_profile_body(){ 951.4Sgson atf_expect_fail "PR toolchain/55760" 961.1Skamil cat > test.cc << EOF 971.1Skamil#include <pthread.h> 981.1Skamilpthread_barrier_t barrier; 991.1Skamilstruct A { 1001.1Skamil volatile bool done; 1011.1Skamil A(): done(false) { } 1021.1Skamil virtual void Done() { done = true; } 1031.1Skamil virtual ~A() { while (!done) ; } 1041.1Skamil}; 1051.1Skamilstruct B: A {}; 1061.1SkamilA *obj = new B; 1071.1Skamilvoid *Thread1(void *x) { 1081.1Skamil pthread_barrier_wait(&barrier); 1091.1Skamil obj->Done(); 1101.1Skamil return NULL; 1111.1Skamil} 1121.1Skamilint main() { 1131.1Skamil pthread_barrier_init(&barrier, NULL, 2); 1141.1Skamil pthread_t t; 1151.1Skamil pthread_create(&t, NULL, Thread1, NULL); 1161.1Skamil pthread_barrier_wait(&barrier); 1171.1Skamil delete obj; 1181.1Skamil pthread_join(t, NULL); 1191.1Skamil return 0; 1201.1Skamil} 1211.1SkamilEOF 1221.8Schristos c++ -fsanitize=thread -o test -pg test.cc 1231.1Skamil paxctl +a test 1241.8Schristos atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: data race" ./test 1251.1Skamil} 1261.1Skamil 1271.1Skamilvptr_race_pic_body(){ 1281.1Skamil cat > test.cc << EOF 1291.1Skamil#include <stdio.h> 1301.1Skamil#include <stdlib.h> 1311.1Skamilint help(int); 1321.1Skamilint main(int argc, char **argv) {return help(argc);} 1331.1SkamilEOF 1341.1Skamil 1351.1Skamil cat > pic.cc << EOF 1361.1Skamil#include <pthread.h> 1371.1Skamilpthread_barrier_t barrier; 1381.1Skamilstruct A { 1391.1Skamil volatile bool done; 1401.1Skamil A(): done(false) { } 1411.1Skamil virtual void Done() { done = true; } 1421.1Skamil virtual ~A() { while (!done) ; } 1431.1Skamil}; 1441.1Skamilstruct B: A {}; 1451.1SkamilA *obj = new B; 1461.1Skamilvoid *Thread1(void *x) { 1471.1Skamil pthread_barrier_wait(&barrier); 1481.1Skamil obj->Done(); 1491.1Skamil return NULL; 1501.1Skamil} 1511.1Skamilint help(int argc) { 1521.1Skamil pthread_barrier_init(&barrier, NULL, 2); 1531.1Skamil pthread_t t; 1541.1Skamil pthread_create(&t, NULL, Thread1, NULL); 1551.1Skamil pthread_barrier_wait(&barrier); 1561.1Skamil delete obj; 1571.1Skamil pthread_join(t, NULL); 1581.1Skamil return 0; 1591.1Skamil} 1601.1SkamilEOF 1611.1Skamil 1621.1Skamil c++ -fsanitize=thread -fPIC -shared -o libtest.so pic.cc 1631.1Skamil c++ -o test test.cc -fsanitize=thread -L. -ltest 1641.1Skamil paxctl +a test 1651.1Skamil 1661.1Skamil export LD_LIBRARY_PATH=. 1671.8Schristos atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: data race" ./test 1681.1Skamil} 1691.1Skamilvptr_race_pie_body(){ 1701.6Sskrll 1711.1Skamil #check whether -pie flag is supported on this architecture 1721.6Sskrll if ! c++ -pie -dM -E - < /dev/null 2>/dev/null >/dev/null; then 1731.1Skamil atf_set_skip "c++ -pie not supported on this architecture" 1741.1Skamil fi 1751.1Skamil cat > test.cc << EOF 1761.1Skamil#include <pthread.h> 1771.1Skamilpthread_barrier_t barrier; 1781.1Skamilstruct A { 1791.1Skamil volatile bool done; 1801.1Skamil A(): done(false) { } 1811.1Skamil virtual void Done() { done = true; } 1821.1Skamil virtual ~A() { while (!done) ; } 1831.1Skamil}; 1841.1Skamilstruct B: A {}; 1851.1SkamilA *obj = new B; 1861.1Skamilvoid *Thread1(void *x) { 1871.1Skamil pthread_barrier_wait(&barrier); 1881.1Skamil obj->Done(); 1891.1Skamil return NULL; 1901.1Skamil} 1911.1Skamilint main() { 1921.1Skamil pthread_barrier_init(&barrier, NULL, 2); 1931.1Skamil pthread_t t; 1941.1Skamil pthread_create(&t, NULL, Thread1, NULL); 1951.1Skamil pthread_barrier_wait(&barrier); 1961.1Skamil delete obj; 1971.1Skamil pthread_join(t, NULL); 1981.1Skamil return 0; 1991.1Skamil} 2001.1SkamilEOF 2011.1Skamil 2021.1Skamil c++ -fsanitize=thread -o test -fpie -pie test.cc 2031.1Skamil paxctl +a test 2041.8Schristos atf_check -s ignore -o ignore -e match:"WARNING: ThreadSanitizer: data race" ./test 2051.1Skamil} 2061.1Skamil 2071.1Skamil 2081.1Skamilatf_test_case target_not_supported 2091.1Skamiltarget_not_supported_head() 2101.1Skamil{ 2111.1Skamil atf_set "descr" "Test forced skip" 2121.1Skamil} 2131.1Skamil 2141.2Skamiltarget_not_supported_body() 2151.2Skamil{ 2161.2Skamil atf_skip "Target is not supported" 2171.2Skamil} 2181.2Skamil 2191.1Skamilatf_init_test_cases() 2201.1Skamil{ 2211.1Skamil atf_add_test_case vptr_race 2221.1Skamil atf_add_test_case vptr_race_profile 2231.1Skamil atf_add_test_case vptr_race_pie 2241.1Skamil atf_add_test_case vptr_race_pic 2251.1Skamil} 226