ProcessController: Explicitly check thread priority

This commit is contained in:
Pawel Dziepak 2013-12-12 21:46:48 +01:00
parent 8cf2f36c37
commit 25feff2c29

View File

@ -104,10 +104,16 @@ ThreadBarMenuItem::DrawBar(bool force)
r.right = fGrenze1; r.right = fGrenze1;
} }
if (r.left < r.right) { if (r.left < r.right) {
if (selected) thread_info threadInfo;
menu->SetHighColor(fThreadID <= gCPUcount ? gIdleColorSelected : gUserColorSelected); bool idleThread = false;
else if (get_thread_info(fThreadID, &threadInfo) == B_OK)
menu->SetHighColor(fThreadID <= gCPUcount ? gIdleColor : gUserColor); idleThread = threadInfo.priority == B_IDLE_PRIORITY;
if (selected) {
menu->SetHighColor(
idleThread ? gIdleColorSelected : gUserColorSelected);
} else
menu->SetHighColor(idleThread ? gIdleColor : gUserColor);
menu->FillRect(r); menu->FillRect(r);
} }
r.left = grenze2; r.left = grenze2;
@ -157,7 +163,7 @@ ThreadBarMenuItem::BarUpdate()
bigtime_t now = system_time(); bigtime_t now = system_time();
fKernel = double(info.kernel_time - fThreadInfo.kernel_time) / double(now - fLastTime); fKernel = double(info.kernel_time - fThreadInfo.kernel_time) / double(now - fLastTime);
fUser = double(info.user_time - fThreadInfo.user_time) / double(now - fLastTime); fUser = double(info.user_time - fThreadInfo.user_time) / double(now - fLastTime);
if (fThreadID <= gCPUcount) { if (info.priority == B_IDLE_PRIORITY) {
fUser += fKernel; fUser += fKernel;
fKernel = 0; fKernel = 0;
} }