* The io_handler::handled_count was increased unconditionally, but in some cases

not at all.
* Tried to improve the readability of the "ints" command output.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@34613 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Axel Dörfler 2009-12-10 11:14:46 +00:00
parent ccc02f719a
commit 2388f50c53

View File

@ -89,12 +89,20 @@ dump_int_statistics(int argc, char **argv)
if (strchr(imageName, '/') != NULL)
imageName = strrchr(imageName, '/') + 1;
kprintf("\t%s:%s (%p), data %p, handled %8lld%s\n", imageName,
symbol, io->func, io->data, io->handled_count,
io->no_handled_info ? ", NO HANDLED INFO" : "");
int length = 4 + strlen(imageName);
kprintf(" %s:%-*s (%p)", imageName, 45 - length, symbol,
io->func);
} else
kprintf("\t%p, data %p\n", io->func, io->data);
kprintf("\t\t\t\t\t func %p", io->func);
kprintf(", data %p, handled ", io->data);
if (io->no_handled_info)
kprintf("<unknown>\n");
else
kprintf("%8lld\n", io->handled_count);
}
kprintf("\n");
}
return 0;
}
@ -180,18 +188,21 @@ int_io_interrupt_handler(int vector, bool levelTriggered)
}
#endif
/* For level-triggered interrupts, we actually handle the return
* value (ie. B_HANDLED_INTERRUPT) to decide wether or not we
* want to call another interrupt handler.
* For edge-triggered interrupts, however, we always need to call
* all handlers, as multiple interrupts cannot be identified. We
* still make sure the return code of this function will issue
* whatever the driver thought would be useful (ie. B_INVOKE_SCHEDULER)
*/
// For level-triggered interrupts, we actually handle the return
// value (ie. B_HANDLED_INTERRUPT) to decide wether or not we
// want to call another interrupt handler.
// For edge-triggered interrupts, however, we always need to call
// all handlers, as multiple interrupts cannot be identified. We
// still make sure the return code of this function will issue
// whatever the driver thought would be useful (ie. B_INVOKE_SCHEDULER)
for (io = sVectors[vector].handler_list; io != NULL; io = io->next) {
status = io->func(io->data);
#if DEBUG_INTERRUPTS
if (status != B_UNHANDLED_INTERRUPT)
io->handled_count++;
#endif
if (levelTriggered && status != B_UNHANDLED_INTERRUPT)
break;
@ -199,9 +210,6 @@ int_io_interrupt_handler(int vector, bool levelTriggered)
handled = true;
else if (status == B_INVOKE_SCHEDULER)
invokeScheduler = true;
#if DEBUG_INTERRUPTS
io->handled_count++;
#endif
}
#if DEBUG_INTERRUPTS