2015-12-17 17:56:48 +00:00
/*
* Copyright ( c ) 2015 Dmitry V . Levin < ldv @ altlinux . org >
* All rights reserved .
*
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
* 2. Redistributions in binary form must reproduce the above copyright
* notice , this list of conditions and the following disclaimer in the
* documentation and / or other materials provided with the distribution .
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission .
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ` ` AS IS ' ' AND ANY EXPRESS OR
* IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED .
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT , INDIRECT ,
* INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING , BUT
* NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE ,
* DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY , OR TORT
* ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
*/
2015-08-04 01:52:40 +03:00
# include "defs.h"
2015-09-17 16:10:53 +00: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 16:47:03 +00: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 15:12:42 +00: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 16:47:03 +00:00
print_timespec_t ( t ) ;
2015-08-04 01:52:40 +03:00
break ;
}
}
static void
2015-09-17 15:12:42 +00:00
print_timeval_t ( const timeval_t * t )
2015-08-04 01:52:40 +03:00
{
2015-09-17 16:47:03 +00: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 15:16:11 +00: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 17:44:16 +00: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 15:12:42 +00:00
print_timespec_t_utime ( & t [ 0 ] ) ;
2015-08-04 01:52:40 +03:00
tprints ( " , " ) ;
2015-09-17 15:12:42 +00:00
print_timespec_t_utime ( & t [ 1 ] ) ;
2015-08-04 01:52:40 +03:00
tprints ( " ] " ) ;
}
2015-09-17 16:47:03 +00: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 15:16:11 +00: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 15:12:42 +00:00
print_timeval_t ( & t [ 0 ] ) ;
2015-08-04 01:52:40 +03:00
tprints ( " , " ) ;
2015-09-17 15:12:42 +00:00
print_timeval_t ( & t [ 1 ] ) ;
2015-08-04 01:52:40 +03:00
tprints ( " ] " ) ;
}
2015-09-17 16:10:53 +00: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 18:02:50 +00: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 20:23:31 +00: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 16:10:53 +00: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 20:23:31 +00: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 15:16:11 +00: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 20:23:31 +00: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 18:02:50 +00: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 20:23:31 +00:00
# endif /* ALPHA */