Name
rtime — get time from a remote machine
Synopsis
#include <rpc/des_crypt.h>
int
rtime( |
struct sockaddr_in
* |
addrp, |
| |
struct rpc_timeval
* |
timep, |
| |
struct rpc_timeval
* |
timeout); |
DESCRIPTION
This function uses the Time Server Protocol as described
in RFC 868 to obtain the time from a remote machine.
The Time Server Protocol gives the time in seconds since
midnight 1900-01-01, and this function subtracts the
appropriate constant in order to convert the result to
seconds since midnight 1970-01-01, the Unix epoch.
When timeout is
non-NULL, the udp/time socket (port 37) is used. Otherwise,
the tcp/time socket (port 37) is used.
RETURN VALUE
On success, 0 is returned, and the obtained 32-bit time
value is stored in timep->tv_sec. In case of
error −1 is returned, and errno is set appropriately.
ERRORS
All errors for underlying functions (sendto(2), poll(2), recvfrom(2), connect(2), read(2)) can occur.
Moreover:
- EIO
-
The number of returned bytes is not 4.
- ETIMEDOUT
-
The waiting time as defined in timeout has
expired.
NOTES
Only IPV4 is supported.
Some in.timed
versions only support TCP. Try the above example program with
use_tcp set to
1.
Libc5 uses the prototype
int rtime(struct sockaddr_in *, struct timeval *, struct
timeval *);
and requires <sys/time.h> instead of
<rpc/auth_des.h>.
BUGS
rtime() in glibc <= 2.2.5
does not work properly on 64bit machines.
EXAMPLE
This example requires that port 37 is up and open. You may
check that the time entry within /etc/inetd.conf is not commented out.
The program connects to a computer called 'linux'. Using
'localhost' does not work. The result is the localtime of the
computer 'linux'.
SEE ALSO
netdate(1), ntpdate(1), rdate(1), inetd(8)
Copyright 2003 walter harms (walter.harms@informatik.uni-oldenburg.de)
Distributed under GPL
Modified 2003-04-04 Walter Harms
<walter.harms@informatik.uni-oldenburg.de>
Slightly polished, aeb, 2003-04-06
|