mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-11 15:33:04 +00:00
de7fdd3e1a
Instead of returning an invalid device capability when a device is (not yet) available, e.g. a PCI device is requested before the PCI bus got parsed accordingly, we check the device capability within the Platform::Connection utilities, and register temporarily an Io_signal_handler to wait for changes of the devices ROM, and try the device aquisition again. Thereby, simple drivers so not have to take the burden to do so. To enable this feature for all drivers, we always have to export a devices ROM, but limit the information about physical resources (I/O memory addresses, IRQ numbers, I/O port ranges) to clients with 'info=yes' in their policy description. Fix genodelabs/genode#4496
178 lines
6.2 KiB
Plaintext
178 lines
6.2 KiB
Plaintext
if { ![have_board pbxa9] } {
|
|
puts "Platform is unsupported."
|
|
exit 0
|
|
}
|
|
|
|
create_boot_directory
|
|
|
|
import_from_depot [depot_user]/src/[base_src] \
|
|
[depot_user]/src/init \
|
|
[depot_user]/src/fs_report \
|
|
[depot_user]/src/fs_rom \
|
|
[depot_user]/src/platform_drv \
|
|
[depot_user]/src/report_rom \
|
|
[depot_user]/src/vfs_import \
|
|
[depot_user]/src/vfs
|
|
|
|
build { test/platform_drv }
|
|
|
|
install_config {
|
|
<config>
|
|
<parent-provides>
|
|
<service name="ROM"/>
|
|
<service name="IRQ"/>
|
|
<service name="IO_MEM"/>
|
|
<service name="PD"/>
|
|
<service name="RM"/>
|
|
<service name="CPU"/>
|
|
<service name="LOG"/>
|
|
</parent-provides>
|
|
<default-route>
|
|
<any-service> <parent/> </any-service>
|
|
</default-route>
|
|
<default caps="100"/>
|
|
|
|
<start name="timer">
|
|
<resource name="RAM" quantum="10M"/>
|
|
<provides><service name="Timer"/></provides>
|
|
</start>
|
|
|
|
<start name="report_fs">
|
|
<binary name="vfs"/>
|
|
<resource name="RAM" quantum="2M"/>
|
|
<provides> <service name="File_system"/> </provides>
|
|
<config>
|
|
<vfs>
|
|
<ram/>
|
|
<import>
|
|
<inline name="config"><config><default-policy/></config>
|
|
</inline>
|
|
<inline name="devices"><devices/>
|
|
</inline>
|
|
</import>
|
|
</vfs>
|
|
<policy label="fs_report -> " root="/" writeable="yes"/>
|
|
<policy label="report_fs_rom -> " root="/"/>
|
|
</config>
|
|
</start>
|
|
|
|
<start name="fs_report">
|
|
<resource name="RAM" quantum="1M"/>
|
|
<provides> <service name="Report"/> </provides>
|
|
<config> <vfs> <fs/> </vfs> </config>
|
|
<route>
|
|
<service name="File_system"> <child name="report_fs"/> </service>
|
|
<any-service> <parent/> </any-service>
|
|
</route>
|
|
</start>
|
|
|
|
<start name="report_fs_rom">
|
|
<binary name="fs_rom"/>
|
|
<resource name="RAM" quantum="3M"/>
|
|
<provides> <service name="ROM"/> </provides>
|
|
<route>
|
|
<service name="File_system"> <child name="report_fs"/> </service>
|
|
<any-service> <parent/> </any-service>
|
|
</route>
|
|
</start>
|
|
|
|
<start name="report_rom">
|
|
<resource name="RAM" quantum="3M"/>
|
|
<provides>
|
|
<service name="ROM"/>
|
|
<service name="Report"/>
|
|
</provides>
|
|
<route>
|
|
<any-service> <parent/> </any-service>
|
|
</route>
|
|
<config verbose="no"/>
|
|
</start>
|
|
|
|
<start name="platform_drv" managing_system="yes">
|
|
<resource name="RAM" quantum="1M"/>
|
|
<provides> <service name="Platform"/> </provides>
|
|
<route>
|
|
<service name="ROM" label="config"> <child name="report_fs_rom"/> </service>
|
|
<service name="ROM" label="devices"><child name="report_fs_rom"/> </service>
|
|
<service name="Report"> <child name="report_rom"/> </service>
|
|
<any-service> <parent/> </any-service>
|
|
</route>
|
|
</start>
|
|
|
|
<start name="test-platform_drv">
|
|
<resource name="RAM" quantum="1M"/>
|
|
<route>
|
|
<service name="Report" label="config">
|
|
<child name="fs_report" label="config"/> </service>
|
|
<service name="Report" label="devices">
|
|
<child name="fs_report" label="devices"/> </service>
|
|
<service name="Platform"> <child name="platform_drv"/> </service>
|
|
<any-service> <parent/> </any-service>
|
|
</route>
|
|
</start>
|
|
</config>}
|
|
|
|
|
|
build_boot_image { test-platform_drv }
|
|
|
|
append qemu_args "-nographic "
|
|
|
|
set good_string {
|
|
[init -> test-platform_drv] <devices version="1">
|
|
[init -> test-platform_drv] <device name="0" type="dummy-device" used="false">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40000000" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="32"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] <device name="1" type="dummy-device" used="false">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40001000" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="33"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] <device name="2" type="dummy-device" used="false">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40002000" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="34"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] </devices>
|
|
[init -> test-platform_drv] <devices version="2">
|
|
[init -> test-platform_drv] <device name="0" type="dummy-device" used="true">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40000000" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="32"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] <device name="1" type="dummy-device" used="true">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40001000" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="33"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] </devices>
|
|
[init -> test-platform_drv] <devices version="3"/>
|
|
[init -> test-platform_drv] <devices version="4">
|
|
[init -> test-platform_drv] <device name="0" type="dummy-device" used="false">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40000000" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="32"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] <device name="1" type="dummy-device" used="false">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40001000" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="33"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] <device name="2" type="dummy-device" used="false">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40002000" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="34"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] <device name="3" type="dummy-device" used="false">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40003000" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="35"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] </devices>
|
|
[init -> test-platform_drv] <devices version="5"/>
|
|
[init -> test-platform_drv] <devices version="6">
|
|
[init -> test-platform_drv] <device name="0" type="dummy-device" used="false">
|
|
[init -> test-platform_drv] <io_mem phys_addr="0x40000100" size="0x1000"/>
|
|
[init -> test-platform_drv] <irq number="32"/>
|
|
[init -> test-platform_drv] </device>
|
|
[init -> test-platform_drv] </devices>
|
|
[init -> test-platform_drv] Found next valid device of dummy type
|
|
[init -> test-platform_drv] Test has ended!
|
|
}
|
|
|
|
run_genode_until "Test has ended!.*\n" 100
|
|
grep_output "init -> test-platform_drv"
|
|
compare_output_to $good_string
|