mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-05-14 18:06:32 +00:00

This change introduces a check-libomp target which is based upon llvm's lit test infrastructure. Each test (generated from the University of Houston's OpenMP testsuite) is compiled and then run. For each test, an exit status of 0 indicates success and non-zero indicates failure. This way, FileCheck is not needed. I've added a bit of logic to generate symlinks (libiomp5 and libgomp) in the build tree so that gcc can be tested as well. When building out-of- tree builds, the user will have to provide llvm-lit either by specifying -DLIBOMP_LLVM_LIT_EXECUTABLE or having llvm-lit in their PATH. Differential Revision: http://reviews.llvm.org/D11821 llvm-svn: 248211
47 lines
954 B
C
47 lines
954 B
C
// RUN: %libomp-compile-and-run
|
|
#include <stdio.h>
|
|
#include "omp_testsuite.h"
|
|
|
|
int test_omp_parallel_num_threads()
|
|
{
|
|
int num_failed;
|
|
int threads;
|
|
int nthreads;
|
|
int max_threads = 0;
|
|
|
|
num_failed = 0;
|
|
|
|
/* first we check how many threads are available */
|
|
#pragma omp parallel
|
|
{
|
|
#pragma omp master
|
|
max_threads = omp_get_num_threads ();
|
|
}
|
|
|
|
/* we increase the number of threads from one to maximum:*/
|
|
for(threads = 1; threads <= max_threads; threads++) {
|
|
nthreads = 0;
|
|
#pragma omp parallel reduction(+:num_failed) num_threads(threads)
|
|
{
|
|
num_failed = num_failed + !(threads == omp_get_num_threads());
|
|
#pragma omp atomic
|
|
nthreads += 1;
|
|
}
|
|
num_failed = num_failed + !(nthreads == threads);
|
|
}
|
|
return (!num_failed);
|
|
}
|
|
|
|
int main()
|
|
{
|
|
int i;
|
|
int num_failed=0;
|
|
|
|
for(i = 0; i < REPETITIONS; i++) {
|
|
if(!test_omp_parallel_num_threads()) {
|
|
num_failed++;
|
|
}
|
|
}
|
|
return num_failed;
|
|
}
|