Hello,
I'm currently trying to get fiasco's built-in profiling working. The
problem is, as soon as roottask has been started, an error (mcount: tos
overflow) occurs which apparently prevents profiling. Later on no
gmon.out.uu is generated. Is that supposed to work? Or what am I doing
wrong here? I attached a log showing the error message.
From the JDB source code, it sounds like you can enable and disable
kernel profiling from JDB. How can this be accomplished?
Thanks for any help
Stefan
L4 Bootstrapper
Scaning /bin/fiasco -profile -profstart -nokdb -nowait -serial -comport 1 -serial_esc
Scaning /bin/sigma0
Scaning /bin/roottask
Bootloader MMAP available
[00000000,0009fc00) RAM (1)
[0009fc00,000a0000) RAM (1)
[000f0000,00100000) reserved (2)
[ffb00000,00000000) reserved (2)
[00100000,1fff0000) RAM (1)
[1fff3000,20000000) ACPI (3)
[1fff0000,1fff3000) ACPI NVS (4)
Relocated mbi to [0x61000-0x611b3]
Loading /bin/fiasco
Loading /bin/sigma0
Loading /bin/roottask
find kernel info page...
found kernel info page at 0x1000
API Version: (87) experimental
Sigma0 config ip:00094cd0 sp:00106100
Roottask config ip:00120000 sp:00109528
[00001000-00002000) /bin/fiasco
[00002000-00052680) /bin/fiasco
[00052680-0005add0) /bin/fiasco
[0005b000-0005e861) /bin/fiasco
[0005e880-00061000) /bin/fiasco
[00090000-00099380) /bin/sigma0
[0009f000-00100000) BIOS area
[00100000-00109764) bootstrap
[00120000-001345d0) /bin/roottask
[00135000-0013f9bb) /bin/roottask
[001409c0-002be9f4) /bin/roottask
[00300000-003017ec) /bin/fiasco
[00302000-0038fce0) /bin/fiasco
[03000000-03152c1d) Modules Memory
[1fff0000-ffffffff) Deep Space
Starting kernel /bin/fiasco at 003007e8
Welcome to Fiasco(ia32)!
DD-L4(v2)/x86 microkernel (C) 1998-2006 TU Dresden
Rev: Thu Dec 21 08:55:14 2006 compiled with gcc 4.1.1 for Pentium M
Performance-critical config option(s) detected:
CONFIG_SCHED_RTC is on
CONFIG_ASSEMBLER_IPC_SHORTCUT is off
CONFIG_PROFILE is on
CONFIG_NO_FRAME_PTR is off
CONFIG_JDB_ACCOUNTING is on
Enabling special fully nested mode for PIC
Using the RTC on IRQ 8 (1kHz) for scheduling
SERIAL ESC: allocated IRQ 4 for serial uart
Absolute KIP Syscalls using: Sysenter
CPU: GenuineIntel (F:2:4:9) Model: Pentium 4 (Northwood/Prestonia) at 1992 MHz
64 Entry I TLB (4K or 4M pages)
64 Entry D TLB (4k or 4M pages)
12K µ-ops T Cache (8-way associative)
8 KB L1 D Cache (4-way associative, 64 bytes per line)
512 KB L2 U Cache (8-way associative, 64 bytes per line)
Freeing init code/data: 24576 bytes (6 pages)
Calibrating timer loop... done.
SIGMA0: Hello!
KIP @ 1000
Found Fiasco: KIP syscalls: yes
allocated 4KB for maintenance structures
Roottask.
Command line found: "/bin/roottask"
mcount: tos overflow
523840kB ( 511MB) total RAM (reported by bootloader)
479676kB ( 469MB) received RAM from Sigma0
1816kB ( 2MB) reserved RAM for RMGR
Received I/O ports 0000-ffff
Attached irqs = [ <!0> 1 <!2> 3 <!4> 5 6 7 <!8> 9 A B C D E F ]
Roottask: Loading 1 module.
#05: loading "/bin/hello"
from [0312d000-03152c1d] to [01000000-01002eea][01003000-010055c0]
entry at 0005b064 via trampoline page code
symbols at [1d6fa000-1d6fb000] (4kB), lines at [1d6f7000-1d6fa000] (12kB)
hello: My thread-id is 5.0
hello: My thread-id is 5.0
hello: My thread-id is 5.0