genode/repos/os/recipes/pkg/test-trace/runtime
Norman Feske bfe88307de core: filter trace subjects by TRACE session label
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
2023-12-13 12:28:52 +01:00

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>