64-bit time for Linux 2.5.xx

This commit is contained in:
albert 2002-05-29 16:40:03 +00:00
parent a42ae5bc42
commit 58d7de98cf
2 changed files with 10 additions and 8 deletions

View File

@ -120,7 +120,8 @@ static void init_Hertz_value(void) __attribute__((constructor));
static void init_Hertz_value(void){ static void init_Hertz_value(void){
unsigned long long user_j, nice_j, sys_j, other_j; /* jiffies (clock ticks) */ unsigned long long user_j, nice_j, sys_j, other_j; /* jiffies (clock ticks) */
double up_1, up_2, seconds; double up_1, up_2, seconds;
unsigned long long jiffies, h; unsigned long long jiffies;
unsigned h;
char *savelocale; char *savelocale;
smp_num_cpus = sysconf(_SC_NPROCESSORS_CONF); smp_num_cpus = sysconf(_SC_NPROCESSORS_CONF);
@ -131,22 +132,22 @@ static void init_Hertz_value(void){
FILE_TO_BUF(UPTIME_FILE,uptime_fd); sscanf(buf, "%lf", &up_1); FILE_TO_BUF(UPTIME_FILE,uptime_fd); sscanf(buf, "%lf", &up_1);
/* uptime(&up_1, NULL); */ /* uptime(&up_1, NULL); */
FILE_TO_BUF(STAT_FILE,stat_fd); FILE_TO_BUF(STAT_FILE,stat_fd);
sscanf(buf, "cpu %lu %lu %lu %lu", &user_j, &nice_j, &sys_j, &other_j); sscanf(buf, "cpu %Lu %Lu %Lu %Lu", &user_j, &nice_j, &sys_j, &other_j);
FILE_TO_BUF(UPTIME_FILE,uptime_fd); sscanf(buf, "%lf", &up_2); FILE_TO_BUF(UPTIME_FILE,uptime_fd); sscanf(buf, "%lf", &up_2);
/* uptime(&up_2, NULL); */ /* uptime(&up_2, NULL); */
} while((long long)( (up_2-up_1)*1000.0/up_1 )); /* want under 0.1% error */ } while((long long)( (up_2-up_1)*1000.0/up_1 )); /* want under 0.1% error */
setlocale(LC_NUMERIC, savelocale); setlocale(LC_NUMERIC, savelocale);
jiffies = user_j + nice_j + sys_j + other_j; jiffies = user_j + nice_j + sys_j + other_j;
seconds = (up_1 + up_2) / 2; seconds = (up_1 + up_2) / 2;
h = (unsigned long long)( (double)jiffies/seconds/smp_num_cpus ); h = (unsigned)( (double)jiffies/seconds/smp_num_cpus );
/* actual values used by 2.4 kernels: 32 64 100 128 1000 1024 1200 */ /* actual values used by 2.4 kernels: 32 64 100 128 1000 1024 1200 */
switch(h){ switch(h){
case 9 ... 11 : Hertz = 10; break; /* S/390 (sometimes) */ case 9 ... 11 : Hertz = 10; break; /* S/390 (sometimes) */
case 18 ... 22 : Hertz = 20; break; /* user-mode Linux */ case 18 ... 22 : Hertz = 20; break; /* user-mode Linux */
case 30 ... 34 : Hertz = 32; break; /* ia64 emulator */ case 30 ... 34 : Hertz = 32; break; /* ia64 emulator */
case 48 ... 52 : Hertz = 50; break; case 48 ... 52 : Hertz = 50; break;
case 58 ... 62 : Hertz = 60; break; case 58 ... 61 : Hertz = 60; break;
case 63 ... 65 : Hertz = 64; break; /* StrongARM /Shark */ case 62 ... 65 : Hertz = 64; break; /* StrongARM /Shark */
case 95 ... 105 : Hertz = 100; break; /* normal Linux */ case 95 ... 105 : Hertz = 100; break; /* normal Linux */
case 124 ... 132 : Hertz = 128; break; /* MIPS, ARM */ case 124 ... 132 : Hertz = 128; break; /* MIPS, ARM */
case 195 ... 204 : Hertz = 200; break; /* normal << 1 */ case 195 ... 204 : Hertz = 200; break; /* normal << 1 */
@ -163,7 +164,7 @@ static void init_Hertz_value(void){
/* If 32-bit or big-endian (not Alpha or ia64), assume HZ is 100. */ /* If 32-bit or big-endian (not Alpha or ia64), assume HZ is 100. */
Hertz = (sizeof(long)==sizeof(int) || htons(999)==999) ? 100UL : 1024UL; Hertz = (sizeof(long)==sizeof(int) || htons(999)==999) ? 100UL : 1024UL;
#endif #endif
fprintf(stderr, "Unknown HZ value! (%ld) Assume %ld.\n", h, Hertz); fprintf(stderr, "Unknown HZ value! (%d) Assume %Ld.\n", h, Hertz);
} }
} }
@ -185,7 +186,7 @@ void four_cpu_numbers(double *uret, double *nret, double *sret, double *iret){
JT ticks_past; /* avoid div-by-0 by not calling too often :-( */ JT ticks_past; /* avoid div-by-0 by not calling too often :-( */
FILE_TO_BUF(STAT_FILE,stat_fd); FILE_TO_BUF(STAT_FILE,stat_fd);
sscanf(buf, "cpu %lu %lu %lu %lu", &new_u, &new_n, &new_s, &new_i); sscanf(buf, "cpu %Lu %Lu %Lu %Lu", &new_u, &new_n, &new_s, &new_i);
ticks_past = (new_u+new_n+new_s+new_i)-(old_u+old_n+old_s+old_i); ticks_past = (new_u+new_n+new_s+new_i)-(old_u+old_n+old_s+old_i);
if(ticks_past){ if(ticks_past){
scale = 100.0 / (double)ticks_past; scale = 100.0 / (double)ticks_past;

3
w.c
View File

@ -168,7 +168,8 @@ static proc_t *getproc(utmp_t *u, char *tty, unsigned long long *jcpu, int *foun
/***** showinfo */ /***** showinfo */
static void showinfo(utmp_t *u, int formtype, int maxcmd, int from) { static void showinfo(utmp_t *u, int formtype, int maxcmd, int from) {
unsigned long long jcpu, ut_pid_found; unsigned long long jcpu;
int ut_pid_found;
unsigned i; unsigned i;
char uname[USERSZ + 1] = "", char uname[USERSZ + 1] = "",
tty[5 + sizeof u->ut_line + 1] = "/dev/"; tty[5 + sizeof u->ut_line + 1] = "/dev/";