mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-11 07:23:25 +00:00
bfe88307de
This patch changes core's TRACE service to expose trace subjects only if their PD label matches the label of the TRACE monitor. Hence, by default, a trace monitor can only observe itself and its child components. Only if the trace monitor's parent rewrites the trace-session's label, the view of trace monitor can become broader. For example, when rewriting the trace label to an empty string "", the trace monitor becomes able to observe the sibling components hosted in the same init instance as the trace monitor. To grant a trace session the special privilege of obtaining a global system view (including the kernel's trace subjects), the top-level init has to rewrite the session's label to an empty string. At core, this specific label "init -> " is handled as a special case that discharges the filtering/namespacing of trace subjects. Note that the trace-subject label as reported as subject info is now given relative to the label of the trace session. As a nice side effect of this change, the pkg/test-trace_logger works now when executed by the depot_autopilot as well as via the test.run script. Issue #847
66 lines
1.6 KiB
Plaintext
66 lines
1.6 KiB
Plaintext
<runtime ram="90M" caps="1000" binary="init">
|
|
|
|
<requires> <timer/> </requires>
|
|
|
|
<fail after_seconds="30"/>
|
|
<succeed>child "sequence" exited with exit value 0</succeed>
|
|
<fail>Error: </fail>
|
|
|
|
<content>
|
|
<rom label="ld.lib.so"/>
|
|
<rom label="top"/>
|
|
<rom label="test-trace"/>
|
|
<rom label="sequence"/>
|
|
<rom label="null"/>
|
|
</content>
|
|
|
|
<config>
|
|
<parent-provides>
|
|
<service name="ROM"/>
|
|
<service name="IRQ"/>
|
|
<service name="IO_MEM"/>
|
|
<service name="IO_PORT"/>
|
|
<service name="PD"/>
|
|
<service name="RM"/>
|
|
<service name="CPU"/>
|
|
<service name="LOG"/>
|
|
<service name="TRACE"/>
|
|
<service name="Timer"/>
|
|
</parent-provides>
|
|
<default-route>
|
|
<service name="TRACE"> <parent label=""/> </service>
|
|
<any-service> <parent/> <any-child/> </any-service>
|
|
</default-route>
|
|
<default caps="200"/>
|
|
<start name="sequence">
|
|
<resource name="RAM" quantum="15M"/>
|
|
<config>
|
|
<start name="test-trace">
|
|
<resource name="RAM" quantum="10M"/>
|
|
<config>
|
|
<trace_policy label="sequence -> test-trace" thread="test-thread" module="null"/>
|
|
</config>
|
|
</start>
|
|
|
|
<start name="test-trace">
|
|
<resource name="RAM" quantum="10M"/>
|
|
<config>
|
|
<trace_policy label="top" thread="ep" module="null"/>
|
|
</config>
|
|
</start>
|
|
|
|
<start name="test-trace">
|
|
<resource name="RAM" quantum="10M"/>
|
|
<config>
|
|
<trace_policy label="top" thread="ep" module="null"/>
|
|
</config>
|
|
</start>
|
|
</config>
|
|
</start>
|
|
<start name="top">
|
|
<resource name="RAM" quantum="2M"/>
|
|
<config period_ms="2000"/>
|
|
</start>
|
|
</config>
|
|
</runtime>
|