ostest: fix smp ostest fail

In SMP we need improve thread waiting strategy

Signed-off-by: hujun5 <hujun5@xiaomi.com>
This commit is contained in:
hujun5 2023-04-16 20:54:07 +08:00 committed by Alin Jerpelea
parent fe1d701b71
commit f0f98c3d73
5 changed files with 63 additions and 5 deletions

View File

@ -33,6 +33,7 @@
#include <stdio.h> #include <stdio.h>
#include <time.h> #include <time.h>
#include <unistd.h> #include <unistd.h>
#include <semaphore.h>
#include "ostest.h" #include "ostest.h"
@ -42,6 +43,7 @@
static pthread_mutex_t mutex; static pthread_mutex_t mutex;
static pthread_cond_t cond; static pthread_cond_t cond;
static sem_t sem_thread_started;
/**************************************************************************** /****************************************************************************
* Private Functions * Private Functions
@ -80,6 +82,7 @@ static FAR void *sem_waiter(FAR void *parameter)
ASSERT(false); ASSERT(false);
} }
sem_post(&sem_thread_started);
printf("sem_waiter: Starting wait for condition\n"); printf("sem_waiter: Starting wait for condition\n");
/* Are we a non-cancelable thread? Yes, set the non-cancelable state */ /* Are we a non-cancelable thread? Yes, set the non-cancelable state */
@ -428,6 +431,8 @@ void cancel_test(void)
void *result; void *result;
int status; int status;
sem_init(&sem_thread_started, 0, 0);
/* Test 1: Normal Cancel **************************************************/ /* Test 1: Normal Cancel **************************************************/
/* Start the waiter thread */ /* Start the waiter thread */
@ -440,7 +445,13 @@ void cancel_test(void)
* make sure. * make sure.
*/ */
usleep(75 * 1000); sem_wait(&sem_thread_started);
/* Make sure sem_waiter run into pthread_cond_wait */
pthread_mutex_lock(&mutex);
pthread_mutex_unlock(&mutex);
printf("cancel_test: Canceling thread\n"); printf("cancel_test: Canceling thread\n");
status = pthread_cancel(waiter); status = pthread_cancel(waiter);
@ -561,7 +572,13 @@ void cancel_test(void)
* bit to be certain. * bit to be certain.
*/ */
usleep(100 * 1000); sem_wait(&sem_thread_started);
/* Make sure sem_waiter run into pthread_cond_wait */
pthread_mutex_lock(&mutex);
pthread_mutex_unlock(&mutex);
printf("cancel_test: Canceling thread\n"); printf("cancel_test: Canceling thread\n");
status = pthread_cancel(waiter); status = pthread_cancel(waiter);
@ -625,7 +642,13 @@ void cancel_test(void)
* The cancellation should succeed, because the cancellation is pending. * The cancellation should succeed, because the cancellation is pending.
*/ */
usleep(100 * 1000); sem_wait(&sem_thread_started);
/* Make sure sem_waiter run into pthread_cond_wait */
pthread_mutex_lock(&mutex);
pthread_mutex_unlock(&mutex);
printf("cancel_test: Canceling thread\n"); printf("cancel_test: Canceling thread\n");
status = pthread_cancel(waiter); status = pthread_cancel(waiter);
@ -693,6 +716,7 @@ void cancel_test(void)
printf("cancel_test: Test 6: Cancel message queue wait\n"); printf("cancel_test: Test 6: Cancel message queue wait\n");
printf("cancel_test: Starting thread (cancelable)\n"); printf("cancel_test: Starting thread (cancelable)\n");
sem_destroy(&sem_thread_started);
#if !defined(CONFIG_DISABLE_MQUEUE) && defined(CONFIG_CANCELLATION_POINTS) #if !defined(CONFIG_DISABLE_MQUEUE) && defined(CONFIG_CANCELLATION_POINTS)
/* Create the message queue */ /* Create the message queue */

View File

@ -27,6 +27,7 @@
#include <sched.h> #include <sched.h>
#include <stdio.h> #include <stdio.h>
#include <unistd.h> #include <unistd.h>
#include <semaphore.h>
#include "ostest.h" #include "ostest.h"
@ -59,6 +60,7 @@ static int signaler_nloops = 0;
static int signaler_already = 0; static int signaler_already = 0;
static int signaler_state = 0; static int signaler_state = 0;
static int signaler_nerrors = 0; static int signaler_nerrors = 0;
static sem_t sem_thread_started;
/**************************************************************************** /****************************************************************************
* Private Functions * Private Functions
@ -78,6 +80,7 @@ static void *thread_waiter(void *parameter)
status = pthread_mutex_lock(&mutex); status = pthread_mutex_lock(&mutex);
waiter_state = RUNNING; waiter_state = RUNNING;
sem_post(&sem_thread_started);
if (status != 0) if (status != 0)
{ {
printf("waiter_thread: " printf("waiter_thread: "
@ -219,7 +222,10 @@ static void *thread_signaler(void *parameter)
* To avoid this situaltion, we add the following usleep() * To avoid this situaltion, we add the following usleep()
*/ */
while (data_available == 1)
{
usleep(10 * 1000); usleep(10 * 1000);
}
#endif #endif
signaler_nloops++; signaler_nloops++;
@ -248,6 +254,8 @@ void cond_test(void)
int prio_mid; int prio_mid;
int status; int status;
sem_init(&sem_thread_started, 0, 0);
/* Initialize the mutex */ /* Initialize the mutex */
printf("cond_test: Initializing mutex\n"); printf("cond_test: Initializing mutex\n");
@ -302,6 +310,8 @@ void cond_test(void)
printf("cond_test: pthread_create failed, status=%d\n", status); printf("cond_test: pthread_create failed, status=%d\n", status);
} }
sem_wait(&sem_thread_started);
printf("cond_test: Starting signaler\n"); printf("cond_test: Starting signaler\n");
status = pthread_attr_init(&attr); status = pthread_attr_init(&attr);
if (status != 0) if (status != 0)
@ -338,6 +348,7 @@ void cond_test(void)
printf("cond_test: signaler terminated, now cancel the waiter\n"); printf("cond_test: signaler terminated, now cancel the waiter\n");
pthread_detach(waiter); pthread_detach(waiter);
pthread_cancel(waiter); pthread_cancel(waiter);
sem_destroy(&sem_thread_started);
printf("cond_test: \tWaiter\tSignaler\n"); printf("cond_test: \tWaiter\tSignaler\n");
printf("cond_test: Loops\t%d\t%d\n", waiter_nloops, signaler_nloops); printf("cond_test: Loops\t%d\t%d\n", waiter_nloops, signaler_nloops);

View File

@ -43,6 +43,7 @@ struct race_cond_s
****************************************************************************/ ****************************************************************************/
static int g_race_cond_thread_pos; static int g_race_cond_thread_pos;
static sem_t g_sem_thread_started;
/**************************************************************************** /****************************************************************************
* Private Functions * Private Functions
@ -308,6 +309,7 @@ static FAR void *timeout_thread1(FAR void *data)
ASSERT(false); ASSERT(false);
} }
sem_post(&g_sem_thread_started);
sem_wait(rc->sem1); sem_wait(rc->sem1);
status = pthread_rwlock_unlock(rc->rw_lock); status = pthread_rwlock_unlock(rc->rw_lock);
@ -408,6 +410,9 @@ static void test_timeout(void)
rc.rw_lock = &rw_lock; rc.rw_lock = &rw_lock;
status = pthread_create(&thread1, NULL, timeout_thread1, &rc); status = pthread_create(&thread1, NULL, timeout_thread1, &rc);
status = sem_wait(&g_sem_thread_started);
status = pthread_create(&thread2, NULL, timeout_thread2, &rc); status = pthread_create(&thread2, NULL, timeout_thread2, &rc);
pthread_join(thread1, NULL); pthread_join(thread1, NULL);
@ -425,6 +430,8 @@ void pthread_rwlock_test(void)
printf("pthread_rwlock: Initializing rwlock\n"); printf("pthread_rwlock: Initializing rwlock\n");
sem_init(&g_sem_thread_started, 0, 0);
status = pthread_rwlock_init(&rw_lock, NULL); status = pthread_rwlock_init(&rw_lock, NULL);
if (status != 0) if (status != 0)
{ {
@ -489,4 +496,6 @@ void pthread_rwlock_test(void)
test_two_threads(); test_two_threads();
test_timeout(); test_timeout();
sem_destroy(&g_sem_thread_started);
} }

View File

@ -240,6 +240,15 @@ void sem_test(void)
ASSERT(false); ASSERT(false);
} }
/* Make sure waiter_thread1 and waiter_thread2 in sem_wait */
do
{
sem_getvalue(&sem, &status);
usleep(10 * 1000L);
}
while (status != -2);
printf("sem_test: Starting poster thread 3\n"); printf("sem_test: Starting poster thread 3\n");
status = pthread_attr_init(&attr); status = pthread_attr_init(&attr);
if (status != 0) if (status != 0)

View File

@ -119,7 +119,12 @@ static FAR void *verifier(FAR void *arg)
/* Wait for count workers to run. */ /* Wait for count workers to run. */
do
{
usleep(SLEEP_TIME); usleep(SLEEP_TIME);
sem_getvalue(&call_sem, &call_count);
}
while (call_count != VERIFY_COUNT);
sem_getvalue(&call_sem, &call_count); sem_getvalue(&call_sem, &call_count);
printf("wqueue_test: call = %d, expect = %d\n", call_count, VERIFY_COUNT); printf("wqueue_test: call = %d, expect = %d\n", call_count, VERIFY_COUNT);