mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-06 05:54:15 +00:00
ed52d5a211
Instead of holding SPEC-variable dependent files and directories inline within the repository structure, move them into 'spec' subdirectories at the corresponding levels, e.g.: repos/base/include/spec repos/base/mk/spec repos/base/lib/mk/spec repos/base/src/core/spec ... Moreover, this commit removes the 'platform' directories. That term was used in an overloaded sense. All SPEC-relative 'platform' directories are now named 'spec'. Other files, like for instance those related to the kernel/architecture specific startup library, where moved from 'platform' directories to explicit, more meaningful places like e.g.: 'src/lib/startup'. Fix #1673
141 lines
3.3 KiB
PHP
141 lines
3.3 KiB
PHP
proc have_platform_drv {} {
|
|
if {[have_spec linux]} {
|
|
return 0
|
|
}
|
|
|
|
return [expr [have_spec arndale] \
|
|
|| [have_spec imx53] \
|
|
|| [have_spec rpi] \
|
|
|| [have_spec odroid_x2] \
|
|
|| [have_spec x86]]
|
|
}
|
|
|
|
proc append_platform_drv_build_components {} {
|
|
global build_components
|
|
|
|
lappend_if [have_platform_drv] build_components drivers/platform
|
|
lappend_if [have_spec acpi] build_components drivers/acpi
|
|
lappend_if [have_spec acpi] build_components server/report_rom
|
|
lappend_if [have_spec nova] build_components drivers/platform/spec/x86/device_pd
|
|
}
|
|
|
|
proc append_platform_drv_boot_modules {} {
|
|
global boot_modules
|
|
|
|
lappend_if [have_platform_drv] boot_modules platform_drv
|
|
lappend_if [have_spec acpi] boot_modules acpi_drv
|
|
lappend_if [have_spec acpi] boot_modules report_rom
|
|
lappend_if [have_spec nova] boot_modules device_pd
|
|
}
|
|
|
|
proc platform_drv_policy {} {
|
|
|
|
if ([have_spec x86]) {
|
|
return {
|
|
<policy label="ps2_drv"> <device name="PS2"/> </policy>
|
|
<policy label="nic_drv"> <pci class="ETHERNET"/> </policy>
|
|
<policy label="fb_drv"> <pci class="VGA"/> </policy>
|
|
<policy label="wifi_drv"> <pci class="WIFI"/> </policy>
|
|
<policy label="usb_drv"> <pci class="USB"/> </policy>
|
|
<policy label="ahci_drv"> <pci class="AHCI"/> </policy>
|
|
<policy label="audio_drv"> <pci class="AUDIO"/> <pci class="HDAUDIO"/> </policy>}
|
|
} else {
|
|
return {}
|
|
}
|
|
}
|
|
|
|
proc platform_drv_priority {} { return "" }
|
|
|
|
proc append_platform_drv_config {} {
|
|
global config
|
|
|
|
if {[have_spec acpi]} {
|
|
|
|
append config "
|
|
<start name=\"acpi_drv\" [platform_drv_priority]>"
|
|
|
|
append config {
|
|
<resource name="RAM" quantum="2M"/>
|
|
<route>
|
|
<service name="LOG"> <parent/> </service>
|
|
<service name="IO_MEM"> <parent/> </service>
|
|
<service name="RM"> <parent/> </service>
|
|
<service name="Report"> <child name="acpi_report_rom"/> </service>
|
|
</route>
|
|
</start>}
|
|
|
|
append config "
|
|
<start name=\"acpi_report_rom\" [platform_drv_priority]>"
|
|
|
|
append config {
|
|
<binary name="report_rom"/>
|
|
<resource name="RAM" quantum="2M"/>
|
|
<provides>
|
|
<service name="ROM" />
|
|
<service name="Report" />
|
|
</provides>
|
|
<config>
|
|
<rom> <policy label="platform_drv -> acpi" report="acpi_drv -> acpi"/> </rom>
|
|
</config>
|
|
<route>
|
|
<service name="LOG"> <parent/> </service>
|
|
<service name="SIGNAL"> <parent/> </service>
|
|
<service name="CAP"> <parent/> </service>
|
|
<service name="RM"> <parent/> </service>
|
|
</route>
|
|
</start>}
|
|
|
|
}
|
|
|
|
if {[have_platform_drv]} {
|
|
|
|
append config "
|
|
<start name=\"platform_drv\" [platform_drv_priority]>"
|
|
|
|
append config {
|
|
<resource name="RAM" quantum="3M" constrain_phys="yes"/>
|
|
<provides>
|
|
<service name="Platform"/>}
|
|
|
|
append_if [have_spec arm] config {
|
|
<service name="Regulator"/>}
|
|
|
|
append config {
|
|
</provides>
|
|
<route>}
|
|
|
|
append_if [have_spec acpi] config {
|
|
<service name="ROM">
|
|
<if-arg key="label" value="acpi"/> <child name="acpi_report_rom"/>
|
|
</service>}
|
|
|
|
append_if [have_spec rpi] config {
|
|
<service name="Timer"> <any-child/> </service>}
|
|
|
|
append config {
|
|
<any-service> <parent/> </any-service>
|
|
</route>}
|
|
|
|
if {[have_spec acpi] || [have_spec arm]} {
|
|
|
|
append config {
|
|
<config>}
|
|
|
|
} else {
|
|
|
|
append config {
|
|
<config acpi="no">}
|
|
|
|
}
|
|
|
|
append config [platform_drv_policy]
|
|
|
|
append config {
|
|
</config>
|
|
</start>}
|
|
|
|
}
|
|
|
|
return $config
|
|
}
|