mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-03 08:11:08 +00:00
* resolv/resolv.h: Include <sys/types.h> for u_long even in
the [__need_res_state] case. Reported by Bruno Haible <bruno@clisp.org>.
This commit is contained in:
parent
4f58b7c6f7
commit
64ca3f329b
@ -1,3 +1,9 @@
|
|||||||
|
2002-09-08 Roland McGrath <roland@redhat.com>
|
||||||
|
|
||||||
|
* resolv/resolv.h: Include <sys/types.h> for u_long even in
|
||||||
|
the [__need_res_state] case.
|
||||||
|
Reported by Bruno Haible <bruno@clisp.org>.
|
||||||
|
|
||||||
2002-09-04 Bruno Haible <bruno@clisp.org>
|
2002-09-04 Bruno Haible <bruno@clisp.org>
|
||||||
|
|
||||||
* sysdeps/generic/bits/ustat.h: Comment fix.
|
* sysdeps/generic/bits/ustat.h: Comment fix.
|
||||||
|
@ -1,3 +1,10 @@
|
|||||||
|
2002-09-04 Bruno Haible <bruno@clisp.org>
|
||||||
|
|
||||||
|
* pthread.c: Include <sys/time.h>.
|
||||||
|
(is_smp_system): Move to sysdeps/unix/sysv/linux/smp.h.
|
||||||
|
* sysdeps/unix/sysv/linux/smp.h: New file, extracted from pthread.c.
|
||||||
|
* Makefile (distribute): Add smp.h to the list.
|
||||||
|
|
||||||
2002-09-04 Bruno Haible <bruno@clisp.org>
|
2002-09-04 Bruno Haible <bruno@clisp.org>
|
||||||
|
|
||||||
* sysdeps/alpha/pt-machine.h: Choose different include file location
|
* sysdeps/alpha/pt-machine.h: Choose different include file location
|
||||||
|
@ -25,7 +25,7 @@ linuxthreads-version := $(shell sed -n 's/^.*$(subdir)-\([0-9.]*\).*$$/\1/p' \
|
|||||||
Banner)
|
Banner)
|
||||||
|
|
||||||
headers := pthread.h semaphore.h
|
headers := pthread.h semaphore.h
|
||||||
distribute := internals.h queue.h restart.h spinlock.h tst-signal.sh
|
distribute := internals.h queue.h restart.h spinlock.h smp.h tst-signal.sh
|
||||||
|
|
||||||
routines := weaks no-tsd
|
routines := weaks no-tsd
|
||||||
|
|
||||||
|
@ -24,12 +24,13 @@
|
|||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
#include <sys/resource.h>
|
#include <sys/resource.h>
|
||||||
#include <sys/sysctl.h>
|
#include <sys/time.h>
|
||||||
#include <shlib-compat.h>
|
#include <shlib-compat.h>
|
||||||
#include "pthread.h"
|
#include "pthread.h"
|
||||||
#include "internals.h"
|
#include "internals.h"
|
||||||
#include "spinlock.h"
|
#include "spinlock.h"
|
||||||
#include "restart.h"
|
#include "restart.h"
|
||||||
|
#include "smp.h"
|
||||||
#include <ldsodefs.h>
|
#include <ldsodefs.h>
|
||||||
#include <tls.h>
|
#include <tls.h>
|
||||||
#include <locale.h> /* for __uselocale */
|
#include <locale.h> /* for __uselocale */
|
||||||
@ -360,38 +361,6 @@ __libc_allocate_rtsig (int high)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/* The function we use to get the kernel revision. */
|
|
||||||
extern int __sysctl (int *name, int nlen, void *oldval, size_t *oldlenp,
|
|
||||||
void *newval, size_t newlen);
|
|
||||||
|
|
||||||
/* Test whether the machine has more than one processor. This is not the
|
|
||||||
best test but good enough. More complicated tests would require `malloc'
|
|
||||||
which is not available at that time. */
|
|
||||||
static int
|
|
||||||
is_smp_system (void)
|
|
||||||
{
|
|
||||||
static const int sysctl_args[] = { CTL_KERN, KERN_VERSION };
|
|
||||||
char buf[512];
|
|
||||||
size_t reslen = sizeof (buf);
|
|
||||||
|
|
||||||
/* Try reading the number using `sysctl' first. */
|
|
||||||
if (__sysctl ((int *) sysctl_args,
|
|
||||||
sizeof (sysctl_args) / sizeof (sysctl_args[0]),
|
|
||||||
buf, &reslen, NULL, 0) < 0)
|
|
||||||
{
|
|
||||||
/* This was not successful. Now try reading the /proc filesystem. */
|
|
||||||
int fd = __open ("/proc/sys/kernel/version", O_RDONLY);
|
|
||||||
if (__builtin_expect (fd, 0) == -1
|
|
||||||
|| (reslen = __read (fd, buf, sizeof (buf))) <= 0)
|
|
||||||
/* This also didn't work. We give up and say it's a UP machine. */
|
|
||||||
buf[0] = '\0';
|
|
||||||
|
|
||||||
__close (fd);
|
|
||||||
}
|
|
||||||
|
|
||||||
return strstr (buf, "SMP") != NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Initialize the pthread library.
|
/* Initialize the pthread library.
|
||||||
Initialization is split in two functions:
|
Initialization is split in two functions:
|
||||||
|
48
linuxthreads/sysdeps/unix/sysv/linux/smp.h
Normal file
48
linuxthreads/sysdeps/unix/sysv/linux/smp.h
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
/* Determine whether the host has multiple processors. Linux version.
|
||||||
|
Copyright (C) 1996, 2002 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., 59 Temple Place - Suite 330,
|
||||||
|
Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
#include <sys/sysctl.h>
|
||||||
|
|
||||||
|
/* Test whether the machine has more than one processor. This is not the
|
||||||
|
best test but good enough. More complicated tests would require `malloc'
|
||||||
|
which is not available at that time. */
|
||||||
|
static inline int
|
||||||
|
is_smp_system (void)
|
||||||
|
{
|
||||||
|
static const int sysctl_args[] = { CTL_KERN, KERN_VERSION };
|
||||||
|
char buf[512];
|
||||||
|
size_t reslen = sizeof (buf);
|
||||||
|
|
||||||
|
/* Try reading the number using `sysctl' first. */
|
||||||
|
if (__sysctl ((int *) sysctl_args,
|
||||||
|
sizeof (sysctl_args) / sizeof (sysctl_args[0]),
|
||||||
|
buf, &reslen, NULL, 0) < 0)
|
||||||
|
{
|
||||||
|
/* This was not successful. Now try reading the /proc filesystem. */
|
||||||
|
int fd = __open ("/proc/sys/kernel/version", O_RDONLY);
|
||||||
|
if (__builtin_expect (fd, 0) == -1
|
||||||
|
|| (reslen = __read (fd, buf, sizeof (buf))) <= 0)
|
||||||
|
/* This also didn't work. We give up and say it's a UP machine. */
|
||||||
|
buf[0] = '\0';
|
||||||
|
|
||||||
|
__close (fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
return strstr (buf, "SMP") != NULL;
|
||||||
|
}
|
@ -50,22 +50,21 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _RESOLV_H_
|
#ifndef _RESOLV_H_
|
||||||
|
|
||||||
|
/* These headers are needed for types used in the `struct res_state'
|
||||||
|
declaration. */
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <netinet/in.h>
|
||||||
|
|
||||||
#ifndef __need_res_state
|
#ifndef __need_res_state
|
||||||
# define _RESOLV_H_
|
# define _RESOLV_H_
|
||||||
|
|
||||||
# include <sys/param.h>
|
# include <sys/param.h>
|
||||||
# if (!defined(BSD)) || (BSD < 199306)
|
|
||||||
# include <sys/bitypes.h>
|
|
||||||
# else
|
|
||||||
# include <sys/types.h>
|
|
||||||
# endif
|
|
||||||
# include <sys/cdefs.h>
|
# include <sys/cdefs.h>
|
||||||
# include <stdio.h>
|
# include <stdio.h>
|
||||||
# include <arpa/nameser.h>
|
# include <arpa/nameser.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <netinet/in.h>
|
|
||||||
|
|
||||||
#ifndef __res_state_defined
|
#ifndef __res_state_defined
|
||||||
# define __res_state_defined
|
# define __res_state_defined
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user