From b245bdfc672e8e9232e16205999f7e71ac9208b3 Mon Sep 17 00:00:00 2001 From: "David S. Miller" Date: Tue, 20 Nov 2012 17:40:28 +0000 Subject: [PATCH] Fix 'info os' crashes on sparc. * common/linux-osdata.c (get_number_of_cpu_cores): Delete. (linux_xfer_osdata_processes): Fetch _SC_NPROCESSORS_ONLN via sysconf. (get_cores_used_by_process): Update comment. --- gdb/ChangeLog | 7 +++++++ gdb/common/linux-osdata.c | 27 +++------------------------ 2 files changed, 10 insertions(+), 24 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 9be4fea..e807ab8 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,10 @@ +2012-11-20 David S. Miller + + * common/linux-osdata.c (get_number_of_cpu_cores): Delete. + (linux_xfer_osdata_processes): Fetch _SC_NPROCESSORS_ONLN via + sysconf. + (get_cores_used_by_process): Update comment. + 2012-11-20 Yao Qi * objfiles.c (init_entry_point_info): Remove trailing spaces. diff --git a/gdb/common/linux-osdata.c b/gdb/common/linux-osdata.c index afe3e75..d54f9d3 100644 --- a/gdb/common/linux-osdata.c +++ b/gdb/common/linux-osdata.c @@ -26,6 +26,7 @@ #include "linux-osdata.h" #include +#include #include #include #include @@ -253,30 +254,8 @@ get_process_owner (uid_t *owner, PID_T pid) return -1; } -/* Returns the number of CPU cores found on the system. */ - -static int -get_number_of_cpu_cores (void) -{ - int cores = 0; - FILE *f = fopen ("/proc/cpuinfo", "r"); - - while (!feof (f)) - { - char buf[512]; - char *p = fgets (buf, sizeof (buf), f); - - if (p && strncmp (buf, "processor", 9) == 0) - ++cores; - } - - fclose (f); - - return cores; -} - /* Find the CPU cores used by process PID and return them in CORES. - CORES points to an array of at least get_number_of_cpu_cores () + CORES points to an array of at least sysconf(_SC_NPROCESSOR_ONLN) elements. */ static int @@ -340,7 +319,7 @@ linux_xfer_osdata_processes (gdb_byte *readbuf, dirp = opendir ("/proc"); if (dirp) { - const int num_cores = get_number_of_cpu_cores (); + const int num_cores = sysconf (_SC_NPROCESSORS_ONLN); struct dirent *dp; while ((dp = readdir (dirp)) != NULL) -- 2.7.4