mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-24 13:33:08 +03:00 
			
		
		
		
	This was found when testing the OpenRISC port I am working on. These two tests fail with SIGSEGV: FAIL: misc/tst-ntp_gettime FAIL: misc/tst-ntp_gettimex This was found to be due to the kernel overwriting the stack space allocated by the timex structure. The reason for the overwrite being that the kernel timex has 64-bit fields and user space code only allocates enough stack space for timex with 32-bit fields. On 32-bit systems with TIMESIZE=64 __USE_TIME_BITS64 is not defined. This causes the timex structure to use 32-bit fields with type __syscall_slong_t. This patch adjusts the ifdef condition to allow 32-bit systems with TIMESIZE=64 to use the 64-bit long long timex definition. Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
		
			
				
	
	
		
			142 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Copyright (C) 1995-2021 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 Lesser General Public
 | |
|    License as published by the Free Software Foundation; either
 | |
|    version 2.1 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
 | |
|    Lesser General Public License for more details.
 | |
| 
 | |
|    You should have received a copy of the GNU Lesser General Public
 | |
|    License along with the GNU C Library; if not, see
 | |
|    <https://www.gnu.org/licenses/>.  */
 | |
| 
 | |
| #ifndef	_BITS_TIMEX_H
 | |
| #define	_BITS_TIMEX_H	1
 | |
| 
 | |
| #include <bits/types.h>
 | |
| #include <bits/types/struct_timeval.h>
 | |
| 
 | |
| /* These definitions from linux/timex.h as of 3.18.  */
 | |
| 
 | |
| struct timex
 | |
| {
 | |
| # if defined __USE_TIME_BITS64 || (__TIMESIZE == 64 && __WORDSIZE == 32)
 | |
|   unsigned int modes;          /* mode selector */
 | |
|   int :32;                     /* pad */
 | |
|   long long offset;            /* time offset (usec) */
 | |
|   long long freq;              /* frequency offset (scaled ppm) */
 | |
|   long long maxerror;          /* maximum error (usec) */
 | |
|   long long esterror;          /* estimated error (usec) */
 | |
|   int status;                  /* clock command/status */
 | |
|   int :32;                     /* pad */
 | |
|   long long constant;          /* pll time constant */
 | |
|   long long precision;         /* clock precision (usec) (read only) */
 | |
|   long long tolerance;         /* clock frequency tolerance (ppm) (ro) */
 | |
|   struct timeval time;     /* (read only, except for ADJ_SETOFFSET) */
 | |
|   long long tick;              /* (modified) usecs between clock ticks */
 | |
|   long long ppsfreq;           /* pps frequency (scaled ppm) (ro) */
 | |
|   long long jitter;            /* pps jitter (us) (ro) */
 | |
|   int shift;                   /* interval duration (s) (shift) (ro) */
 | |
|   int :32;                     /* pad */
 | |
|   long long stabil;            /* pps stability (scaled ppm) (ro) */
 | |
|   long long jitcnt;            /* jitter limit exceeded (ro) */
 | |
|   long long calcnt;            /* calibration intervals (ro) */
 | |
|   long long errcnt;            /* calibration errors (ro) */
 | |
|   long long stbcnt;            /* stability limit exceeded (ro) */
 | |
| 
 | |
|   int tai;                     /* TAI offset (ro) */
 | |
| 
 | |
|   int  :32; int  :32; int  :32; int  :32;
 | |
|   int  :32; int  :32; int  :32; int  :32;
 | |
|   int  :32; int  :32; int  :32;
 | |
| # else
 | |
|   unsigned int modes;		/* mode selector */
 | |
|   __syscall_slong_t offset;	/* time offset (usec) */
 | |
|   __syscall_slong_t freq;	/* frequency offset (scaled ppm) */
 | |
|   __syscall_slong_t maxerror;	/* maximum error (usec) */
 | |
|   __syscall_slong_t esterror;	/* estimated error (usec) */
 | |
|   int status;			/* clock command/status */
 | |
|   __syscall_slong_t constant;	/* pll time constant */
 | |
|   __syscall_slong_t precision;	/* clock precision (usec) (ro) */
 | |
|   __syscall_slong_t tolerance;	/* clock frequency tolerance (ppm) (ro) */
 | |
|   struct timeval time;		/* (read only, except for ADJ_SETOFFSET) */
 | |
|   __syscall_slong_t tick;	/* (modified) usecs between clock ticks */
 | |
|   __syscall_slong_t ppsfreq;	/* pps frequency (scaled ppm) (ro) */
 | |
|   __syscall_slong_t jitter;	/* pps jitter (us) (ro) */
 | |
|   int shift;			/* interval duration (s) (shift) (ro) */
 | |
|   __syscall_slong_t stabil;	/* pps stability (scaled ppm) (ro) */
 | |
|   __syscall_slong_t jitcnt;	/* jitter limit exceeded (ro) */
 | |
|   __syscall_slong_t calcnt;	/* calibration intervals (ro) */
 | |
|   __syscall_slong_t errcnt;	/* calibration errors (ro) */
 | |
|   __syscall_slong_t stbcnt;	/* stability limit exceeded (ro) */
 | |
| 
 | |
|   int tai;			/* TAI offset (ro) */
 | |
| 
 | |
|   /* ??? */
 | |
|   int  :32; int  :32; int  :32; int  :32;
 | |
|   int  :32; int  :32; int  :32; int  :32;
 | |
|   int  :32; int  :32; int  :32;
 | |
| # endif
 | |
| };
 | |
| 
 | |
| /* Mode codes (timex.mode) */
 | |
| #define ADJ_OFFSET		0x0001	/* time offset */
 | |
| #define ADJ_FREQUENCY		0x0002	/* frequency offset */
 | |
| #define ADJ_MAXERROR		0x0004	/* maximum time error */
 | |
| #define ADJ_ESTERROR		0x0008	/* estimated time error */
 | |
| #define ADJ_STATUS		0x0010	/* clock status */
 | |
| #define ADJ_TIMECONST		0x0020	/* pll time constant */
 | |
| #define ADJ_TAI			0x0080	/* set TAI offset */
 | |
| #define ADJ_SETOFFSET		0x0100	/* add 'time' to current time */
 | |
| #define ADJ_MICRO		0x1000	/* select microsecond resolution */
 | |
| #define ADJ_NANO		0x2000	/* select nanosecond resolution */
 | |
| #define ADJ_TICK		0x4000	/* tick value */
 | |
| #define ADJ_OFFSET_SINGLESHOT	0x8001	/* old-fashioned adjtime */
 | |
| #define ADJ_OFFSET_SS_READ	0xa001	/* read-only adjtime */
 | |
| 
 | |
| /* xntp 3.4 compatibility names */
 | |
| #define MOD_OFFSET	ADJ_OFFSET
 | |
| #define MOD_FREQUENCY	ADJ_FREQUENCY
 | |
| #define MOD_MAXERROR	ADJ_MAXERROR
 | |
| #define MOD_ESTERROR	ADJ_ESTERROR
 | |
| #define MOD_STATUS	ADJ_STATUS
 | |
| #define MOD_TIMECONST	ADJ_TIMECONST
 | |
| #define MOD_CLKB	ADJ_TICK
 | |
| #define MOD_CLKA	ADJ_OFFSET_SINGLESHOT /* 0x8000 in original */
 | |
| #define MOD_TAI		ADJ_TAI
 | |
| #define MOD_MICRO	ADJ_MICRO
 | |
| #define MOD_NANO	ADJ_NANO
 | |
| 
 | |
| 
 | |
| /* Status codes (timex.status) */
 | |
| #define STA_PLL		0x0001	/* enable PLL updates (rw) */
 | |
| #define STA_PPSFREQ	0x0002	/* enable PPS freq discipline (rw) */
 | |
| #define STA_PPSTIME	0x0004	/* enable PPS time discipline (rw) */
 | |
| #define STA_FLL		0x0008	/* select frequency-lock mode (rw) */
 | |
| 
 | |
| #define STA_INS		0x0010	/* insert leap (rw) */
 | |
| #define STA_DEL		0x0020	/* delete leap (rw) */
 | |
| #define STA_UNSYNC	0x0040	/* clock unsynchronized (rw) */
 | |
| #define STA_FREQHOLD	0x0080	/* hold frequency (rw) */
 | |
| 
 | |
| #define STA_PPSSIGNAL	0x0100	/* PPS signal present (ro) */
 | |
| #define STA_PPSJITTER	0x0200	/* PPS signal jitter exceeded (ro) */
 | |
| #define STA_PPSWANDER	0x0400	/* PPS signal wander exceeded (ro) */
 | |
| #define STA_PPSERROR	0x0800	/* PPS signal calibration error (ro) */
 | |
| 
 | |
| #define STA_CLOCKERR	0x1000	/* clock hardware fault (ro) */
 | |
| #define STA_NANO	0x2000	/* resolution (0 = us, 1 = ns) (ro) */
 | |
| #define STA_MODE	0x4000	/* mode (0 = PLL, 1 = FLL) (ro) */
 | |
| #define STA_CLK		0x8000	/* clock source (0 = A, 1 = B) (ro) */
 | |
| 
 | |
| /* Read-only bits */
 | |
| #define STA_RONLY (STA_PPSSIGNAL | STA_PPSJITTER | STA_PPSWANDER \
 | |
|     | STA_PPSERROR | STA_CLOCKERR | STA_NANO | STA_MODE | STA_CLK)
 | |
| 
 | |
| #endif /* bits/timex.h */
 |