forked from Imagelibrary/rtems
* psx01/init.c, psx01/system.h, psx01/task.c, psx02/init.c, psx02/system.h, psx02/task.c, psx03/init.c, psx03/system.h, psx03/task.c, psx04/init.c, psx04/system.h, psx04/task1.c, psx04/task2.c, psx04/task3.c, psx05/init.c, psx05/system.h, psx05/task.c, psx05/task2.c, psx05/task3.c, psx06/init.c, psx06/system.h, psx06/task.c, psx06/task2.c, psx07/init.c, psx07/system.h, psx07/task.c, psx08/init.c, psx08/system.h, psx08/task1.c, psx08/task2.c, psx08/task3.c, psx09/init.c, psx09/system.h, psx10/init.c, psx10/system.h, psx10/task.c, psx10/task2.c, psx10/task3.c, psx11/init.c, psx11/system.h, psx11/task.c, psx12/init.c, psx12/system.h, psx12/task.c, psx13/main.c, psx13/test.c, psxcancel/init.c, psxfile01/main.c, psxfile01/test.c, psxhdrs/clock01.c, psxhdrs/clock02.c, psxhdrs/clock03.c, psxhdrs/clock04.c, psxhdrs/clock05.c, psxhdrs/clock06.c, psxhdrs/cond01.c, psxhdrs/cond02.c, psxhdrs/cond03.c, psxhdrs/cond04.c, psxhdrs/cond05.c, psxhdrs/cond06.c, psxhdrs/cond07.c, psxhdrs/cond08.c, psxhdrs/cond09.c, psxhdrs/cond10.c, psxhdrs/key01.c, psxhdrs/key02.c, psxhdrs/key03.c, psxhdrs/key04.c, psxhdrs/mutex01.c, psxhdrs/mutex02.c, psxhdrs/mutex03.c, psxhdrs/mutex04.c, psxhdrs/mutex05.c, psxhdrs/mutex06.c, psxhdrs/mutex07.c, psxhdrs/mutex08.c, psxhdrs/mutex09.c, psxhdrs/mutex10.c, psxhdrs/mutex11.c, psxhdrs/mutex12.c, psxhdrs/mutex13.c, psxhdrs/mutex14.c, psxhdrs/mutex15.c, psxhdrs/mutex16.c, psxhdrs/proc01.c, psxhdrs/proc02.c, psxhdrs/proc03.c, psxhdrs/proc04.c, psxhdrs/proc05.c, psxhdrs/proc06.c, psxhdrs/proc07.c, psxhdrs/proc08.c, psxhdrs/proc09.c, psxhdrs/proc10.c, psxhdrs/proc11.c, psxhdrs/proc12.c, psxhdrs/proc13.c, psxhdrs/proc14.c, psxhdrs/pthread01.c, psxhdrs/pthread02.c, psxhdrs/pthread03.c, psxhdrs/pthread04.c, psxhdrs/pthread05.c, psxhdrs/pthread06.c, psxhdrs/pthread07.c, psxhdrs/pthread08.c, psxhdrs/pthread09.c, psxhdrs/pthread10.c, psxhdrs/pthread11.c, psxhdrs/pthread12.c, psxhdrs/pthread13.c, psxhdrs/pthread14.c, psxhdrs/pthread15.c, psxhdrs/pthread16.c, psxhdrs/pthread17.c, psxhdrs/pthread18.c, psxhdrs/pthread19.c, psxhdrs/pthread20.c, psxhdrs/pthread21.c, psxhdrs/pthread22.c, psxhdrs/pthread23.c, psxhdrs/pthread24.c, psxhdrs/pthread25.c, psxhdrs/pthread26.c, psxhdrs/pthread27.c, psxhdrs/pthread28.c, psxhdrs/pthread29.c, psxhdrs/pthread30.c, psxhdrs/pthread31.c, psxhdrs/pthread32.c, psxhdrs/pthread33.c, psxhdrs/pthread34.c, psxhdrs/pthread35.c, psxhdrs/pthread36.c, psxhdrs/sched01.c, psxhdrs/sched02.c, psxhdrs/sched03.c, psxhdrs/sched04.c, psxhdrs/sched05.c, psxhdrs/sched06.c, psxhdrs/sched07.c, psxhdrs/sched08.c, psxhdrs/signal01.c, psxhdrs/signal02.c, psxhdrs/signal03.c, psxhdrs/signal04.c, psxhdrs/signal05.c, psxhdrs/signal06.c, psxhdrs/signal07.c, psxhdrs/signal08.c, psxhdrs/signal09.c, psxhdrs/signal10.c, psxhdrs/signal11.c, psxhdrs/signal12.c, psxhdrs/signal13.c, psxhdrs/signal14.c, psxhdrs/signal15.c, psxhdrs/signal16.c, psxhdrs/signal17.c, psxhdrs/signal18.c, psxhdrs/signal19.c, psxhdrs/signal20.c, psxhdrs/signal21.c, psxhdrs/signal22.c, psxhdrs/signal23.c, psxhdrs/sync01.c, psxhdrs/sync02.c, psxhdrs/sync03.c, psxhdrs/time01.c, psxhdrs/time02.c, psxhdrs/time03.c, psxhdrs/time04.c, psxhdrs/time05.c, psxhdrs/time06.c, psxhdrs/time07.c, psxhdrs/time08.c, psxhdrs/time09.c, psxhdrs/time10.c, psxhdrs/time11.c, psxhdrs/time12.c, psxhdrs/time13.c, psxhdrs/timer01.c, psxhdrs/timer02.c, psxhdrs/timer03.c, psxhdrs/timer04.c, psxhdrs/timer05.c, psxhdrs/timer06.c, psxhdrs/timer07.c, psxmsgq01/init.c, psxmsgq01/system.h, psxsem01/system.h, psxstat/main.c, psxstat/test.c, psxtime/main.c, psxtime/test.c, psxtimer/psxtimer.c, psxtimer/system.h: URL for license changed.
204 lines
4.7 KiB
C
204 lines
4.7 KiB
C
/*
|
|
* COPYRIGHT (c) 1989-1999.
|
|
* 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$
|
|
*/
|
|
|
|
#define CONFIGURE_INIT
|
|
#include "system.h"
|
|
#include <signal.h>
|
|
#include <errno.h>
|
|
|
|
volatile int Signal_occurred;
|
|
volatile int Signal_count;
|
|
|
|
void Signal_handler(
|
|
int signo
|
|
)
|
|
{
|
|
Signal_count++;
|
|
printf(
|
|
"Signal: %d caught by 0x%x (%d)\n",
|
|
signo,
|
|
pthread_self(),
|
|
Signal_count
|
|
);
|
|
Signal_occurred = 1;
|
|
}
|
|
|
|
void *POSIX_Init(
|
|
void *argument
|
|
)
|
|
{
|
|
int status;
|
|
struct timespec timeout;
|
|
struct sigaction act;
|
|
sigset_t mask;
|
|
sigset_t waitset;
|
|
int signo;
|
|
siginfo_t siginfo;
|
|
|
|
puts( "\n\n*** POSIX TEST 3 ***" );
|
|
|
|
/* set the time of day, and print our buffer in multiple ways */
|
|
|
|
set_time( TM_FRIDAY, TM_MAY, 24, 96, 11, 5, 0 );
|
|
|
|
/* get id of this thread */
|
|
|
|
Init_id = pthread_self();
|
|
printf( "Init's ID is 0x%08x\n", Init_id );
|
|
|
|
/* install a signal handler */
|
|
|
|
status = sigemptyset( &act.sa_mask );
|
|
assert( !status );
|
|
|
|
act.sa_handler = Signal_handler;
|
|
act.sa_flags = 0;
|
|
|
|
sigaction( SIGUSR1, &act, NULL );
|
|
|
|
/* initialize signal handler variables */
|
|
|
|
Signal_count = 0;
|
|
Signal_occurred = 0;
|
|
|
|
/*
|
|
* wait on SIGUSR1 for 3 seconds, will timeout
|
|
*/
|
|
|
|
/* initialize the signal set we will wait for to SIGUSR1 */
|
|
|
|
status = sigemptyset( &waitset );
|
|
assert( !status );
|
|
|
|
status = sigaddset( &waitset, SIGUSR1 );
|
|
assert( !status );
|
|
|
|
timeout.tv_sec = 3;
|
|
timeout.tv_nsec = 0;
|
|
|
|
puts( "Init: waiting on any signal for 3 seconds." );
|
|
signo = sigtimedwait( &waitset, &siginfo, &timeout );
|
|
assert( signo == -1 );
|
|
|
|
if ( errno == EAGAIN )
|
|
puts( "Init: correctly timed out waiting for SIGUSR1." );
|
|
else
|
|
printf( "sigtimedwait returned wrong errno - %d\n", errno );
|
|
|
|
Signal_occurred = 0;
|
|
|
|
/*
|
|
* wait on SIGUSR1 for 3 seconds, will timeout because Task_1 sends SIGUSR2
|
|
*/
|
|
|
|
empty_line();
|
|
|
|
/* initialize a mask to block SIGUSR2 */
|
|
|
|
status = sigemptyset( &mask );
|
|
assert( !status );
|
|
|
|
status = sigaddset( &mask, SIGUSR2 );
|
|
assert( !status );
|
|
|
|
printf( "Init: Block SIGUSR2\n" );
|
|
status = sigprocmask( SIG_BLOCK, &mask, NULL );
|
|
assert( !status );
|
|
|
|
/* create a thread */
|
|
|
|
status = pthread_create( &Task_id, NULL, Task_1, NULL );
|
|
assert( !status );
|
|
|
|
/* signal handler is still installed, waitset is still set for SIGUSR1 */
|
|
|
|
timeout.tv_sec = 3;
|
|
timeout.tv_nsec = 0;
|
|
|
|
puts( "Init: waiting on any signal for 3 seconds." );
|
|
signo = sigtimedwait( &waitset, &siginfo, &timeout );
|
|
|
|
/* switch to Task 1 */
|
|
|
|
if ( errno == EAGAIN )
|
|
puts( "Init: correctly timed out waiting for SIGUSR1." );
|
|
else
|
|
printf( "sigtimedwait returned wrong errno - %d\n", errno );
|
|
assert( signo == -1 );
|
|
|
|
/*
|
|
* wait on SIGUSR1 for 3 seconds, Task_2 will send it to us
|
|
*/
|
|
|
|
empty_line();
|
|
|
|
/* create a thread */
|
|
|
|
status = pthread_create( &Task_id, NULL, Task_2, NULL );
|
|
assert( !status );
|
|
|
|
/* signal handler is still installed, waitset is still set for SIGUSR1 */
|
|
|
|
/* wait on SIGUSR1 for 3 seconds, will receive SIGUSR1 from Task_2 */
|
|
|
|
timeout.tv_sec = 3;
|
|
timeout.tv_nsec = 0;
|
|
|
|
/* just so we can check that these were altered */
|
|
|
|
siginfo.si_code = -1;
|
|
siginfo.si_signo = -1;
|
|
siginfo.si_value.sival_int = -1;
|
|
|
|
puts( "Init: waiting on any signal for 3 seconds." );
|
|
signo = sigtimedwait( &waitset, &siginfo, &timeout );
|
|
printf( "Init: received (%d) SIGUSR1=%d\n", siginfo.si_signo, SIGUSR1 );
|
|
assert( signo == SIGUSR1 );
|
|
assert( siginfo.si_signo == SIGUSR1 );
|
|
assert( siginfo.si_code == SI_USER );
|
|
assert( siginfo.si_value.sival_int != -1 ); /* rtems does always set this */
|
|
|
|
/* try out a process signal */
|
|
|
|
empty_line();
|
|
puts( "Init: kill with SIGUSR2." );
|
|
status = kill( getpid(), SIGUSR2 );
|
|
assert( !status );
|
|
|
|
siginfo.si_code = -1;
|
|
siginfo.si_signo = -1;
|
|
siginfo.si_value.sival_int = -1;
|
|
|
|
status = sigemptyset( &waitset );
|
|
assert( !status );
|
|
|
|
status = sigaddset( &waitset, SIGUSR1 );
|
|
assert( !status );
|
|
|
|
status = sigaddset( &waitset, SIGUSR2 );
|
|
assert( !status );
|
|
|
|
puts( "Init: waiting on any signal for 3 seconds." );
|
|
signo = sigtimedwait( &waitset, &siginfo, &timeout );
|
|
printf( "Init: received (%d) SIGUSR2=%d\n", siginfo.si_signo, SIGUSR2 );
|
|
assert( signo == SIGUSR2 );
|
|
assert( siginfo.si_signo == SIGUSR2 );
|
|
assert( siginfo.si_code == SI_USER );
|
|
assert( siginfo.si_value.sival_int != -1 ); /* rtems does always set this */
|
|
|
|
/* exit this thread */
|
|
|
|
puts( "*** END OF POSIX TEST 3 ***" );
|
|
rtems_test_exit( 0 );
|
|
|
|
return NULL; /* just so the compiler thinks we returned something */
|
|
}
|