genode/repos/os/recipes/pkg/test-trace_logger/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

116 lines
3.3 KiB
Plaintext

<runtime ram="100M" caps="1000" binary="init">
<requires> <timer/> </requires>
<fail after_seconds="20"/>
<succeed>
[init -> trace_logger] Report *
[init -> trace_logger] PD "cpu_burner.*"*
[init -> trace_logger] Thread "ep" at (0,0) TRACED total:* recent:*
[init -> trace_logger] PD "dynamic_rom"*
[init -> trace_logger] Thread "ep" at (0,0) TRACED total:* recent:*
[init -> trace_logger] PD "test-trace_logger"*
[init -> trace_logger] Thread "ep" at (0,0) TRACED total:* recent:*
[init -> trace_logger] 100 *
[init -> trace_logger] trigger_once
[init -> trace_logger] trigger_once
</succeed>
<content>
<rom label="ld.lib.so"/>
<rom label="dynamic_rom"/>
<rom label="cpu_burner"/>
<rom label="test-trace_logger"/>
<rom label="trace_logger"/>
<rom label="null"/>
<rom label="rpc_name"/>
<rom label="log_output"/>
</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>
<any-service> <parent/> <any-child/> </any-service>
</default-route>
<default caps="100"/>
<start name="trace_logger">
<resource name="RAM" quantum="80M"/>
<config verbose="yes" priority="no" sc_time="no" session_ram="10M" session_parent_levels="1" session_arg_buffer="64K" period_sec="3" default_policy="null" default_buffer="1K">
<policy label_prefix="cpu_burner" thread="ep"/>
<policy label="test-trace_logger" thread="ep" buffer="4K" policy="rpc_name"/>
<policy label="dynamic_rom" thread="ep" buffer="8K" policy="log_output"/>
</config>
<route>
<service name="TRACE"> <parent label=""/> </service>
<any-service> <parent/> <any-child/> </any-service>
</route>
</start>
<start name="dynamic_rom">
<resource name="RAM" quantum="4M"/>
<provides><service name="ROM"/></provides>
<config verbose="yes">
<rom name="cpu_burner1.config">
<inline description="initial state">
<config percent="5"/>
</inline>
<sleep milliseconds="5000"/>
<inline description="50%">
<config percent="50"/>
</inline>
<sleep milliseconds="5000"/>
</rom>
<rom name="cpu_burner2.config">
<inline description="initial state">
<config percent="5"/>
</inline>
<sleep milliseconds="4800"/>
<inline description="100%">
<config percent="70"/>
</inline>
<sleep milliseconds="2700"/>
</rom>
</config>
</start>
<start name="test-trace_logger">
<resource name="RAM" quantum="1M"/>
</start>
<start name="cpu_burner.1">
<binary name="cpu_burner"/>
<resource name="RAM" quantum="1280K"/>
<route>
<service name="ROM" label="config">
<child name="dynamic_rom" label="cpu_burner1.config"/> </service>
<any-service> <parent/> <any-child/> </any-service>
</route>
</start>
<start name="cpu_burner.2">
<binary name="cpu_burner"/>
<resource name="RAM" quantum="1280K"/>
<route>
<service name="ROM" label="config">
<child name="dynamic_rom" label="cpu_burner2.config"/> </service>
<any-service> <parent/> <any-child/> </any-service>
</route>
</start>
</config>
</runtime>