wok-current diff coreutils/stuff/uname.u @ rev 18235
Up: tazinst(63): fix "/dev/sdb or /dev/sdb or ... /dev/sdb" bug
author | Aleksej Bobylev <al.bobylev@gmail.com> |
---|---|
date | Fri Jul 24 14:46:51 2015 +0300 (2015-07-24) |
parents | |
children |
line diff
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/coreutils/stuff/uname.u Fri Jul 24 14:46:51 2015 +0300 1.3 @@ -0,0 +1,173 @@ 1.4 +On linux platforms, grok /proc/cpuinfo for the CPU/vendor info. 1.5 + 1.6 +Prob not suitable for upstream seeing as how it's 100% linux-specific 1.7 +http://lists.gnu.org/archive/html/bug-coreutils/2005-09/msg00063.html 1.8 + 1.9 +Patch originally by Carlos E. Gorges <carlos@techlinux.com.br>, but 1.10 +heavily reworked to suck less. 1.11 + 1.12 +To add support for additional platforms, check out the show_cpuinfo() 1.13 +func in the linux/arch/<ARCH>/ source tree of the kernel. 1.14 + 1.15 +--- coreutils/src/uname.c 1.16 ++++ coreutils/src/uname.c 1.17 +@@ -50,6 +50,11 @@ 1.18 + # include <mach-o/arch.h> 1.19 + #endif 1.20 + 1.21 ++#if defined(__linux__) 1.22 ++# define USE_PROCINFO 1.23 ++# define UNAME_HARDWARE_PLATFORM 1.24 ++#endif 1.25 ++ 1.26 + #include "system.h" 1.27 + #include "error.h" 1.28 + #include "quote.h" 1.29 +@@ -138,6 +143,117 @@ 1.30 + exit (status); 1.31 + } 1.32 + 1.33 ++#if defined(USE_PROCINFO) 1.34 ++ 1.35 ++# if defined(__s390__) || defined(__s390x__) 1.36 ++# define CPUINFO_FILE "/proc/sysinfo" 1.37 ++# define CPUINFO_FORMAT "%64[^\t :]%*[ :]%256[^\n]%c" 1.38 ++# else 1.39 ++# define CPUINFO_FILE "/proc/cpuinfo" 1.40 ++# define CPUINFO_FORMAT "%64[^\t:]\t:%256[^\n]%c" 1.41 ++# endif 1.42 ++ 1.43 ++# define PROCINFO_PROCESSOR 0 1.44 ++# define PROCINFO_HARDWARE_PLATFORM 1 1.45 ++ 1.46 ++static void __eat_cpuinfo_space(char *buf) 1.47 ++{ 1.48 ++ /* first eat trailing space */ 1.49 ++ char *tmp = buf + strlen(buf) - 1; 1.50 ++ while (tmp > buf && isspace(*tmp)) 1.51 ++ *tmp-- = '\0'; 1.52 ++ /* then eat leading space */ 1.53 ++ tmp = buf; 1.54 ++ while (*tmp && isspace(*tmp)) 1.55 ++ tmp++; 1.56 ++ if (tmp != buf) 1.57 ++ memmove(buf, tmp, strlen(tmp)+1); 1.58 ++ /* finally collapse whitespace */ 1.59 ++ tmp = buf; 1.60 ++ while (tmp[0] && tmp[1]) { 1.61 ++ if (isspace(tmp[0]) && isspace(tmp[1])) { 1.62 ++ memmove(tmp, tmp+1, strlen(tmp)); 1.63 ++ continue; 1.64 ++ } 1.65 ++ ++tmp; 1.66 ++ } 1.67 ++} 1.68 ++ 1.69 ++static int __linux_procinfo(int x, char *fstr, size_t s) 1.70 ++{ 1.71 ++ FILE *fp; 1.72 ++ 1.73 ++ char *procinfo_keys[] = { 1.74 ++ /* --processor --hardware-platform */ 1.75 ++ #if defined(__alpha__) 1.76 ++ "cpu model", "system type" 1.77 ++ #elif defined(__arm__) 1.78 ++ "Processor", "Hardware" 1.79 ++ #elif defined(__avr32__) 1.80 ++ "processor", "cpu family" 1.81 ++ #elif defined(__bfin__) 1.82 ++ "CPU", "BOARD Name" 1.83 ++ #elif defined(__cris__) 1.84 ++ "cpu", "cpu model" 1.85 ++ #elif defined(__frv__) 1.86 ++ "CPU-Core", "System" 1.87 ++ #elif defined(__i386__) || defined(__x86_64__) 1.88 ++ "model name", "vendor_id" 1.89 ++ #elif defined(__ia64__) 1.90 ++ "family", "vendor" 1.91 ++ #elif defined(__hppa__) 1.92 ++ "cpu", "model" 1.93 ++ #elif defined(__m68k__) 1.94 ++ "CPU", "MMU" 1.95 ++ #elif defined(__mips__) 1.96 ++ "cpu model", "system type" 1.97 ++ #elif defined(__powerpc__) || defined(__powerpc64__) 1.98 ++ "cpu", "machine" 1.99 ++ #elif defined(__s390__) || defined(__s390x__) 1.100 ++ "Type", "Manufacturer" 1.101 ++ #elif defined(__sh__) 1.102 ++ "cpu type", "machine" 1.103 ++ #elif defined(sparc) || defined(__sparc__) 1.104 ++ "type", "cpu" 1.105 ++ #elif defined(__vax__) 1.106 ++ "cpu type", "cpu" 1.107 ++ #else 1.108 ++ "unknown", "unknown" 1.109 ++ #endif 1.110 ++ }; 1.111 ++ 1.112 ++ if ((fp = fopen(CPUINFO_FILE, "r")) != NULL) { 1.113 ++ char key[65], value[257], eol, *ret = NULL; 1.114 ++ 1.115 ++ while (fscanf(fp, CPUINFO_FORMAT, key, value, &eol) != EOF) { 1.116 ++ __eat_cpuinfo_space(key); 1.117 ++ if (!strcmp(key, procinfo_keys[x])) { 1.118 ++ __eat_cpuinfo_space(value); 1.119 ++ ret = value; 1.120 ++ break; 1.121 ++ } 1.122 ++ if (eol != '\n') { 1.123 ++ /* we need two fscanf's here in case the previous 1.124 ++ * length limit caused us to read right up to the 1.125 ++ * newline ... doing "%*[^\n]\n" wont eat the newline 1.126 ++ */ 1.127 ++ fscanf(fp, "%*[^\n]"); 1.128 ++ fscanf(fp, "\n"); 1.129 ++ } 1.130 ++ } 1.131 ++ fclose(fp); 1.132 ++ 1.133 ++ if (ret) { 1.134 ++ strncpy(fstr, ret, s); 1.135 ++ return 0; 1.136 ++ } 1.137 ++ } 1.138 ++ 1.139 ++ return -1; 1.140 ++} 1.141 ++ 1.142 ++#endif 1.143 ++ 1.144 + /* Print ELEMENT, preceded by a space if something has already been 1.145 + printed. */ 1.146 + 1.147 +@@ -250,10 +344,14 @@ main (int argc, char **argv) 1.148 + if (toprint & PRINT_PROCESSOR) 1.149 + { 1.150 + char const *element = unknown; 1.151 +-#if HAVE_SYSINFO && defined SI_ARCHITECTURE 1.152 ++#if ( HAVE_SYSINFO && defined SI_ARCHITECTURE ) || defined(USE_PROCINFO) 1.153 + { 1.154 + static char processor[257]; 1.155 ++#if defined(USE_PROCINFO) 1.156 ++ if (0 <= __linux_procinfo (PROCINFO_PROCESSOR, processor, sizeof processor)) 1.157 ++#else 1.158 + if (0 <= sysinfo (SI_ARCHITECTURE, processor, sizeof processor)) 1.159 ++#endif 1.160 + element = processor; 1.161 + } 1.162 + #endif 1.163 +@@ -306,9 +404,13 @@ main (int argc, char **argv) 1.164 + if (element == unknown) 1.165 + { 1.166 + static char hardware_platform[257]; 1.167 ++#if defined(USE_PROCINFO) 1.168 ++ if (0 <= __linux_procinfo (PROCINFO_HARDWARE_PLATFORM, hardware_platform, sizeof hardware_platform)) 1.169 ++#else 1.170 + size_t s = sizeof hardware_platform; 1.171 + static int mib[] = { CTL_HW, UNAME_HARDWARE_PLATFORM }; 1.172 + if (sysctl (mib, 2, hardware_platform, &s, 0, 0) >= 0) 1.173 ++#endif 1.174 + element = hardware_platform; 1.175 + } 1.176 + #endif