Move stubby from genode to genode-world

Issue genodelabs/genode#3789
This commit is contained in:
Norman Feske
2020-06-26 11:28:37 +02:00
parent a50a742a2f
commit 471283c69d
23 changed files with 1247 additions and 0 deletions

200
run/stubby.run Normal file
View File

@@ -0,0 +1,200 @@
assert_spec x86
if {[have_spec linux]} {
puts "The [run_name] scenario requires QEMU networking."
exit 1
}
source ${genode_dir}/repos/base/run/platform_drv.inc
set build_components {
app/drill
app/sequence
app/stubby
core init timer
drivers/nic
drivers/rtc
lib/vfs/jitterentropy
lib/vfs/lxip
server/nic_router
server/vfs
test/libc_getaddrinfo
}
append_platform_drv_build_components
build $build_components
create_boot_directory
append config {
<config>
<parent-provides>
<service name="CPU"/>
<service name="IO_MEM"/>
<service name="IO_PORT"/>
<service name="IRQ"/>
<service name="LOG"/>
<service name="PD"/>
<service name="RM"/>
<service name="ROM"/>
</parent-provides>
<default-route>
<service name="Nic"> <child name="nic_router"/> </service>
<any-service> <parent/> <any-child/> </any-service>
</default-route>
<default caps="128"/>}
append_platform_drv_config
append config {
<start name="timer">
<resource name="RAM" quantum="1M"/>
<provides> <service name="Timer"/> </provides>
</start>
<start name="rtc_drv">
<resource name="RAM" quantum="1M"/>
<provides> <service name="Rtc"/> </provides>
</start>
<start name="nic_drv">
<binary name="ipxe_nic_drv"/>
<resource name="RAM" quantum="4M"/>
<provides> <service name="Nic"/> </provides>
</start>
<start name="nic_router" caps="200">
<resource name="RAM" quantum="10M"/>
<provides><service name="Nic"/></provides>
<config verbose="no">
<policy label_prefix="vfs" domain="default" />
<policy label_prefix="stubby" domain="dns" />
<uplink domain="uplink" />
<domain name="uplink">
<nat domain="dns" tcp-ports="64" udp-ports="64"/>
</domain>
<domain name="dns" interface="10.0.53.1/24">
<ip dst="10.0.1.0/24" domain="default"/>
<tcp dst="10.0.4.0/24"><permit-any domain="default"/></tcp>
<udp dst="10.0.4.0/24"><permit-any domain="default"/></udp>
<tcp dst="0.0.0.0/0"><permit-any domain="uplink"/></tcp>
<udp dst="0.0.0.0/0"><permit-any domain="uplink"/></udp>
</domain>
<domain name="default" interface="10.0.1.1/24">
<dhcp-server ip_first="10.0.1.2"
ip_last="10.0.1.200"
ip_lease_time_sec="360"
dns_server="10.0.53.2"/>
<ip dst="10.0.53.0/24" domain="dns"/>
<udp dst="10.0.53.0/24"><permit-any domain="dns"/></udp>
<tcp dst="0.0.0.0/0"><permit-any domain="uplink"/></tcp>
<udp dst="0.0.0.0/0"><permit-any domain="uplink"/></udp>
</domain>
</config>
<route>
<service name="Nic"> <child name="nic_drv"/> </service>
<any-service> <parent/> <any-child/> </any-service>
</route>
</start>
<start name="stubby" caps="512">
<resource name="RAM" quantum="32M"/>
<config>
<vfs>
<ram/>
<dir name="dev">
<log/> <null/> <rtc/>
<jitterentropy name="random"/>
</dir>
<dir name="socket">
<lxip ip_addr="10.0.53.2" netmask="255.255.255.0" gateway="10.0.53.1" nameserver="10.0.2.3"/>
</dir>
<inline name="stubby.yaml">
listen_addresses:
- 10.0.53.2
</inline>
</vfs>
<libc stdout="/dev/log" stderr="/dev/log" rtc="/dev/rtc" socket="/socket"/>
<env key="HOME" value="/"/>
<arg value="stubby"/>
<arg value="-C"/>
<arg value="/stubby.yaml"/>
</config>
</start>
<start name="vfs">
<resource name="RAM" quantum="32M"/>
<provides> <service name="File_system"/> </provides>
<config>
<vfs>
<dir name="socket"> <lxip dhcp="yes"/> </dir>
</vfs>
<default-policy writeable="yes" root="/"/>
</config>
</start>
<start name="application" caps="256">
<binary name="sequence"/>
<resource name="RAM" quantum="8M"/>
<config>
<start name="getaddrinfo">
<binary name="test-libc_getaddrinfo"/>
<config>
<vfs>
<fs/>
<dir name="dev"> <log/> </dir>
</vfs>
<libc stdout="/dev/log" socket="/socket"/>
<arg value="test-libc_getenv"/>
<arg value="genode.org"/>
<arg value="hypervisor.org"/>
<arg value="example.com"/>
</config>
</start>
<start name="ldns">
<binary name="drill"/>
<config>
<vfs>
<fs/>
<dir name="dev"> <log/> </dir>
</vfs>
<libc stdout="/dev/log" stderr="/dev/log" rtc="/dev/rtc" socket="/socket"/>
<arg value="drill"/>
<arg value="genode.org"/>
<arg value="@10.0.53.2"/>
</config>
</start>
</config>
</start>
</config>
}
install_config $config
set boot_modules {
core init ld.lib.so
drill
libc.lib.so libm.lib.so posix.lib.so
libcrypto.lib.so
libgetdns.lib.so
libssl.lib.so
lxip.lib.so vfs_lxip.lib.so
nic_router
ipxe_nic_drv
rtc_drv
sequence
stubby
timer
test-libc_getaddrinfo
vfs
vfs_jitterentropy.lib.so
}
# platform-specific modules
append_platform_drv_boot_modules
build_boot_image $boot_modules
append qemu_args " -nographic -net nic,model=e1000 -net user -net dump,file=[run_dir]/dump.pcap"
run_genode_until "child \"application\" exited with exit value 0.*\n" 120
if {[have_include "power_on/qemu"]} {
puts "\ntraffic dump at [run_dir]/dump.pcap"
}

203
run/stubby_deploy.run Normal file
View File

@@ -0,0 +1,203 @@
assert_spec x86
if {[have_spec linux]} {
puts "Platform is unsupported."
exit 0
}
create_boot_directory
proc current_pkg { pkg } { return $pkg/[_current_depot_archive_version pkg $pkg] }
import_from_depot [depot_user]/src/[base_src] \
[depot_user]/pkg/[drivers_nic_pkg] \
[depot_user]/src/report_rom \
[depot_user]/src/fs_rom \
[depot_user]/src/vfs \
[depot_user]/src/init \
[depot_user]/src/rtc_drv \
[depot_user]/src/posix \
[depot_user]/src/libc \
[depot_user]/src/vfs_lxip \
create_tar_from_depot_binaries [run_dir]/genode/depot.tar \
[depot_user]/pkg/nic_router-nat-dns \
install_config {
<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"/>
</parent-provides>
<default-route>
<service name="Nic"> <child name="dynamic"/> </service>
<service name="Report"> <child name="report_rom"/> </service>
<any-service> <parent/> <any-child/> </any-service>
</default-route>
<default caps="100"/>
<start name="timer">
<resource name="RAM" quantum="1M"/>
<provides> <service name="Timer"/> </provides>
</start>
<start name="nic_drv" caps="1000">
<resource name="RAM" quantum="32M" constrain_phys="yes"/>
<binary name="init"/>
<route>
<service name="ROM" label="config"> <parent label="drivers.config"/> </service>
<service name="Timer"> <child name="timer"/> </service>
<any-service> <parent/> </any-service>
</route>
<provides> <service name="Nic"/> </provides>
</start>
<start name="rtc_drv">
<resource name="RAM" quantum="6M"/>
<provides> <service name="Rtc"/> </provides>
</start>
<start name="report_rom">
<binary name="report_rom"/>
<resource name="RAM" quantum="1M"/>
<provides> <service name="Report"/> <service name="ROM"/> </provides>
<config verbose="no">
<policy label="depot_deploy -> blueprint" report="depot_query -> blueprint"/>
<policy label="depot_query -> query" report="depot_deploy -> query"/>
<policy label="dynamic -> config" report="depot_deploy -> init.config"/>
</config>
</start>
<start name="vfs">
<resource name="RAM" quantum="4M"/>
<provides> <service name="File_system"/> </provides>
<config>
<vfs> <tar name="depot.tar"/> </vfs>
<policy label="depot_query -> depot" root="/" />
<policy label="fs_rom -> " root="/" />
</config>
</start>
<start name="fs_rom">
<resource name="RAM" quantum="50M"/>
<provides> <service name="ROM"/> </provides>
<route>
<service name="File_system"> <child name="vfs"/> </service>
<any-service> <parent/> </any-service>
</route>
</start>
<start name="depot_query">
<resource name="RAM" quantum="1M"/>
<config query="rom">
<vfs> <dir name="depot"> <fs label="depot"/> </dir> </vfs>
</config>
<route>
<service name="ROM" label="query"> <child name="report_rom"/> </service>
<service name="File_system"> <child name="vfs"/> </service>
<service name="Report"> <child name="report_rom"/> </service>
<any-service> <parent/> <any-child/> </any-service>
</route>
</start>
<start name="ram_fs">
<resource name="RAM" quantum="8M"/>
<binary name="vfs"/>
<provides> <service name="File_system"/> </provides>
<config>
<vfs> <ram/> </vfs>
<default-policy root="/" writeable="yes"/>
</config>
</start>
<start name="depot_deploy">
<resource name="RAM" quantum="1M"/>
<config arch="} [depot_spec] {">
<static>
<parent-provides>
<service name="ROM"/>
<service name="RM"/>
<service name="CPU"/>
<service name="PD"/>
<service name="LOG"/>
<service name="File_system"/>
<service name="Nic"/>
<service name="Rtc"/>
<service name="Timer"/>
</parent-provides>
<service name="Nic">
<default-policy> <child name="nic_router"/> </default-policy> </service>
</static>
<common_routes>
<service name="ROM" label_last="ld.lib.so"> <parent/> </service>
<service name="ROM" label_last="init"> <parent/> </service>
<service name="CPU"> <parent/> </service>
<service name="PD"> <parent/> </service>
<service name="LOG"> <parent/> </service>
<service name="Timer"> <parent/> </service>
<service name="Rtc"> <parent/> </service>
<service name="Nic"> <parent/> </service>
</common_routes>
<start name="nic_router" pkg="} [depot_user]/pkg/[current_pkg nic_router-nat-dns] {">
<route>
<service name="RM"> <parent/> </service>
<service name="Rtc"> <parent/> </service>
<service name="Nic"> <parent/> </service>
</route>
</start>
</config>
<route>
<service name="ROM" label="blueprint"> <child name="report_rom"/> </service>
<service name="Report" label="query"> <child name="report_rom"/> </service>
<service name="Report"> <child name="report_rom"/> </service>
<any-service> <parent/> <any-child/> </any-service>
</route>
</start>
<start name="dynamic" caps="8000">
<resource name="RAM" quantum="160M"/>
<binary name="init"/>
<provides> <service name="Nic"/> </provides>
<route>
<service name="ROM" label_last="ld.lib.so"> <parent/> </service>
<service name="ROM" label_last="init"> <parent/> </service>
<service name="ROM" label="config"> <child name="report_rom"/> </service>
<service name="ROM"> <child name="fs_rom"/> </service>
<service name="Timer"> <child name="timer"/> </service>
<service name="File_system"> <child name="ram_fs"/> </service>
<service name="Nic"> <child name="nic_drv"/> </service>
<any-service> <parent/> <any-child/> </any-service>
</route>
</start>
<start name="test-libc_getaddrinfo" caps="256">
<resource name="RAM" quantum="32M"/>
<config>
<vfs>
<dir name="dev"> <log/> </dir>
<dir name="socket"> <lxip dhcp="yes"/> </dir>
</vfs>
<libc stdout="/dev/log" socket="/socket"/>
<arg value="test-libc_getenv"/>
<arg value="genode.org"/>
<arg value="genode-labs.com"/>
</config>
</start>
</config>}
append qemu_args -nographic
build { app/depot_query app/depot_deploy test/libc_getaddrinfo }
build_boot_image { depot_query depot_deploy test-libc_getaddrinfo }
run_genode_until "child \"test-libc_getaddrinfo\" exited with exit value 0.*\n" 120