Code to dump IPC statistics over a serial line. (Disabled) code to disable the
FPU.
This commit is contained in:
parent
1cffa69d2c
commit
f5389ecf19
1 changed files with 49 additions and 0 deletions
|
@ -6,11 +6,15 @@
|
||||||
#include <ibm/cmos.h>
|
#include <ibm/cmos.h>
|
||||||
#include <ibm/bios.h>
|
#include <ibm/bios.h>
|
||||||
#include <minix/portio.h>
|
#include <minix/portio.h>
|
||||||
|
#include <minix/u64.h>
|
||||||
|
|
||||||
#include "proto.h"
|
#include "proto.h"
|
||||||
#include "../../proc.h"
|
#include "../../proc.h"
|
||||||
|
|
||||||
|
#define CR0_EM 0x0004 /* set to enable trap on any FP instruction */
|
||||||
|
|
||||||
FORWARD _PROTOTYPE( void ser_debug, (int c));
|
FORWARD _PROTOTYPE( void ser_debug, (int c));
|
||||||
|
FORWARD _PROTOTYPE( void ser_dump_stats, (void));
|
||||||
|
|
||||||
PUBLIC void arch_shutdown(int how)
|
PUBLIC void arch_shutdown(int how)
|
||||||
{
|
{
|
||||||
|
@ -43,6 +47,11 @@ PUBLIC void arch_shutdown(int how)
|
||||||
PUBLIC void system_init(void)
|
PUBLIC void system_init(void)
|
||||||
{
|
{
|
||||||
prot_init();
|
prot_init();
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
/* Set CR0_EM until we get FP context switching */
|
||||||
|
write_cr0(read_cr0() | CR0_EM);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#define COM1_BASE 0x3F8
|
#define COM1_BASE 0x3F8
|
||||||
|
@ -90,6 +99,9 @@ PRIVATE void ser_debug(int c)
|
||||||
case '1':
|
case '1':
|
||||||
ser_dump_proc();
|
ser_dump_proc();
|
||||||
break;
|
break;
|
||||||
|
case '2':
|
||||||
|
ser_dump_stats();
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
do_serial_debug--;
|
do_serial_debug--;
|
||||||
}
|
}
|
||||||
|
@ -110,9 +122,46 @@ PUBLIC void ser_dump_proc()
|
||||||
pp->p_priority, pp->p_max_priority,
|
pp->p_priority, pp->p_max_priority,
|
||||||
pp->p_user_time, pp->p_sys_time,
|
pp->p_user_time, pp->p_sys_time,
|
||||||
pp->p_reg.pc);
|
pp->p_reg.pc);
|
||||||
|
stacktrace(pp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PRIVATE void ser_dump_stats()
|
||||||
|
{
|
||||||
|
kprintf("ipc_stats:\n");
|
||||||
|
kprintf("deadproc: %d\n", ipc_stats.deadproc);
|
||||||
|
kprintf("bad_endpoint: %d\n", ipc_stats.bad_endpoint);
|
||||||
|
kprintf("dst_not_allowed: %d\n", ipc_stats.dst_not_allowed);
|
||||||
|
kprintf("bad_call: %d\n", ipc_stats.bad_call);
|
||||||
|
kprintf("call_not_allowed: %d\n", ipc_stats.call_not_allowed);
|
||||||
|
kprintf("bad_buffer: %d\n", ipc_stats.bad_buffer);
|
||||||
|
kprintf("deadlock: %d\n", ipc_stats.deadlock);
|
||||||
|
kprintf("not_ready: %d\n", ipc_stats.not_ready);
|
||||||
|
kprintf("src_died: %d\n", ipc_stats.src_died);
|
||||||
|
kprintf("dst_died: %d\n", ipc_stats.dst_died);
|
||||||
|
kprintf("no_priv: %d\n", ipc_stats.no_priv);
|
||||||
|
kprintf("bad_size: %d\n", ipc_stats.bad_size);
|
||||||
|
kprintf("bad_senda: %d\n", ipc_stats.bad_senda);
|
||||||
|
if (ex64hi(ipc_stats.total))
|
||||||
|
{
|
||||||
|
kprintf("total: %x:%08x\n", ex64hi(ipc_stats.total),
|
||||||
|
ex64lo(ipc_stats.total));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
kprintf("total: %u\n", ex64lo(ipc_stats.total));
|
||||||
|
|
||||||
|
kprintf("sys_stats:\n");
|
||||||
|
kprintf("bad_req: %d\n", sys_stats.bad_req);
|
||||||
|
kprintf("not_allowed: %d\n", sys_stats.not_allowed);
|
||||||
|
if (ex64hi(sys_stats.total))
|
||||||
|
{
|
||||||
|
kprintf("total: %x:%08x\n", ex64hi(sys_stats.total),
|
||||||
|
ex64lo(sys_stats.total));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
kprintf("total: %u\n", ex64lo(sys_stats.total));
|
||||||
|
}
|
||||||
|
|
||||||
#if SPROFILE
|
#if SPROFILE
|
||||||
|
|
||||||
PUBLIC int arch_init_profile_clock(u32_t freq)
|
PUBLIC int arch_init_profile_clock(u32_t freq)
|
||||||
|
|
Loading…
Reference in a new issue