gems: import run-script ingredients from depot

This patch adjusts the interactive scenarios of the gems repository to
use the depot. This has three immediate benefits. First, once the depot
is populated with binary archives, the start time of the scenarios
becomes very quick because most dependency checks and build steps are
side-stepped. Second, the run scripts become more versatile. In
particular, run scripts that were formerly supported on base-linux only
(nit_fader, decorator, menu_view) have become usable on all base
platforms that have a 'drivers_interactive' package defined. Finally,
the run scripts have become much shorter.

Issue #2339
This commit is contained in:
Norman Feske 2017-04-14 19:19:39 +02:00 committed by Christian Helmuth
parent 015d319fa7
commit 4f19e4b6af
7 changed files with 214 additions and 461 deletions

View File

@ -1,50 +1,51 @@
#
# Build
#
if {![have_spec linux]} {
puts "Runs on Linux only"
exit 0
}
set build_components {
core init drivers/timer drivers/framebuffer
server/dynamic_rom server/report_rom server/nitpicker app/decorator
}
build $build_components
create_boot_directory create_boot_directory
# import_from_depot genodelabs/src/[base_src] \
# Generate config genodelabs/pkg/[drivers_interactive_pkg] \
# genodelabs/src/init \
genodelabs/src/report_rom \
genodelabs/src/dynamic_rom \
genodelabs/src/nitpicker \
genodelabs/src/libc \
genodelabs/src/libpng \
genodelabs/src/zlib
append config { install_config {
<config> <config>
<parent-provides> <parent-provides>
<service name="ROM"/> <service name="ROM"/>
<service name="RAM"/> <service name="RAM"/>
<service name="CPU"/> <service name="CPU"/>
<service name="PD"/> <service name="PD"/>
<service name="RM"/>
<service name="LOG"/> <service name="LOG"/>
<service name="IRQ"/> <service name="IRQ"/>
<service name="IO_MEM"/> <service name="IO_MEM"/>
<service name="IO_PORT"/> <service name="IO_PORT"/>
</parent-provides> </parent-provides>
<default-route> <default-route>
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</default-route> </default-route>
<start name="fb_sdl">
<resource name="RAM" quantum="4M"/>
<provides>
<service name="Input"/>
<service name="Framebuffer"/>
</provides>
</start>
<start name="timer"> <start name="timer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Timer"/></provides> <provides><service name="Timer"/></provides>
</start> </start>
<start name="drivers">
<resource name="RAM" quantum="32M"/>
<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="Input"/> <service name="Framebuffer"/>
</provides>
</start>
<start name="report_rom"> <start name="report_rom">
<resource name="RAM" quantum="2M"/> <resource name="RAM" quantum="2M"/>
<provides> <service name="ROM" /> <provides> <service name="ROM" />
@ -53,6 +54,7 @@ append config {
<policy label="decorator -> pointer" report="nitpicker -> pointer"/> <policy label="decorator -> pointer" report="nitpicker -> pointer"/>
</config> </config>
</start> </start>
<start name="nitpicker"> <start name="nitpicker">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Nitpicker"/></provides> <provides><service name="Nitpicker"/></provides>
@ -62,6 +64,7 @@ append config {
<default-policy domain="default"/> <default-policy domain="default"/>
</config> </config>
</start> </start>
<start name="dynamic_rom"> <start name="dynamic_rom">
<resource name="RAM" quantum="4M"/> <resource name="RAM" quantum="4M"/>
<provides><service name="ROM"/></provides> <provides><service name="ROM"/></provides>
@ -152,6 +155,7 @@ append config {
</rom> </rom>
</config> </config>
</start> </start>
<start name="decorator"> <start name="decorator">
<resource name="RAM" quantum="4M"/> <resource name="RAM" quantum="4M"/>
<route> <route>
@ -166,17 +170,8 @@ append config {
</start> </start>
</config>} </config>}
install_config $config build { app/decorator }
# build_boot_image { decorator }
# Boot modules
#
# generic modules
set boot_modules {
core ld.lib.so init timer dynamic_rom report_rom fb_sdl nitpicker decorator
}
build_boot_image $boot_modules
run_genode_until forever run_genode_until forever

View File

@ -1,40 +1,17 @@
#
# Build
#
if {[have_spec odroid_xu]} {
puts "Run script does not support this platform."
exit 0
}
set build_components {
core init
drivers/timer
app/decorator
server/nitpicker server/report_rom
test/decorator_stress
drivers/framebuffer drivers/input
}
source ${genode_dir}/repos/base/run/platform_drv.inc
append_platform_drv_build_components
lappend_if [need_usb_hid] build_components drivers/usb
lappend_if [have_spec gpio] build_components drivers/gpio
build $build_components
create_boot_directory create_boot_directory
# import_from_depot genodelabs/src/[base_src] \
# Generate config genodelabs/pkg/[drivers_interactive_pkg] \
# genodelabs/src/init \
genodelabs/src/report_rom \
genodelabs/src/dynamic_rom \
genodelabs/src/nitpicker \
genodelabs/src/decorator \
genodelabs/src/libc \
genodelabs/src/libpng \
genodelabs/src/zlib
proc gpio_drv { } { if {[have_spec rpi] && [have_spec hw]} { return hw_gpio_drv } install_config {
if {[have_spec rpi] && [have_spec foc]} { return foc_gpio_drv }
return gpio_drv }
append config {
<config> <config>
<parent-provides> <parent-provides>
<service name="ROM"/> <service name="ROM"/>
@ -47,59 +24,29 @@ append config {
<service name="CPU"/> <service name="CPU"/>
<service name="LOG"/> <service name="LOG"/>
</parent-provides> </parent-provides>
<default-route> <default-route>
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</default-route>} </default-route>
append_if [have_spec sdl] config {
<start name="fb_sdl">
<resource name="RAM" quantum="4M"/>
<provides>
<service name="Input"/>
<service name="Framebuffer"/>
</provides>
</start>}
append_platform_drv_config
append_if [have_spec framebuffer] config {
<start name="fb_drv">
<resource name="RAM" quantum="4M"/>
<provides><service name="Framebuffer"/></provides>
</start>}
append_if [have_spec gpio] config "
<start name=\"[gpio_drv]\">
<resource name=\"RAM\" quantum=\"4M\"/>
<provides><service name=\"Gpio\"/></provides>
<config/>
</start>"
append_if [have_spec imx53] config {
<start name="input_drv">
<resource name="RAM" quantum="1M"/>
<provides><service name="Input"/></provides>
<config/>
</start> }
append_if [have_spec ps2] config {
<start name="ps2_drv">
<resource name="RAM" quantum="1M"/>
<provides><service name="Input"/></provides>
</start>}
append_if [need_usb_hid] config {
<start name="usb_drv">
<resource name="RAM" quantum="12M"/>
<provides><service name="Input"/></provides>
<config ehci="yes" uhci="yes" xhci="no"> <hid/> </config>
</start> }
append config {
<start name="timer"> <start name="timer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Timer"/></provides> <provides><service name="Timer"/></provides>
</start> </start>
<start name="drivers">
<resource name="RAM" quantum="32M"/>
<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="Input"/> <service name="Framebuffer"/>
</provides>
</start>
<start name="nitpicker"> <start name="nitpicker">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Nitpicker"/></provides> <provides><service name="Nitpicker"/></provides>
@ -113,6 +60,7 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="report_rom"> <start name="report_rom">
<resource name="RAM" quantum="2M"/> <resource name="RAM" quantum="2M"/>
<provides> <service name="ROM" /> <provides> <service name="ROM" />
@ -124,6 +72,7 @@ append config {
report="test-decorator_stress -> window_layout"/> report="test-decorator_stress -> window_layout"/>
</config> </config>
</start> </start>
<start name="test-decorator_stress"> <start name="test-decorator_stress">
<resource name="RAM" quantum="2M"/> <resource name="RAM" quantum="2M"/>
<route> <route>
@ -131,6 +80,7 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="decorator"> <start name="decorator">
<resource name="RAM" quantum="8M"/> <resource name="RAM" quantum="8M"/>
<route> <route>
@ -144,34 +94,9 @@ append config {
</start> </start>
</config>} </config>}
install_config $config build { test/decorator_stress }
build_boot_image { test-decorator_stress }
#
# Boot modules
#
# generic modules
set boot_modules {
core ld.lib.so init
timer
decorator
nitpicker report_rom
test-decorator_stress
libc.lib.so libm.lib.so
}
# platform-specific modules
append_platform_drv_boot_modules
lappend_if [have_spec linux] boot_modules fb_sdl
lappend_if [have_spec ps2] boot_modules ps2_drv
lappend_if [have_spec framebuffer] boot_modules fb_drv
lappend_if [need_usb_hid] boot_modules usb_drv
lappend_if [have_spec gpio] boot_modules [gpio_drv]
lappend_if [have_spec imx53] boot_modules input_drv
build_boot_image $boot_modules
append qemu_args " -m 256 " append qemu_args " -m 256 "

View File

@ -1,29 +1,19 @@
#
# Build
#
set build_components {
core init drivers/timer drivers/framebuffer drivers/input
server/dynamic_rom server/nitpicker server/report_rom
app/pointer app/menu_view
app/scout app/launchpad app/launcher test/nitpicker
server/nit_fader server/rom_filter server/wm app/decorator
app/floating_window_layouter app/status_bar server/nit_fb
app/backdrop app/xray_trigger
}
source ${genode_dir}/repos/base/run/platform_drv.inc
append_platform_drv_build_components
build $build_components
create_boot_directory create_boot_directory
# import_from_depot genodelabs/src/[base_src] \
# Generate config genodelabs/pkg/[drivers_interactive_pkg] \
# genodelabs/pkg/wm \
genodelabs/raw/genode_bg \
genodelabs/pkg/backdrop \
genodelabs/src/demo \
genodelabs/src/init \
genodelabs/src/nitpicker \
genodelabs/src/nit_fb \
genodelabs/src/nit_fader \
genodelabs/src/rom_filter \
genodelabs/src/menu_view
append config { install_config {
<config> <config>
<parent-provides> <parent-provides>
<service name="ROM"/> <service name="ROM"/>
@ -36,40 +26,29 @@ append config {
<service name="IO_MEM"/> <service name="IO_MEM"/>
<service name="IO_PORT"/> <service name="IO_PORT"/>
</parent-provides> </parent-provides>
<default-route> <default-route>
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</default-route>} </default-route>
append_if [have_spec sdl] config {
<start name="fb_sdl">
<resource name="RAM" quantum="4M"/>
<provides>
<service name="Input"/>
<service name="Framebuffer"/>
</provides>
<config width="640" height="480"/>
</start>}
append_platform_drv_config
append_if [have_spec framebuffer] config {
<start name="fb_drv">
<resource name="RAM" quantum="4M"/>
<provides><service name="Framebuffer"/></provides>
<config buffered="yes" />
</start>}
append_if [have_spec ps2] config {
<start name="ps2_drv">
<resource name="RAM" quantum="1M"/>
<provides><service name="Input"/></provides>
</start>}
append config {
<start name="timer"> <start name="timer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Timer"/></provides> <provides><service name="Timer"/></provides>
</start> </start>
<start name="drivers">
<resource name="RAM" quantum="32M"/>
<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="Input"/> <service name="Framebuffer"/>
</provides>
</start>
<start name="nitpicker"> <start name="nitpicker">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Nitpicker"/></provides> <provides><service name="Nitpicker"/></provides>
@ -97,6 +76,7 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="pointer"> <start name="pointer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<route> <route>
@ -188,9 +168,8 @@ append config {
<start name="decorator"> <start name="decorator">
<binary name="decorator"/> <binary name="decorator"/>
<resource name="RAM" quantum="8M"/> <resource name="RAM" quantum="8M"/>
<configfile name="decorator.config"/>
<route> <route>
<service name="ROM" label="decorator.config"> <service name="ROM" label="config">
<child name="decorator_config"/> </service> <child name="decorator_config"/> </service>
<service name="ROM" label="window_layout"> <service name="ROM" label="window_layout">
<child name="report_rom"/> </service> <child name="report_rom"/> </service>
@ -286,29 +265,10 @@ append config {
</start> </start>
</config>} </config>}
install_config $config build { app/launcher test/nitpicker app/status_bar app/xray_trigger }
# build_boot_image { testnit launcher xray_trigger status_bar }
# Boot modules
#
# generic modules append qemu_args " -m 256 "
set boot_modules {
core init timer dynamic_rom nitpicker pointer menu_view
ld.lib.so libpng.lib.so libc.lib.so libm.lib.so zlib.lib.so
menu_view_styles.tar
scout launchpad testnit
nit_fader report_rom launcher rom_filter xray_trigger
decorator wm floating_window_layouter status_bar nit_fb backdrop
}
# platform-specific modules
append_platform_drv_boot_modules
lappend_if [have_spec linux] boot_modules fb_sdl
lappend_if [have_spec ps2] boot_modules ps2_drv
lappend_if [have_spec framebuffer] boot_modules fb_drv
build_boot_image $boot_modules
run_genode_until forever run_genode_until forever

View File

@ -1,27 +1,16 @@
#
# Build
#
if {![have_spec linux]} {
puts "Runs on Linux only"
exit 0
}
set build_components {
core init drivers/timer drivers/framebuffer
server/dynamic_rom server/nitpicker
app/pointer app/menu_view
app/scout
}
build $build_components
create_boot_directory create_boot_directory
# import_from_depot genodelabs/src/[base_src] \
# Generate config genodelabs/pkg/[drivers_interactive_pkg] \
# genodelabs/src/init \
genodelabs/src/dynamic_rom \
genodelabs/src/nitpicker \
genodelabs/src/demo \
genodelabs/src/libc \
genodelabs/src/libpng \
genodelabs/src/zlib
append config { install_config {
<config> <config>
<parent-provides> <parent-provides>
<service name="PD"/> <service name="PD"/>
@ -34,20 +23,29 @@ append config {
<service name="IO_MEM"/> <service name="IO_MEM"/>
<service name="IO_PORT"/> <service name="IO_PORT"/>
</parent-provides> </parent-provides>
<default-route> <default-route>
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</default-route> </default-route>
<start name="fb_sdl">
<resource name="RAM" quantum="4M"/>
<provides>
<service name="Input"/>
<service name="Framebuffer"/>
</provides>
</start>
<start name="timer"> <start name="timer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Timer"/></provides> <provides><service name="Timer"/></provides>
</start> </start>
<start name="drivers">
<resource name="RAM" quantum="32M"/>
<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="Input"/> <service name="Framebuffer"/>
</provides>
</start>
<start name="nitpicker"> <start name="nitpicker">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Nitpicker"/></provides> <provides><service name="Nitpicker"/></provides>
@ -59,6 +57,7 @@ append config {
<default-policy domain="default"/> <default-policy domain="default"/>
</config> </config>
</start> </start>
<start name="pointer"> <start name="pointer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<route> <route>
@ -66,6 +65,7 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="dynamic_rom"> <start name="dynamic_rom">
<resource name="RAM" quantum="4M"/> <resource name="RAM" quantum="4M"/>
<provides><service name="ROM"/></provides> <provides><service name="ROM"/></provides>
@ -116,6 +116,7 @@ append config {
</rom> </rom>
</config> </config>
</start> </start>
<start name="menu_view"> <start name="menu_view">
<resource name="RAM" quantum="5M"/> <resource name="RAM" quantum="5M"/>
<config xpos="200" ypos="100"> <config xpos="200" ypos="100">
@ -130,25 +131,14 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="scout"> <start name="scout">
<resource name="RAM" quantum="64M" /> <resource name="RAM" quantum="64M" />
</start> </start>
</config>} </config>}
install_config $config build { app/menu_view }
# build_boot_image { menu_view menu_view_styles.tar }
# Boot modules
#
# generic modules
set boot_modules {
core ld.lib.so init timer dynamic_rom fb_sdl nitpicker pointer menu_view
libpng.lib.so libc.lib.so libm.lib.so zlib.lib.so
menu_view_styles.tar
scout
}
build_boot_image $boot_modules
run_genode_until forever run_genode_until forever

View File

@ -1,26 +1,12 @@
#
# Build
#
if {![have_spec linux]} {
puts "Runs on Linux only"
exit 0
}
set build_components {
core init
drivers/timer
server/nitpicker server/dynamic_rom app/nano3d
drivers/framebuffer
app/backdrop
}
build $build_components
create_boot_directory create_boot_directory
# import_from_depot genodelabs/src/[base_src] \
# Generate config genodelabs/pkg/[drivers_interactive_pkg] \
# genodelabs/raw/genode_bg \
genodelabs/pkg/backdrop \
genodelabs/src/init \
genodelabs/src/dynamic_rom \
genodelabs/src/nitpicker
append config { append config {
<config> <config>
@ -35,15 +21,21 @@ append config {
<service name="CPU"/> <service name="CPU"/>
<service name="LOG"/> <service name="LOG"/>
</parent-provides> </parent-provides>
<default-route> <default-route>
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</default-route> </default-route>
<start name="fb_sdl"> <start name="drivers">
<resource name="RAM" quantum="4M"/> <resource name="RAM" quantum="32M"/>
<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> <provides>
<service name="Input"/> <service name="Input"/> <service name="Framebuffer"/>
<service name="Framebuffer"/>
</provides> </provides>
</start> </start>
@ -120,27 +112,8 @@ append config {
install_config $config install_config $config
# copy backdrop PNG images to bin directory build { app/nano3d }
foreach file { genode_logo.png grid.png } {
file copy -force [genode_dir]/repos/gems/src/app/backdrop/$file bin/ }
# build_boot_image { nano3d }
# Boot modules
#
# generic modules
set boot_modules {
core ld.lib.so init
timer
nitpicker dynamic_rom nano3d
backdrop
libpng.lib.so libc.lib.so libm.lib.so zlib.lib.so
genode_logo.png grid.png
}
# platform-specific modules
lappend_if [have_spec linux] boot_modules fb_sdl
build_boot_image $boot_modules
run_genode_until forever run_genode_until forever

View File

@ -1,51 +1,48 @@
#
# Build
#
if {![have_spec linux]} {
puts "Runs on Linux only"
exit 0
}
set build_components {
core init drivers/timer drivers/framebuffer
server/dynamic_rom server/nitpicker app/scout server/nit_fader
app/pointer
}
build $build_components
create_boot_directory create_boot_directory
# import_from_depot genodelabs/src/[base_src] \
# Generate config genodelabs/pkg/[drivers_interactive_pkg] \
# genodelabs/src/init \
genodelabs/src/dynamic_rom \
genodelabs/src/nitpicker \
genodelabs/src/demo
append config { install_config {
<config> <config>
<parent-provides> <parent-provides>
<service name="ROM"/> <service name="ROM"/>
<service name="RAM"/> <service name="RAM"/>
<service name="CPU"/> <service name="CPU"/>
<service name="PD"/> <service name="PD"/>
<service name="RM"/>
<service name="LOG"/> <service name="LOG"/>
<service name="IRQ"/> <service name="IRQ"/>
<service name="IO_MEM"/> <service name="IO_MEM"/>
<service name="IO_PORT"/> <service name="IO_PORT"/>
</parent-provides> </parent-provides>
<default-route> <default-route>
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</default-route> </default-route>
<start name="fb_sdl">
<resource name="RAM" quantum="4M"/>
<provides>
<service name="Input"/>
<service name="Framebuffer"/>
</provides>
</start>
<start name="timer"> <start name="timer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Timer"/></provides> <provides><service name="Timer"/></provides>
</start> </start>
<start name="drivers">
<resource name="RAM" quantum="32M"/>
<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="Input"/> <service name="Framebuffer"/>
</provides>
</start>
<start name="nitpicker"> <start name="nitpicker">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Nitpicker"/></provides> <provides><service name="Nitpicker"/></provides>
@ -57,6 +54,7 @@ append config {
<default-policy domain="default"/> <default-policy domain="default"/>
</config> </config>
</start> </start>
<start name="pointer"> <start name="pointer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<route> <route>
@ -64,6 +62,7 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="dynamic_rom"> <start name="dynamic_rom">
<resource name="RAM" quantum="4M"/> <resource name="RAM" quantum="4M"/>
<provides><service name="ROM"/></provides> <provides><service name="ROM"/></provides>
@ -89,6 +88,7 @@ append config {
</rom> </rom>
</config> </config>
</start> </start>
<start name="nit_fader"> <start name="nit_fader">
<resource name="RAM" quantum="5M"/> <resource name="RAM" quantum="5M"/>
<provides><service name="Nitpicker"/></provides> <provides><service name="Nitpicker"/></provides>
@ -101,6 +101,7 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="scout"> <start name="scout">
<resource name="RAM" quantum="8M"/> <resource name="RAM" quantum="8M"/>
<route> <route>
@ -108,6 +109,7 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="scout2"> <start name="scout2">
<binary name="scout" /> <binary name="scout" />
<resource name="RAM" quantum="8M"/> <resource name="RAM" quantum="8M"/>
@ -118,17 +120,8 @@ append config {
</start> </start>
</config>} </config>}
install_config $config build { server/nit_fader }
# build_boot_image { nit_fader }
# Boot modules
#
# generic modules
set boot_modules {
core ld.lib.so init timer dynamic_rom fb_sdl nitpicker nit_fader scout pointer
}
build_boot_image $boot_modules
run_genode_until forever run_genode_until forever

View File

@ -1,42 +1,21 @@
#
# Build
#
if {[have_spec odroid_xu]} {
puts "Run script not supported on this platform."; exit 0 }
set build_components {
core init
drivers/timer
server/wm app/decorator app/floating_window_layouter
server/nitpicker app/pointer server/report_rom
drivers/framebuffer drivers/input
test/nitpicker
app/backdrop
app/launchpad
server/nit_fb
}
source ${genode_dir}/repos/base/run/platform_drv.inc
lappend_if [need_usb_hid] build_components drivers/usb
lappend_if [have_spec gpio] build_components drivers/gpio
proc gpio_drv { } { if {[have_spec rpi] && [have_spec hw]} { return hw_gpio_drv }
if {[have_spec rpi] && [have_spec foc]} { return foc_gpio_drv }
return gpio_drv }
append_platform_drv_build_components
build $build_components
create_boot_directory create_boot_directory
# #
# Generate config # To use the themed decorator instead of the default one, replace 'pkg/wm'
# with 'pkg/themed_wm'.
# #
append config { import_from_depot genodelabs/src/[base_src] \
genodelabs/pkg/[drivers_interactive_pkg] \
genodelabs/pkg/wm \
genodelabs/raw/genode_bg \
genodelabs/pkg/backdrop \
genodelabs/src/demo \
genodelabs/src/init \
genodelabs/src/nitpicker \
genodelabs/src/nit_fb
install_config {
<config prio_levels="2"> <config prio_levels="2">
<parent-provides> <parent-provides>
<service name="ROM"/> <service name="ROM"/>
@ -51,57 +30,26 @@ append config {
</parent-provides> </parent-provides>
<default-route> <default-route>
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</default-route>} </default-route>
append_if [have_spec sdl] config {
<start name="fb_sdl">
<resource name="RAM" quantum="4M"/>
<provides>
<service name="Input"/>
<service name="Framebuffer"/>
</provides>
</start>}
append_platform_drv_config
append_if [have_spec framebuffer] config {
<start name="fb_drv">
<resource name="RAM" quantum="4M"/>
<provides><service name="Framebuffer"/></provides>
</start>}
append_if [have_spec gpio] config "
<start name=\"[gpio_drv]\">
<resource name=\"RAM\" quantum=\"4M\"/>
<provides><service name=\"Gpio\"/></provides>
<config/>
</start>"
append_if [have_spec imx53] config {
<start name="input_drv">
<resource name="RAM" quantum="1M"/>
<provides><service name="Input"/></provides>
<config/>
</start> }
append_if [have_spec ps2] config {
<start name="ps2_drv">
<resource name="RAM" quantum="1M"/>
<provides><service name="Input"/></provides>
</start>}
append_if [need_usb_hid] config {
<start name="usb_drv">
<resource name="RAM" quantum="12M"/>
<provides><service name="Input"/></provides>
<config ehci="yes" uhci="yes" xhci="no"> <hid/> </config>
</start> }
append config {
<start name="timer"> <start name="timer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<provides><service name="Timer"/></provides> <provides><service name="Timer"/></provides>
</start> </start>
<start name="drivers">
<resource name="RAM" quantum="32M"/>
<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="Input"/> <service name="Framebuffer"/>
</provides>
</start>
<start name="nitpicker"> <start name="nitpicker">
<resource name="RAM" quantum="4M"/> <resource name="RAM" quantum="4M"/>
<provides><service name="Nitpicker"/></provides> <provides><service name="Nitpicker"/></provides>
@ -113,6 +61,7 @@ append config {
<default-policy domain="default"/> <default-policy domain="default"/>
</config> </config>
</start> </start>
<start name="pointer"> <start name="pointer">
<resource name="RAM" quantum="1M"/> <resource name="RAM" quantum="1M"/>
<route> <route>
@ -120,6 +69,7 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="wm"> <start name="wm">
<resource name="RAM" quantum="24M"/> <resource name="RAM" quantum="24M"/>
<binary name="init"/> <binary name="init"/>
@ -130,6 +80,7 @@ append config {
<any-service> <parent/> <any-child/> </any-service> <any-service> <parent/> <any-child/> </any-service>
</route> </route>
</start> </start>
<start name="launchpad" priority="-1"> <start name="launchpad" priority="-1">
<resource name="RAM" quantum="20M"/> <resource name="RAM" quantum="20M"/>
<config> <config>
@ -149,6 +100,7 @@ append config {
</any-service> </any-service>
</route> </route>
</start> </start>
<start name="backdrop" priority="-1"> <start name="backdrop" priority="-1">
<resource name="RAM" quantum="24M"/> <resource name="RAM" quantum="24M"/>
<config> <config>
@ -167,6 +119,7 @@ append config {
</any-service> </any-service>
</route> </route>
</start> </start>
<start name="wm_backdrop" priority="-1"> <start name="wm_backdrop" priority="-1">
<binary name="backdrop" /> <binary name="backdrop" />
<resource name="RAM" quantum="24M"/> <resource name="RAM" quantum="24M"/>
@ -187,43 +140,7 @@ append config {
</start> </start>
</config>} </config>}
install_config $config build_boot_image { }
# copy backdrop PNG images to bin directory
foreach file { genode_logo.png grid.png } {
file copy -force [genode_dir]/repos/gems/src/app/backdrop/$file bin/ }
file copy -force [genode_dir]/repos/gems/src/server/wm/wm.config bin/
#
# Boot modules
#
# generic modules
set boot_modules {
core ld.lib.so init
timer
wm decorator wm.config
floating_window_layouter
nitpicker pointer report_rom
backdrop
testnit launchpad nit_fb
libpng.lib.so libc.lib.so libm.lib.so zlib.lib.so
genode_logo.png grid.png
}
# platform-specific modules
append_platform_drv_boot_modules
lappend_if [have_spec linux] boot_modules fb_sdl
lappend_if [have_spec ps2] boot_modules ps2_drv
lappend_if [have_spec framebuffer] boot_modules fb_drv
lappend_if [need_usb_hid] boot_modules usb_drv
lappend_if [have_spec gpio] boot_modules [gpio_drv]
lappend_if [have_spec imx53] boot_modules input_drv
build_boot_image $boot_modules
append qemu_args " -m 256 " append qemu_args " -m 256 "