mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-13 08:19:56 +00:00
4c4ce2f899
The former implementation did not internally track ROM changes notified vs. delivered to the client. We adapt the versioning implementation implemented in dynamic_rom_session.h and enable explicit notification of the current version. The feature is used by the clipboard to notify permitted readers of the clipboard ROM service on focus change via the newly created private Rom::Module::_notify_permitted_readers() function. Fixes #4274
77 lines
2.8 KiB
Plaintext
77 lines
2.8 KiB
Plaintext
<runtime ram="32M" caps="1000" binary="init">
|
|
|
|
<requires> <timer/> </requires>
|
|
|
|
<events>
|
|
<timeout meaning="failed" sec="30" />
|
|
<log meaning="failed">exited with exit value -1</log>
|
|
<log meaning="succeeded">
|
|
[init -> test-report_rom] --- test-report_rom started ---
|
|
[init -> test-report_rom] Reporter: open session
|
|
[init -> test-report_rom] Reporter: brightness 10
|
|
[init -> test-report_rom] ROM client: request brightness report
|
|
[init -> test-report_rom] -> <brightness value="10"/>
|
|
[init -> test-report_rom]
|
|
[init -> test-report_rom] Reporter: updated brightness to 77
|
|
[init -> test-report_rom] ROM client: wait for update notification
|
|
[init -> test-report_rom] ROM client: got signal
|
|
[init -> test-report_rom] ROM client: request updated brightness report
|
|
[init -> test-report_rom] -> <brightness value="77"/>
|
|
[init -> test-report_rom]
|
|
[init -> test-report_rom] Reporter: close report session, wait a bit
|
|
[init -> test-report_rom] got timeout
|
|
[init -> test-report_rom] -> <brightness value="77"/>
|
|
[init -> test-report_rom]
|
|
[init -> test-report_rom] ROM client: ROM is available despite report was closed - OK
|
|
[init -> test-report_rom] Reporter: start reporting (while the ROM client still listens)
|
|
[init -> test-report_rom] ROM client: wait for update notification
|
|
[init -> test-report_rom] ROM client: try to open the same report again
|
|
[init -> test-report_rom] *Error: Report-session creation failed (label="brightness", ram_quota=14336, cap_quota=3, buffer_size=4096)*
|
|
[init -> test-report_rom] ROM client: caught Service_denied - OK
|
|
[init -> test-report_rom] --- test-report_rom finished ---
|
|
[init] child "test-report_rom" exited with exit value 0
|
|
</log>
|
|
</events>
|
|
|
|
<content>
|
|
<rom label="ld.lib.so"/>
|
|
<rom label="test-report_rom"/>
|
|
<rom label="report_rom"/>
|
|
</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="Timer"/>
|
|
</parent-provides>
|
|
<default-route>
|
|
<any-service> <parent/> <any-child/> </any-service>
|
|
</default-route>
|
|
<default caps="100"/>
|
|
<start name="report_rom">
|
|
<resource name="RAM" quantum="2M"/>
|
|
<provides> <service name="ROM"/> <service name="Report"/> </provides>
|
|
<config>
|
|
<policy label_prefix="test-report_rom ->" label_suffix="brightness"
|
|
report="test-report_rom -> brightness"/>
|
|
</config>
|
|
</start>
|
|
<start name="test-report_rom">
|
|
<resource name="RAM" quantum="2M"/>
|
|
<route>
|
|
<service name="ROM" label="brightness">
|
|
<child name="report_rom"/>
|
|
</service>
|
|
<any-service> <parent/> <any-child/> </any-service>
|
|
</route>
|
|
</start>
|
|
</config>
|
|
</runtime>
|