mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-11-03 20:53:13 +03:00 
			
		
		
		
	* sysdeps/unix/sysv/linux/i386/Makefile: New file. Wed Apr 24 17:35:30 Ulrich Drepper <drepper@cygnus.com> * inet/netinet/in.h, socket/sys/socket.h: Move to sysdeps/generic/netinet/in.h, sysdeps/generic/sys/socket.h. * netinet/in.h, sys/socket.h: Remove file. * misc/Makefile (routines): Add fdatasync. * posix/Makefile (headers): Add sched.h. (routines): Add nanosleep, sched_setp, sched_getp, sched_sets, sched_gets, sched_yield, sched_primax, sched_primin, sched_rr_gi. * posix/getconf.c (vars): Add entries for _POSIX_REALTIME_SIGNALS, _POSIX_PRIORITY_SCHEDULING, _POSIX_TIMERS, _POSIX_ASYNCHRONOUS_IO, _POSIX_PRIORITIZED_IO, _POSIX_SYNCHRONIZED_IO, _POSIX_FSYNC, _POSIX_MAPPED_FILES, _POSIX_MEMLOCK, _POSIX_MEMLOCK_RANGE, _POSIX_MEMORY_PROTECTION, _POSIX_MESSAGE_PASSING, _POSIX_SEMAPHORES, _POSIX_SHARED_MEMORY_OBJECTS. * posix/sched.h: New file. Header for POSIX scheduling interface. * posix/unistd.h: Describe options from POSIX.4. Add declaration of fdatasync. * sysdeps/generic/confname.h: Add definition for _SC_REALTIME_SIGNALS, _SC_PRIORITY_SCHEDULING, _SC_TIMERS, _SC_ASYNCHRONOUS_IO, _SC_PRIORITIZED_IO, _SC_SYNCHRONIZED_IO, _SC_FSYNC, _SC_MAPPED_FILES, _SC_MEMLOCK, _SC_MEMLOCK_RANGE, _SC_MEMORY_PROTECTION, _SC_MESSAGE_PASSING, _SC_SEMAPHORES, _SC_SHARED_MEMORY_OBJECTS. * sysdeps/generic/fdatasync.c: New file. Default implementation simply uses fsync. * sysdeps/generic/netinit/in.h: Moved to here from inet/netinet/in.h. * sysdeps/generic/schedbits.h: New file. System dependent defintion for POSIX.4 scheduling interface. * sysdeps/generic/sys/socket.h: Moved to here from socket/sys/socket.h. * sysdeps/stub/nanosleep.c, sysdeps/stub/sched_getp.c, sysdeps/stub/sched_gets.c, sysdeps/stub/sched_primax.c, sysdeps/stub/sched_primin.c, sysdeps/stub/sched_rr_gi.c, sysdeps/stub/sched_setp.c, sysdeps/stub/sched_sets.c, sysdeps/stub/sched_yield.c: New file: Stub implementation for systems missing these POSIX.4 system calls. * sysdeps/unix/sysv/linux/gnu/types.h, sysdeps/unix/sysv/linux/ioctls.h: Use kernel header for data type definitions. * sysdeps/unix/sysv/linux/netinet/in.h: New file. Linux specific version. * sysdeps/unix/sysv/linux/posix_opt.h: New file. Define POSIX options applicable for Linux. * sysdeps/unix/sysv/linux/syscalls.list: Add definitions for fdatasync, nanosleep, sched_setparam, sched_getparam, sched_setscheduler, sched_getscheduler, sched_yield, sched_get_priority_max, sched_get_priority_min, and sched_rr_get_interval. * sysdeps/unix/sysv/linux/sysconf.c: Add handling of POSIX.4 options. * sysdeps/unix/sysv/linux/termbits.h: Use kernel headers. * time/sys/time.h: Remove definition of `struct timespec'. * time/time.h (struct timespec): Move definition to here. variable, LUCKY, to use instead of setting D to -1 (which fouls
		
			
				
	
	
		
			159 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Copyright (C) 1991, 92, 93, 94, 96 Free Software Foundation, Inc.
 | 
						|
This file is part of the GNU C Library.
 | 
						|
 | 
						|
The GNU C Library is free software; you can redistribute it and/or
 | 
						|
modify it under the terms of the GNU Library General Public License as
 | 
						|
published by the Free Software Foundation; either version 2 of the
 | 
						|
License, or (at your option) any later version.
 | 
						|
 | 
						|
The GNU C Library is distributed in the hope that it will be useful,
 | 
						|
but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | 
						|
Library General Public License for more details.
 | 
						|
 | 
						|
You should have received a copy of the GNU Library General Public
 | 
						|
License along with the GNU C Library; see the file COPYING.LIB.  If
 | 
						|
not, write to the Free Software Foundation, Inc., 675 Mass Ave,
 | 
						|
Cambridge, MA 02139, USA.  */
 | 
						|
 | 
						|
#ifndef _SYS_TIME_H
 | 
						|
 | 
						|
#define _SYS_TIME_H	1
 | 
						|
#include <features.h>
 | 
						|
 | 
						|
#include <time.h>
 | 
						|
 | 
						|
__BEGIN_DECLS
 | 
						|
 | 
						|
/* A time value that is accurate to the nearest
 | 
						|
   microsecond but also has a range of years.  */
 | 
						|
struct timeval
 | 
						|
  {
 | 
						|
    int tv_sec;			/* Seconds.  */
 | 
						|
    int tv_usec;		/* Microseconds.  */
 | 
						|
  };
 | 
						|
 | 
						|
/* Macros for converting between `struct timeval' and `struct timespec'.  */
 | 
						|
#define TIMEVAL_TO_TIMESPEC(tv, ts) {                                   \
 | 
						|
        (ts)->ts_sec = (tv)->tv_sec;                                    \
 | 
						|
        (ts)->ts_nsec = (tv)->tv_usec * 1000;                           \
 | 
						|
}
 | 
						|
#define TIMESPEC_TO_TIMEVAL(tv, ts) {                                   \
 | 
						|
        (tv)->tv_sec = (ts)->ts_sec;                                    \
 | 
						|
        (tv)->tv_usec = (ts)->ts_nsec / 1000;                           \
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
/* Structure crudely representing a timezone.
 | 
						|
   This is obsolete and should never be used.  */
 | 
						|
struct timezone
 | 
						|
  {
 | 
						|
    int tz_minuteswest;		/* Minutes west of GMT.  */
 | 
						|
    int tz_dsttime;		/* Nonzero if DST is ever in effect.  */
 | 
						|
  };
 | 
						|
 | 
						|
/* Get the current time of day and timezone information,
 | 
						|
   putting it into *TV and *TZ.  If TZ is NULL, *TZ is not filled.
 | 
						|
   Returns 0 on success, -1 on errors.
 | 
						|
   NOTE: This form of timezone information is obsolete.
 | 
						|
   Use the functions and variables declared in <time.h> instead.  */
 | 
						|
extern int __gettimeofday __P ((struct timeval *__tv,
 | 
						|
				struct timezone *__tz));
 | 
						|
extern int gettimeofday __P ((struct timeval *__tv,
 | 
						|
			      struct timezone *__tz));
 | 
						|
 | 
						|
/* Set the current time of day and timezone information.
 | 
						|
   This call is restricted to the super-user.  */
 | 
						|
extern int __settimeofday __P ((__const struct timeval *__tv,
 | 
						|
				__const struct timezone *__tz));
 | 
						|
extern int settimeofday __P ((__const struct timeval *__tv,
 | 
						|
			      __const struct timezone *__tz));
 | 
						|
 | 
						|
/* Adjust the current time of day by the amount in DELTA.
 | 
						|
   If OLDDELTA is not NULL, it is filled in with the amount
 | 
						|
   of time adjustment remaining to be done from the last `adjtime' call.
 | 
						|
   This call is restricted to the super-user.  */
 | 
						|
extern int __adjtime __P ((__const struct timeval *__delta,
 | 
						|
			   struct timeval *__olddelta));
 | 
						|
extern int adjtime __P ((__const struct timeval *__delta,
 | 
						|
			 struct timeval *__olddelta));
 | 
						|
 | 
						|
 | 
						|
/* Values for the first argument to `getitimer' and `setitimer'.  */
 | 
						|
enum __itimer_which
 | 
						|
  {
 | 
						|
    /* Timers run in real time.  */
 | 
						|
    ITIMER_REAL = 0,
 | 
						|
    /* Timers run only when the process is executing.  */
 | 
						|
    ITIMER_VIRTUAL = 1,
 | 
						|
    /* Timers run when the process is executing and when
 | 
						|
       the system is executing on behalf of the process.  */
 | 
						|
    ITIMER_PROF = 2
 | 
						|
  };
 | 
						|
 | 
						|
/* Type of the second argument to `getitimer' and
 | 
						|
   the second and third arguments `setitimer'.  */
 | 
						|
struct itimerval
 | 
						|
  {
 | 
						|
    /* Value to put into `it_value' when the timer expires.  */
 | 
						|
    struct timeval it_interval;
 | 
						|
    /* Time to the next timer expiration.  */
 | 
						|
    struct timeval it_value;
 | 
						|
  };
 | 
						|
 | 
						|
/* Set *VALUE to the current setting of timer WHICH.
 | 
						|
   Return 0 on success, -1 on errors.  */
 | 
						|
extern int __getitimer __P ((enum __itimer_which __which,
 | 
						|
			     struct itimerval *__value));
 | 
						|
extern int getitimer __P ((enum __itimer_which __which,
 | 
						|
			   struct itimerval *__value));
 | 
						|
 | 
						|
/* Set the timer WHICH to *NEW.  If OLD is not NULL,
 | 
						|
   set *OLD to the old value of timer WHICH.
 | 
						|
   Returns 0 on success, -1 on errors.  */
 | 
						|
extern int __setitimer __P ((enum __itimer_which __which,
 | 
						|
			     struct itimerval *__new,
 | 
						|
			     struct itimerval *__old));
 | 
						|
extern int setitimer __P ((enum __itimer_which __which,
 | 
						|
			   struct itimerval *__new,
 | 
						|
			   struct itimerval *__old));
 | 
						|
 | 
						|
/* Change the access time of FILE to TVP[0] and
 | 
						|
   the modification time of FILE to TVP[1].  */
 | 
						|
extern int __utimes __P ((__const char *__file, struct timeval __tvp[2]));
 | 
						|
extern int utimes __P ((__const char *__file, struct timeval __tvp[2]));
 | 
						|
 | 
						|
 | 
						|
/* Convenience macros for operations on timevals.
 | 
						|
   NOTE: `timercmp' does not work for >= or <=.  */
 | 
						|
#define	timerisset(tvp)		((tvp)->tv_sec || (tvp)->tv_usec)
 | 
						|
#define	timerclear(tvp)		((tvp)->tv_sec = (tvp)->tv_usec = 0)
 | 
						|
#define	timercmp(a, b, CMP) 						      \
 | 
						|
  (((a)->tv_sec == (b)->tv_sec) ? 					      \
 | 
						|
   ((a)->tv_usec CMP (b)->tv_usec) : 					      \
 | 
						|
   ((a)->tv_sec CMP (b)->tv_sec))
 | 
						|
#define	timeradd(a, b, result)						      \
 | 
						|
  do {									      \
 | 
						|
    (result)->tv_sec = (a)->tv_sec + (b)->tv_sec;			      \
 | 
						|
    (result)->tv_usec = (a)->tv_usec + (b)->tv_usec;			      \
 | 
						|
    if ((result)->tv_usec >= 1000000)					      \
 | 
						|
      {									      \
 | 
						|
	++(result)->tv_sec;						      \
 | 
						|
	(result)->tv_usec -= 1000000;					      \
 | 
						|
      }									      \
 | 
						|
  } while (0)
 | 
						|
#define	timersub(a, b, result)						      \
 | 
						|
  do {									      \
 | 
						|
    (result)->tv_sec = (a)->tv_sec - (b)->tv_sec;			      \
 | 
						|
    (result)->tv_usec = (a)->tv_usec - (b)->tv_usec;			      \
 | 
						|
    if ((result)->tv_usec < 0) {					      \
 | 
						|
      --(result)->tv_sec;						      \
 | 
						|
      (result)->tv_usec += 1000000;					      \
 | 
						|
    }									      \
 | 
						|
  } while (0)
 | 
						|
 | 
						|
 | 
						|
__END_DECLS
 | 
						|
 | 
						|
#endif /* sys/time.h */
 |