patches/glibc/ports-2.10.1/500-alpha-add-getsystats-support.patch
author "Yann E. MORIN" <yann.morin.1998@free.fr>
Tue Oct 16 20:57:44 2012 +0200 (2012-10-16)
changeset 3079 37831a33e07e
permissions -rw-r--r--
kernel/linux: fix using custom location

Currently, extract and patch are skipped as thus:
- using a custom directory of pre-installed headers
- a correctly named directory already exists

Otherwise, extract and patch are done.

The current second condition is wrong, because it allows the following
sequence to happen:
- a non-custom kernel is used
- a previous build only partially extracted the non-custom sources
- that p[revious build broke during extraction (eg. incomplete tarball...)
- a subsequent build will find a properly named directory, and will
thus skip extract and patch, which is wrong

Fix that by following the conditions in this table:

Type | Extract | Patch
----------------------+---------+-------
Pre-installed headers | N | N
custom directory | N | N
custom tarball | Y | N
mainstream tarball | Y | Y

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
Cc: David Holsgrove <david.holsgrove@xilinx.com>
yann@1625
     1
2009-05-16  Aurelien Jarno  <aurelien@aurel32.net>
yann@1625
     2
yann@1625
     3
        * sysdeps/unix/sysv/linux/alpha/getsysstats.c (GET_NPROCS_PARSER):
yann@1625
     4
        Change parameters and use next_line.
yann@1625
     5
yann@1625
     6
 ports/sysdeps/unix/sysv/linux/alpha/getsysstats.c |    5 +++--
yann@1625
     7
 1 file changed, 3 insertions(+), 2 deletions(-)
yann@1625
     8
yann@1625
     9
diff -durN glibc-2.10.1.orig/glibc-ports-2.10.1/sysdeps/unix/sysv/linux/alpha/getsysstats.c glibc-2.10.1/glibc-ports-2.10.1/sysdeps/unix/sysv/linux/alpha/getsysstats.c
yann@1625
    10
--- glibc-2.10.1.orig/glibc-ports-2.10.1/sysdeps/unix/sysv/linux/alpha/getsysstats.c	2009-05-16 10:36:20.000000000 +0200
yann@1625
    11
+++ glibc-2.10.1/glibc-ports-2.10.1/sysdeps/unix/sysv/linux/alpha/getsysstats.c	2009-11-13 00:51:07.000000000 +0100
yann@1625
    12
@@ -20,15 +20,16 @@
yann@1625
    13
 
yann@1625
    14
 
yann@1625
    15
 /* We need to define a special parser for /proc/cpuinfo.  */
yann@1625
    16
-#define GET_NPROCS_PARSER(FP, BUFFER, RESULT)				   \
yann@1625
    17
+#define GET_NPROCS_PARSER(FD, BUFFER, CP, RE, BUFFER_END, RESULT)	   \
yann@1625
    18
   do									   \
yann@1625
    19
     {									   \
yann@1625
    20
       /* Find the line that contains the information about the number of   \
yann@1625
    21
 	 active cpus.  We don't have to fear extremely long lines since	   \
yann@1625
    22
 	 the kernel will not generate them.  8192 bytes are really enough. \
yann@1625
    23
 	 If there is no "CPUs ..." line then we are on a UP system.  */	   \
yann@1625
    24
+      char *l;								   \
yann@1625
    25
       (RESULT) = 1;							   \
yann@1625
    26
-      while (fgets_unlocked (BUFFER, sizeof (BUFFER), FP) != NULL)	   \
yann@1625
    27
+      while ((l = next_line (FD, BUFFER, &CP, &RE, BUFFER_END)) != NULL)  \
yann@1625
    28
 	if ((sscanf (BUFFER, "cpus active : %d", &(RESULT)) == 1)	   \
yann@1625
    29
 	    || (sscanf (BUFFER, "CPUs probed %*d active %d",		   \
yann@1625
    30
 			&(RESULT)) == 1))  				   \
yann@1625
    31
diff -durN glibc-2.10.1.orig/ports/sysdeps/unix/sysv/linux/alpha/getsysstats.c glibc-2.10.1/ports/sysdeps/unix/sysv/linux/alpha/getsysstats.c