Files
rtems/testsuites/psxtests/psx11/task.c
Joel Sherrill 2e7e636f75 2009-05-10 Joel Sherrill <joel.sherrill@oarcorp.com>
* psx01/init.c, psx01/task.c, psx02/init.c, psx02/task.c, psx03/init.c,
	psx04/init.c, psx04/task1.c, psx04/task3.c, psx05/init.c,
	psx06/init.c, psx07/init.c, psx08/init.c, psx09/init.c, psx11/task.c,
	psx12/init.c, psx13/main.c, psx13/test.c, psxbarrier01/test.c,
	psxcancel/init.c, psxcleanup/psxcleanup.c, psxenosys/init.c,
	psxmsgq02/init.c, psxtime/main.c, psxtime/test.c,
	psxtimer01/psxtimer.c, psxtimer02/psxtimer.c: Fix warnings.
2009-05-11 01:41:16 +00:00

98 lines
2.0 KiB
C

/* Task_1
*
* This routine serves as a test task. It verifies the basic task
* switching capabilities of the executive.
*
* Input parameters:
* argument - task argument
*
* Output parameters: NONE
*
* COPYRIGHT (c) 1989-2009.
* On-Line Applications Research Corporation (OAR).
*
* The license and distribution terms for this file may be
* found in the file LICENSE in this distribution or at
* http://www.rtems.com/license/LICENSE.
*
* $Id$
*/
#include "system.h"
#include <time.h>
#include <sched.h>
void diff_timespec(
struct timespec *start,
struct timespec *stop,
struct timespec *result
);
void diff_timespec(
struct timespec *start,
struct timespec *stop,
struct timespec *result
)
{
int nsecs_per_sec = 1000000000;
result->tv_sec = stop->tv_sec - start->tv_sec;
if ( stop->tv_nsec < start->tv_nsec ) {
result->tv_nsec = nsecs_per_sec - start->tv_nsec + stop->tv_nsec;
result->tv_sec--;
} else
result->tv_nsec = stop->tv_nsec - start->tv_nsec;
}
void *Task_1(
void *argument
)
{
int status;
struct timespec start;
struct timespec current;
struct timespec difference;
struct timespec delay;
status = clock_gettime( CLOCK_REALTIME, &start );
assert( !status );
status = sched_rr_get_interval( getpid(), &delay );
assert( !status );
/* double the rr interval for confidence */
delay.tv_sec *= 2;
delay.tv_nsec *= 2;
if ( delay.tv_nsec >= 1000000000 ) { /* handle overflow/carry */
delay.tv_nsec -= 1000000000;
delay.tv_sec++;
}
puts( "Task_1: killing time" );
for ( ; ; ) {
status = clock_gettime( CLOCK_REALTIME, &current );
assert( !status );
diff_timespec( &start, &current, &difference );
if ( difference.tv_sec < delay.tv_sec )
continue;
if ( difference.tv_sec > delay.tv_sec )
break;
if ( difference.tv_nsec > delay.tv_nsec )
break;
}
puts( "Task_1: exitting" );
pthread_exit( NULL );
return NULL; /* just so the compiler thinks we returned something */
}