powerpc/selftests: Wait all threads to join

Test tm-tmspr might exit before all threads stop executing, because it just
waits for the very last thread to join before proceeding/exiting.

This patch makes sure that all threads that were created will join before
proceeding/exiting.

This patch also guarantees that the amount of threads being created is equal
to thread_num.

Signed-off-by: Breno Leitao <leitao@debian.org>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
This commit is contained in:
Breno Leitao 2018-07-31 17:55:57 -03:00 committed by Michael Ellerman
parent b0dc0f8618
commit 693b31b2fc
1 changed files with 19 additions and 12 deletions

View File

@ -98,7 +98,7 @@ void texasr(void *in)
int test_tmspr()
{
pthread_t thread;
pthread_t *thread;
int thread_num;
unsigned long i;
@ -107,21 +107,28 @@ int test_tmspr()
/* To cause some context switching */
thread_num = 10 * sysconf(_SC_NPROCESSORS_ONLN);
/* Test TFIAR and TFHAR */
for (i = 0 ; i < thread_num ; i += 2){
if (pthread_create(&thread, NULL, (void*)tfiar_tfhar, (void *)i))
return EXIT_FAILURE;
}
if (pthread_join(thread, NULL) != 0)
thread = malloc(thread_num * sizeof(pthread_t));
if (thread == NULL)
return EXIT_FAILURE;
/* Test TEXASR */
for (i = 0 ; i < thread_num ; i++){
if (pthread_create(&thread, NULL, (void*)texasr, (void *)i))
/* Test TFIAR and TFHAR */
for (i = 0; i < thread_num; i += 2) {
if (pthread_create(&thread[i], NULL, (void *)tfiar_tfhar,
(void *)i))
return EXIT_FAILURE;
}
if (pthread_join(thread, NULL) != 0)
/* Test TEXASR */
for (i = 1; i < thread_num; i += 2) {
if (pthread_create(&thread[i], NULL, (void *)texasr, (void *)i))
return EXIT_FAILURE;
}
for (i = 0; i < thread_num; i++) {
if (pthread_join(thread[i], NULL) != 0)
return EXIT_FAILURE;
}
free(thread);
if (passed)
return 0;