rpms/procps/devel procps-3.2.8-setlocale.patch, NONE, 1.1 procps.spec, 1.84, 1.85

Daniel Novotny dnovotny at fedoraproject.org
Mon Jan 11 14:27:12 UTC 2010


Author: dnovotny

Update of /cvs/extras/rpms/procps/devel
In directory cvs1.fedora.phx.redhat.com:/tmp/cvs-serv14791

Modified Files:
	procps.spec 
Added Files:
	procps-3.2.8-setlocale.patch 
Log Message:
fix #548711 -  [abrt] crash in procps-3.2.8-3.fc12


procps-3.2.8-setlocale.patch:
 sysinfo.c |   17 +++++++++++------
 1 file changed, 11 insertions(+), 6 deletions(-)

--- NEW FILE procps-3.2.8-setlocale.patch ---
diff -Nur procps-3.2.8-orig/proc/sysinfo.c procps-3.2.8/proc/sysinfo.c
--- procps-3.2.8-orig/proc/sysinfo.c	2008-03-24 05:33:43.000000000 +0100
+++ procps-3.2.8/proc/sysinfo.c	2009-12-18 22:50:52.000000000 +0100
@@ -74,17 +74,19 @@
 /***********************************************************************/
 int uptime(double *restrict uptime_secs, double *restrict idle_secs) {
     double up=0, idle=0;
-    char *restrict savelocale;
+    char *savelocale;
 
     FILE_TO_BUF(UPTIME_FILE,uptime_fd);
-    savelocale = setlocale(LC_NUMERIC, NULL);
+    savelocale = strdup(setlocale(LC_NUMERIC, NULL));
     setlocale(LC_NUMERIC,"C");
     if (sscanf(buf, "%lf %lf", &up, &idle) < 2) {
         setlocale(LC_NUMERIC,savelocale);
+        free(savelocale);
         fputs("bad data in " UPTIME_FILE "\n", stderr);
 	    return 0;
     }
     setlocale(LC_NUMERIC,savelocale);
+    free(savelocale);
     SET_IF_DESIRED(uptime_secs, up);
     SET_IF_DESIRED(idle_secs, idle);
     return up;	/* assume never be zero seconds in practice */
@@ -128,9 +130,9 @@
   double up_1, up_2, seconds;
   unsigned long long jiffies;
   unsigned h;
-  char *restrict savelocale;
+  char *savelocale;
 
-  savelocale = setlocale(LC_NUMERIC, NULL);
+  savelocale = strdup(setlocale(LC_NUMERIC, NULL));
   setlocale(LC_NUMERIC, "C");
   do{
     FILE_TO_BUF(UPTIME_FILE,uptime_fd);  sscanf(buf, "%lf", &up_1);
@@ -141,6 +143,7 @@
     /* uptime(&up_2, NULL); */
   } while((long long)( (up_2-up_1)*1000.0/up_1 )); /* want under 0.1% error */
   setlocale(LC_NUMERIC, savelocale);
+  free(savelocale);
   jiffies = user_j + nice_j + sys_j + other_j;
   seconds = (up_1 + up_2) / 2;
   h = (unsigned)( (double)jiffies/seconds/smp_num_cpus );
@@ -303,16 +306,18 @@
 /***********************************************************************/
 void loadavg(double *restrict av1, double *restrict av5, double *restrict av15) {
     double avg_1=0, avg_5=0, avg_15=0;
-    char *restrict savelocale;
+    char *savelocale;
     
     FILE_TO_BUF(LOADAVG_FILE,loadavg_fd);
-    savelocale = setlocale(LC_NUMERIC, NULL);
+    savelocale = strdup(setlocale(LC_NUMERIC, NULL));
     setlocale(LC_NUMERIC, "C");
     if (sscanf(buf, "%lf %lf %lf", &avg_1, &avg_5, &avg_15) < 3) {
 	fputs("bad data in " LOADAVG_FILE "\n", stderr);
+    free(savelocale);
 	exit(1);
     }
     setlocale(LC_NUMERIC, savelocale);
+    free(savelocale);
     SET_IF_DESIRED(av1,  avg_1);
     SET_IF_DESIRED(av5,  avg_5);
     SET_IF_DESIRED(av15, avg_15);


Index: procps.spec
===================================================================
RCS file: /cvs/extras/rpms/procps/devel/procps.spec,v
retrieving revision 1.84
retrieving revision 1.85
diff -u -p -r1.84 -r1.85
--- procps.spec	16 Nov 2009 14:09:38 -0000	1.84
+++ procps.spec	11 Jan 2010 14:27:12 -0000	1.85
@@ -1,7 +1,7 @@
 Summary: System and process monitoring utilities
 Name: procps
 Version: 3.2.8
-Release: 4%{?dist}
+Release: 5%{?dist}
 License: GPLv2+ and LGPLv2+
 Group: Applications/System
 URL: http://procps.sourceforge.net
@@ -86,6 +86,8 @@ Patch43: procps-3.2.7-free-hlmem.patch
 Patch44: procps-3.2.8-threads.patch
 # enable core file generation (don't trap it)
 Patch45: procps-enable-core.patch
+#548711 -  [abrt] crash in procps-3.2.8-3.fc12
+Patch46: procps-3.2.8-setlocale.patch
 
 BuildRequires: ncurses-devel
 
@@ -152,6 +154,7 @@ working directory of a process or proces
 %patch43 -p1
 %patch44 -p1
 %patch45 -p1
+%patch46 -p1
 
 cp %SOURCE1 .
 
@@ -189,6 +192,9 @@ rm -rf %{buildroot}
 %attr(0644,root,root) %{_mandir}/man5/*
 
 %changelog
+* Mon Jan 11 2010 Daniel Novotny <dnovotny at redhat.com> 3.2.8-5
+- fix #548711 -  [abrt] crash in procps-3.2.8-3.fc12
+
 * Mon Nov 16 2009 Daniel Novotny <dnovotny at redhat.com> 3.2.8-4
 - patch for enabling core file generation in ps (we don't trap the signal anymore)
 



More information about the scm-commits mailing list