mirror of https://github.com/xzeldon/htop.git
Merge branch 'Sp1l-master'
This commit is contained in:
commit
453105e77a
|
@ -86,7 +86,6 @@ static int MIB_kern_cp_time[2];
|
||||||
static int MIB_kern_cp_times[2];
|
static int MIB_kern_cp_times[2];
|
||||||
static int kernelFScale;
|
static int kernelFScale;
|
||||||
|
|
||||||
|
|
||||||
ProcessList* ProcessList_new(UsersTable* usersTable, Hashtable* pidWhiteList, uid_t userId) {
|
ProcessList* ProcessList_new(UsersTable* usersTable, Hashtable* pidWhiteList, uid_t userId) {
|
||||||
size_t len;
|
size_t len;
|
||||||
char errbuf[_POSIX2_LINE_MAX];
|
char errbuf[_POSIX2_LINE_MAX];
|
||||||
|
@ -483,6 +482,7 @@ void ProcessList_goThroughEntries(ProcessList* this) {
|
||||||
// from FreeBSD source /src/usr.bin/top/machine.c
|
// from FreeBSD source /src/usr.bin/top/machine.c
|
||||||
proc->m_size = kproc->ki_size / 1024 / pageSizeKb;
|
proc->m_size = kproc->ki_size / 1024 / pageSizeKb;
|
||||||
proc->m_resident = kproc->ki_rssize;
|
proc->m_resident = kproc->ki_rssize;
|
||||||
|
proc->percent_mem = (proc->m_resident * PAGE_SIZE_KB) / (double)(this->totalMem) * 100.0;
|
||||||
proc->nlwp = kproc->ki_numthreads;
|
proc->nlwp = kproc->ki_numthreads;
|
||||||
proc->time = (kproc->ki_runtime + 5000) / 10000;
|
proc->time = (kproc->ki_runtime + 5000) / 10000;
|
||||||
|
|
||||||
|
@ -493,9 +493,6 @@ void ProcessList_goThroughEntries(ProcessList* this) {
|
||||||
// system idle process should own all CPU time left regardless of CPU count
|
// system idle process should own all CPU time left regardless of CPU count
|
||||||
if ( strcmp("idle", kproc->ki_comm) == 0 ) {
|
if ( strcmp("idle", kproc->ki_comm) == 0 ) {
|
||||||
isIdleProcess = true;
|
isIdleProcess = true;
|
||||||
} else {
|
|
||||||
if (cpus > 1)
|
|
||||||
proc->percent_cpu = proc->percent_cpu / (double) cpus;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (isIdleProcess == false && proc->percent_cpu >= 99.8) {
|
if (isIdleProcess == false && proc->percent_cpu >= 99.8) {
|
||||||
|
|
|
@ -55,7 +55,6 @@ typedef struct FreeBSDProcessList_ {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ProcessList* ProcessList_new(UsersTable* usersTable, Hashtable* pidWhiteList, uid_t userId);
|
ProcessList* ProcessList_new(UsersTable* usersTable, Hashtable* pidWhiteList, uid_t userId);
|
||||||
|
|
||||||
void ProcessList_delete(ProcessList* this);
|
void ProcessList_delete(ProcessList* this);
|
||||||
|
|
|
@ -163,15 +163,15 @@ double Platform_setCPUValues(Meter* this, int cpu) {
|
||||||
double percent;
|
double percent;
|
||||||
double* v = this->values;
|
double* v = this->values;
|
||||||
|
|
||||||
v[CPU_METER_NICE] = cpuData->nicePercent;
|
v[CPU_METER_NICE] = cpuData->nicePercent * cpus;
|
||||||
v[CPU_METER_NORMAL] = cpuData->userPercent;
|
v[CPU_METER_NORMAL] = cpuData->userPercent * cpus;
|
||||||
if (this->pl->settings->detailedCPUTime) {
|
if (this->pl->settings->detailedCPUTime) {
|
||||||
v[CPU_METER_KERNEL] = cpuData->systemPercent;
|
v[CPU_METER_KERNEL] = cpuData->systemPercent * cpus;
|
||||||
v[CPU_METER_IRQ] = cpuData->irqPercent;
|
v[CPU_METER_IRQ] = cpuData->irqPercent * cpus;
|
||||||
Meter_setItems(this, 4);
|
Meter_setItems(this, 4);
|
||||||
percent = v[0]+v[1]+v[2]+v[3];
|
percent = v[0]+v[1]+v[2]+v[3];
|
||||||
} else {
|
} else {
|
||||||
v[2] = cpuData->systemAllPercent;
|
v[2] = cpuData->systemAllPercent * cpus;
|
||||||
Meter_setItems(this, 3);
|
Meter_setItems(this, 3);
|
||||||
percent = v[0]+v[1]+v[2];
|
percent = v[0]+v[1]+v[2];
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue