2015-09-16 19:31:43 +03:00
/*
2016-02-08 02:28:18 +03:00
* This file is part of timer_create strace test .
*
2016-01-06 12:49:32 +03:00
* Copyright ( c ) 2015 - 2016 Dmitry V . Levin < ldv @ altlinux . org >
2015-09-16 19:31:43 +03:00
* All rights reserved .
*
2018-12-10 03:00:00 +03:00
* SPDX - License - Identifier : GPL - 2.0 - or - later
2015-09-16 19:31:43 +03:00
*/
2016-01-02 16:28:43 +03:00
# include "tests.h"
2016-08-09 17:38:29 +03:00
# include <asm/unistd.h>
2015-09-16 19:31:43 +03:00
# ifdef __NR_timer_create
2016-01-06 12:49:32 +03:00
# include <stdio.h>
# include <signal.h>
# include <time.h>
# include <unistd.h>
2016-01-12 04:13:48 +03:00
# include "sigevent.h"
2016-01-06 12:49:32 +03:00
2015-09-16 19:31:43 +03:00
int
main ( void )
{
2016-02-08 02:28:18 +03:00
syscall ( __NR_timer_create , CLOCK_REALTIME , NULL , NULL ) ;
2016-05-17 20:18:48 +03:00
printf ( " timer_create(CLOCK_REALTIME, NULL, NULL) = -1 %s (%m) \n " ,
errno2name ( ) ) ;
2016-02-08 02:28:18 +03:00
2015-09-16 19:31:43 +03:00
int tid [ 4 ] = { } ;
2016-01-12 04:13:48 +03:00
struct_sigevent sev = {
2016-02-08 02:28:18 +03:00
. sigev_notify = 0xdefaced ,
2015-09-16 19:31:43 +03:00
. sigev_signo = 0xfacefeed ,
2016-11-13 19:14:46 +03:00
. sigev_value . sival_ptr = ( unsigned long ) 0xdeadbeefbadc0dedULL
2015-09-16 19:31:43 +03:00
} ;
2016-02-08 02:28:18 +03:00
syscall ( __NR_timer_create , CLOCK_REALTIME , & sev , NULL ) ;
2016-11-28 22:12:12 +03:00
printf ( " timer_create(CLOCK_REALTIME, {sigev_value={sival_int=%d, "
" sival_ptr=%#lx}, sigev_signo=%u, "
" sigev_notify=%#x /* SIGEV_??? */}, NULL) = -1 %s (%m) \n " ,
2016-02-08 02:28:18 +03:00
sev . sigev_value . sival_int ,
sev . sigev_value . sival_ptr ,
2016-05-17 20:18:48 +03:00
sev . sigev_signo , sev . sigev_notify ,
errno2name ( ) ) ;
2016-02-08 02:28:18 +03:00
sev . sigev_notify = SIGEV_NONE ;
2015-09-16 19:31:43 +03:00
if ( syscall ( __NR_timer_create , CLOCK_REALTIME , & sev , & tid [ 0 ] ) )
2016-01-06 12:49:32 +03:00
perror_msg_and_skip ( " timer_create CLOCK_REALTIME " ) ;
2016-11-28 22:12:12 +03:00
printf ( " timer_create(CLOCK_REALTIME, {sigev_value={sival_int=%d, "
" sival_ptr=%#lx}, sigev_signo=%u, sigev_notify=SIGEV_NONE}, "
" [%d]) = 0 \n " ,
2015-09-16 19:31:43 +03:00
sev . sigev_value . sival_int ,
sev . sigev_value . sival_ptr ,
sev . sigev_signo , tid [ 0 ] ) ;
sev . sigev_notify = SIGEV_SIGNAL ;
sev . sigev_signo = SIGALRM ;
if ( syscall ( __NR_timer_create , CLOCK_MONOTONIC , & sev , & tid [ 1 ] ) )
2016-01-06 12:49:32 +03:00
perror_msg_and_skip ( " timer_create CLOCK_MONOTONIC " ) ;
2016-11-28 22:12:12 +03:00
printf ( " timer_create(CLOCK_MONOTONIC, {sigev_value={sival_int=%d, "
" sival_ptr=%#lx}, sigev_signo=SIGALRM, "
" sigev_notify=SIGEV_SIGNAL}, [%d]) = 0 \n " ,
2015-09-16 19:31:43 +03:00
sev . sigev_value . sival_int ,
sev . sigev_value . sival_ptr , tid [ 1 ] ) ;
sev . sigev_notify = SIGEV_THREAD ;
2016-11-13 19:14:46 +03:00
sev . sigev_un . sigev_thread . function =
( unsigned long ) 0xdeadbeefbadc0dedULL ;
sev . sigev_un . sigev_thread . attribute =
( unsigned long ) 0xcafef00dfacefeedULL ;
2015-09-16 19:31:43 +03:00
if ( syscall ( __NR_timer_create , CLOCK_REALTIME , & sev , & tid [ 2 ] ) )
2016-01-06 12:49:32 +03:00
perror_msg_and_skip ( " timer_create CLOCK_REALTIME " ) ;
2016-11-28 22:12:12 +03:00
printf ( " timer_create(CLOCK_REALTIME, {sigev_value={sival_int=%d, "
" sival_ptr=%#lx}, sigev_signo=SIGALRM, sigev_notify=SIGEV_THREAD "
2016-01-12 04:13:48 +03:00
" , sigev_notify_function=%#lx, sigev_notify_attributes=%#lx} "
2015-09-16 19:31:43 +03:00
" , [%d]) = 0 \n " ,
sev . sigev_value . sival_int ,
sev . sigev_value . sival_ptr ,
2016-01-12 04:13:48 +03:00
sev . sigev_un . sigev_thread . function ,
sev . sigev_un . sigev_thread . attribute ,
2015-09-16 19:31:43 +03:00
tid [ 2 ] ) ;
2016-01-12 04:13:48 +03:00
# ifndef SIGEV_THREAD_ID
# define SIGEV_THREAD_ID 4
# endif
2015-09-16 19:31:43 +03:00
sev . sigev_notify = SIGEV_THREAD_ID ;
2016-01-12 04:13:48 +03:00
sev . sigev_un . tid = getpid ( ) ;
2015-09-16 19:31:43 +03:00
if ( syscall ( __NR_timer_create , CLOCK_MONOTONIC , & sev , & tid [ 3 ] ) )
2016-01-06 12:49:32 +03:00
perror_msg_and_skip ( " timer_create CLOCK_MONOTONIC " ) ;
2016-11-28 22:12:12 +03:00
printf ( " timer_create(CLOCK_MONOTONIC, {sigev_value={sival_int=%d, "
" sival_ptr=%#lx}, sigev_signo=SIGALRM, "
" sigev_notify=SIGEV_THREAD_ID, sigev_notify_thread_id=%d} "
2015-09-16 19:31:43 +03:00
" , [%d]) = 0 \n " ,
sev . sigev_value . sival_int ,
sev . sigev_value . sival_ptr ,
2016-01-12 04:13:48 +03:00
sev . sigev_un . tid ,
2015-09-16 19:31:43 +03:00
tid [ 3 ] ) ;
puts ( " +++ exited with 0 +++ " ) ;
return 0 ;
}
# else
2016-01-06 12:49:32 +03:00
SKIP_MAIN_UNDEFINED ( " __NR_timer_create " )
2015-09-16 19:31:43 +03:00
# endif