OS test: improve the sporadic scheduler test by waiting for a bit in the 'nuisance' thread
This commit is contained in:
parent
c27364570f
commit
ae2e61c764
@ -73,13 +73,35 @@ static time_t g_start_time;
|
|||||||
* Private Functions
|
* Private Functions
|
||||||
***********************************************************************/
|
***********************************************************************/
|
||||||
|
|
||||||
|
void my_mdelay(unsigned int milliseconds)
|
||||||
|
{
|
||||||
|
volatile unsigned int i;
|
||||||
|
volatile unsigned int j;
|
||||||
|
|
||||||
|
for (i = 0; i < milliseconds; i++)
|
||||||
|
{
|
||||||
|
for (j = 0; j < CONFIG_BOARD_LOOPSPERMSEC; j++)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
static void *nuisance_func(void *parameter)
|
static void *nuisance_func(void *parameter)
|
||||||
{
|
{
|
||||||
|
/* Synchronized start */
|
||||||
|
|
||||||
while (sem_wait(&g_sporadic_sem) < 0);
|
while (sem_wait(&g_sporadic_sem) < 0);
|
||||||
|
|
||||||
|
/* Sleep until we are cancelled */
|
||||||
|
|
||||||
for (;;)
|
for (;;)
|
||||||
{
|
{
|
||||||
|
/* Sleep gracefully for awhile */
|
||||||
|
|
||||||
usleep(500*1000);
|
usleep(500*1000);
|
||||||
|
|
||||||
|
/* Then hog some CPU time */
|
||||||
|
|
||||||
|
my_mdelay(100);
|
||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user