2015-08-04 01:52:40 +03:00
# include "defs.h"
2015-09-17 19:10:53 +03:00
# include DEF_MPERS_TYPE(time_t)
2015-08-04 01:52:40 +03:00
# include DEF_MPERS_TYPE(timespec_t)
# include DEF_MPERS_TYPE(timeval_t)
typedef struct timespec timespec_t ;
typedef struct timeval timeval_t ;
# include MPERS_DEFS
# ifndef UTIME_NOW
# define UTIME_NOW ((1l << 30) - 1l)
# endif
# ifndef UTIME_OMIT
# define UTIME_OMIT ((1l << 30) - 2l)
# endif
2015-09-17 19:47:03 +03:00
static const char time_fmt [ ] = " {%jd, %jd} " ;
static void
print_timespec_t ( const timespec_t * t )
{
tprintf ( time_fmt , ( intmax_t ) t - > tv_sec , ( intmax_t ) t - > tv_nsec ) ;
}
2015-08-04 01:52:40 +03:00
static void
2015-09-17 18:12:42 +03:00
print_timespec_t_utime ( const timespec_t * t )
2015-08-04 01:52:40 +03:00
{
switch ( t - > tv_nsec ) {
case UTIME_NOW :
tprints ( " UTIME_NOW " ) ;
break ;
case UTIME_OMIT :
tprints ( " UTIME_OMIT " ) ;
break ;
default :
2015-09-17 19:47:03 +03:00
print_timespec_t ( t ) ;
2015-08-04 01:52:40 +03:00
break ;
}
}
static void
2015-09-17 18:12:42 +03:00
print_timeval_t ( const timeval_t * t )
2015-08-04 01:52:40 +03:00
{
2015-09-17 19:47:03 +03:00
tprintf ( time_fmt , ( intmax_t ) t - > tv_sec , ( intmax_t ) t - > tv_usec ) ;
2015-08-04 01:52:40 +03:00
}
2015-09-18 18:16:11 +03:00
MPERS_PRINTER_DECL ( void , print_timespec ) ( struct tcb * tcp , const long addr )
{
timespec_t t ;
if ( umove_or_printaddr ( tcp , addr , & t ) )
return ;
print_timespec_t ( & t ) ;
}
2015-09-18 20:44:16 +03:00
MPERS_PRINTER_DECL ( const char * , sprint_timespec ) ( struct tcb * tcp , const long addr )
{
timespec_t t ;
static char buf [ sizeof ( time_fmt ) + 3 * sizeof ( t ) ] ;
if ( ! addr ) {
strcpy ( buf , " NULL " ) ;
} else if ( ! verbose ( tcp ) | | ( exiting ( tcp ) & & syserror ( tcp ) ) | |
umove ( tcp , addr , & t ) ) {
snprintf ( buf , sizeof ( buf ) , " %#lx " , addr ) ;
} else {
snprintf ( buf , sizeof ( buf ) , time_fmt ,
( intmax_t ) t . tv_sec , ( intmax_t ) t . tv_nsec ) ;
}
return buf ;
}
2015-08-04 01:52:40 +03:00
MPERS_PRINTER_DECL ( void , print_timespec_utime_pair ) ( struct tcb * tcp , const long addr )
{
timespec_t t [ 2 ] ;
if ( umove_or_printaddr ( tcp , addr , & t ) )
return ;
tprints ( " [ " ) ;
2015-09-17 18:12:42 +03:00
print_timespec_t_utime ( & t [ 0 ] ) ;
2015-08-04 01:52:40 +03:00
tprints ( " , " ) ;
2015-09-17 18:12:42 +03:00
print_timespec_t_utime ( & t [ 1 ] ) ;
2015-08-04 01:52:40 +03:00
tprints ( " ] " ) ;
}
2015-09-17 19:47:03 +03:00
MPERS_PRINTER_DECL ( void , print_itimerspec ) ( struct tcb * tcp , const long addr )
{
timespec_t t [ 2 ] ;
if ( umove_or_printaddr ( tcp , addr , & t ) )
return ;
tprints ( " {it_interval= " ) ;
print_timespec_t ( & t [ 0 ] ) ;
tprints ( " , it_value= " ) ;
print_timespec_t ( & t [ 1 ] ) ;
tprints ( " } " ) ;
}
2015-09-18 18:16:11 +03:00
MPERS_PRINTER_DECL ( void , print_timeval ) ( struct tcb * tcp , const long addr )
{
timeval_t t ;
if ( umove_or_printaddr ( tcp , addr , & t ) )
return ;
print_timeval_t ( & t ) ;
}
2015-08-04 01:52:40 +03:00
MPERS_PRINTER_DECL ( void , print_timeval_pair ) ( struct tcb * tcp , const long addr )
{
timeval_t t [ 2 ] ;
if ( umove_or_printaddr ( tcp , addr , & t ) )
return ;
tprints ( " [ " ) ;
2015-09-17 18:12:42 +03:00
print_timeval_t ( & t [ 0 ] ) ;
2015-08-04 01:52:40 +03:00
tprints ( " , " ) ;
2015-09-17 18:12:42 +03:00
print_timeval_t ( & t [ 1 ] ) ;
2015-08-04 01:52:40 +03:00
tprints ( " ] " ) ;
}
2015-09-17 19:10:53 +03:00
Convert another parser of struct timeval to new mpers infrastructure
* print_time.c (sprint_timeval): New mpers printer.
[ALPHA] (sprint_timeval32): New function.
* defs.h [ALPHA] (sprint_timeval32): New prototype.
(bitness_t, TIMEVAL_TEXT_BUFSIZE, printtv_bitness, sprinttv): Remove.
* desc.c (decode_select): Replace bitness parameter with two printers.
Use them instead of printtv_bitness and sprinttv.
(sys_oldselect, sys_select): Pass print_timeval and sprint_timeval
to decode_select.
[ALPHA] (sys_osf_select): Pass print_timeval32 and sprint_timeval32
to decode_select.
(pselect6): Pass print_timespec and sprint_timespec to decode_select.
* time.c (UTIME_NOW, UTIME_OMIT, current_time_t_is_compat,
struct timeval32, printtv_bitness, do_sprinttv, sprinttv): Remove.
2015-09-18 21:02:50 +03:00
MPERS_PRINTER_DECL ( const char * , sprint_timeval ) ( struct tcb * tcp , const long addr )
{
timeval_t t ;
static char buf [ sizeof ( time_fmt ) + 3 * sizeof ( t ) ] ;
if ( ! addr ) {
strcpy ( buf , " NULL " ) ;
} else if ( ! verbose ( tcp ) | | ( exiting ( tcp ) & & syserror ( tcp ) ) | |
umove ( tcp , addr , & t ) ) {
snprintf ( buf , sizeof ( buf ) , " %#lx " , addr ) ;
} else {
snprintf ( buf , sizeof ( buf ) , time_fmt ,
( intmax_t ) t . tv_sec , ( intmax_t ) t . tv_usec ) ;
}
return buf ;
}
2015-09-17 23:23:31 +03:00
MPERS_PRINTER_DECL ( void , print_itimerval ) ( struct tcb * tcp , const long addr )
{
timeval_t t [ 2 ] ;
if ( umove_or_printaddr ( tcp , addr , & t ) )
return ;
tprints ( " {it_interval= " ) ;
print_timeval_t ( & t [ 0 ] ) ;
tprints ( " , it_value= " ) ;
print_timeval_t ( & t [ 1 ] ) ;
tprints ( " } " ) ;
}
2015-09-17 19:10:53 +03:00
SYS_FUNC ( time )
{
if ( exiting ( tcp ) ) {
time_t t ;
if ( ! umove_or_printaddr ( tcp , tcp - > u_arg [ 0 ] , & t ) )
tprintf ( " [%jd] " , ( intmax_t ) t ) ;
}
return 0 ;
}
2015-09-17 23:23:31 +03:00
# ifdef ALPHA
typedef struct {
int tv_sec , tv_usec ;
} timeval32_t ;
static void
print_timeval32_t ( const timeval32_t * t )
{
tprintf ( time_fmt , ( intmax_t ) t - > tv_sec , ( intmax_t ) t - > tv_usec ) ;
}
2015-09-18 18:16:11 +03:00
void
print_timeval32 ( struct tcb * tcp , const long addr )
{
timeval32_t t ;
if ( umove_or_printaddr ( tcp , addr , & t ) )
return ;
print_timeval32_t ( & t ) ;
}
void
print_timeval32_pair ( struct tcb * tcp , const long addr )
{
timeval32_t t [ 2 ] ;
if ( umove_or_printaddr ( tcp , addr , & t ) )
return ;
tprints ( " [ " ) ;
print_timeval32_t ( & t [ 0 ] ) ;
tprints ( " , " ) ;
print_timeval32_t ( & t [ 1 ] ) ;
tprints ( " ] " ) ;
}
2015-09-17 23:23:31 +03:00
void
print_itimerval32 ( struct tcb * tcp , const long addr )
{
timeval32_t t [ 2 ] ;
if ( umove_or_printaddr ( tcp , addr , & t ) )
return ;
tprints ( " {it_interval= " ) ;
print_timeval32_t ( & t [ 0 ] ) ;
tprints ( " , it_value= " ) ;
print_timeval32_t ( & t [ 1 ] ) ;
tprints ( " } " ) ;
}
Convert another parser of struct timeval to new mpers infrastructure
* print_time.c (sprint_timeval): New mpers printer.
[ALPHA] (sprint_timeval32): New function.
* defs.h [ALPHA] (sprint_timeval32): New prototype.
(bitness_t, TIMEVAL_TEXT_BUFSIZE, printtv_bitness, sprinttv): Remove.
* desc.c (decode_select): Replace bitness parameter with two printers.
Use them instead of printtv_bitness and sprinttv.
(sys_oldselect, sys_select): Pass print_timeval and sprint_timeval
to decode_select.
[ALPHA] (sys_osf_select): Pass print_timeval32 and sprint_timeval32
to decode_select.
(pselect6): Pass print_timespec and sprint_timespec to decode_select.
* time.c (UTIME_NOW, UTIME_OMIT, current_time_t_is_compat,
struct timeval32, printtv_bitness, do_sprinttv, sprinttv): Remove.
2015-09-18 21:02:50 +03:00
const char *
sprint_timeval32 ( struct tcb * tcp , const long addr )
{
timeval32_t t ;
static char buf [ sizeof ( time_fmt ) + 3 * sizeof ( t ) ] ;
if ( ! addr ) {
strcpy ( buf , " NULL " ) ;
} else if ( ! verbose ( tcp ) | | ( exiting ( tcp ) & & syserror ( tcp ) ) | |
umove ( tcp , addr , & t ) ) {
snprintf ( buf , sizeof ( buf ) , " %#lx " , addr ) ;
} else {
snprintf ( buf , sizeof ( buf ) , time_fmt ,
( intmax_t ) t . tv_sec , ( intmax_t ) t . tv_usec ) ;
}
return buf ;
}
2015-09-17 23:23:31 +03:00
# endif /* ALPHA */