blob: f5b851fb6407ea9c8e05ae3fa5b15f2d3e89406f [file] [log] [blame]
# Copyright 2019 The Fuchsia Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
import("//build/bind/bind.gni")
import("//build/components.gni")
import("//build/drivers.gni")
import("//build/test.gni")
driver_bind_rules("intel-display-bind") {
rules = "meta/intel-display.bind"
tests = "meta/intel-display-bind-tests.json"
deps = [
"//sdk/fidl/fuchsia.hardware.pci:fuchsia.hardware.pci_bindlib",
"//src/devices/bind/fuchsia.acpi",
"//src/devices/bind/fuchsia.pci",
]
}
source_set("common_srcs") {
public_configs = [ "//build/config/fuchsia:enable_zircon_asserts" ]
sources = [
"acpi-memory-region-util.h",
"acpi-memory-region.cc",
"acpi-memory-region.h",
"clock/cdclk.cc",
"clock/cdclk.h",
"ddi-aux-channel.cc",
"ddi-aux-channel.h",
"ddi-physical-layer-manager.cc",
"ddi-physical-layer-manager.h",
"ddi-physical-layer.cc",
"ddi-physical-layer.h",
"ddi.cc",
"ddi.h",
"display-device.cc",
"display-device.h",
"display-timing-mode-conversion.h",
"dp-aux-channel-impl.cc",
"dp-aux-channel-impl.h",
"dp-aux-channel.h",
"dp-capabilities.cc",
"dp-capabilities.h",
"dp-display.cc",
"dp-display.h",
"dpcd.h",
"dpll-config.cc",
"dpll-config.h",
"dpll.cc",
"dpll.h",
"edid-reader.cc",
"edid-reader.h",
"firmware-bridge.cc",
"firmware-bridge.h",
"fuse-config.cc",
"fuse-config.h",
"gtt.cc",
"gtt.h",
"hardware-common.h",
"hdmi-display.cc",
"hdmi-display.h",
"i2c/gmbus-gpio.h",
"i2c/gmbus-i2c.cc",
"i2c/gmbus-i2c.h",
"igd.cc",
"igd.h",
"intel-display-driver.cc",
"intel-display-driver.h",
"intel-display.cc",
"intel-display.h",
"interrupts.cc",
"interrupts.h",
"pch-engine.cc",
"pch-engine.h",
"pci-ids.h",
"pipe-manager.cc",
"pipe-manager.h",
"pipe.cc",
"pipe.h",
"power-controller.cc",
"power-controller.h",
"power.cc",
"power.h",
"registers-ddi-phy-tiger-lake.h",
"registers-ddi.h",
"registers-dpll.h",
"registers-gmbus.h",
"registers-gt-mailbox.h",
"registers-pch.h",
"registers-pipe-scaler.h",
"registers-pipe.h",
"registers-transcoder.h",
"registers-typec.h",
"registers.h",
"tiling.h",
]
public_deps = [
":intel-display-bind",
"//sdk/banjo/fuchsia.hardware.intelgpucore:fuchsia.hardware.intelgpucore_banjo_cpp",
"//sdk/fidl/fuchsia.boot:fuchsia.boot_cpp",
"//sdk/fidl/fuchsia.hardware.backlight:fuchsia.hardware.backlight_cpp",
"//sdk/fidl/fuchsia.hardware.sysmem:fuchsia.hardware.sysmem_cpp",
"//sdk/fidl/fuchsia.kernel:fuchsia.kernel_cpp",
"//sdk/fidl/fuchsia.sysmem2:fuchsia.sysmem2_cpp",
"//sdk/fidl/fuchsia.system.state:fuchsia.system.state_cpp",
"//sdk/lib/async-loop:async-loop-cpp",
"//sdk/lib/driver/compat/cpp",
"//sdk/lib/driver/component/cpp",
"//sdk/lib/driver/incoming/cpp",
"//sdk/lib/driver/logging/cpp",
"//sdk/lib/driver/mmio/cpp",
"//sdk/lib/driver/runtime:driver_runtime_cpp",
"//sdk/lib/stdcompat",
"//sdk/lib/zbi-format",
"//src/devices/bind/fuchsia:fuchsia_cpp",
"//src/devices/bind/fuchsia.display:fuchsia.display_cpp",
"//src/devices/bind/fuchsia.intel.platform.gpucore:fuchsia.intel.platform.gpucore_cpp",
"//src/devices/bind/fuchsia.sysmem.heap:fuchsia.sysmem.heap_cpp",
"//src/devices/lib/driver:driver_runtime",
"//src/devices/pci/lib/device-protocol-pci",
"//src/devices/pci/lib/pci",
"//src/graphics/display/lib/api-protocols/cpp",
"//src/graphics/display/lib/api-types/cpp",
"//src/graphics/display/lib/driver-utils",
"//src/graphics/display/lib/edid",
"//src/lib/ddk:ddk-hw-headers",
"//src/lib/fxl",
"//src/lib/zbitl",
"//zircon/system/ulib/fbl",
"//zircon/system/ulib/hwreg",
"//zircon/system/ulib/image-format",
"//zircon/system/ulib/inspect",
"//zircon/system/ulib/region-alloc",
"//zircon/system/ulib/sync:sync-cpp",
"//zircon/system/ulib/zircon-internal",
"//zircon/system/ulib/zx",
]
}
fuchsia_cc_driver("driver") {
output_name = "intel-display"
deps = [ ":common_srcs" ]
}
fuchsia_driver_component("intel-display") {
component_name = "intel-display"
deps = [ ":driver" ]
info = "meta/intel-display-info.json"
manifest = "meta/intel-display.cml"
}
fuchsia_driver_package("package") {
package_name = "intel-display"
driver_components = [ ":intel-display" ]
}
test("intel-display-tests") {
sources = [
"acpi-memory-region-unittest.cc",
"acpi-memory-region-util-unittest.cc",
"ddi-aux-channel-unittest.cc",
"ddi-physical-layer-manager-unittest.cc",
"ddi-physical-layer-unittest.cc",
"display-timing-mode-conversion-unittest.cc",
"dp-capabilities-unittest.cc",
"dp-display-unittest.cc",
"dpll-config-unittest.cc",
"dpll-unittest.cc",
"fake-dp-aux-channel.cc",
"fake-dp-aux-channel.h",
"firmware-bridge-unittest.cc",
"fuse-config-unittest.cc",
"gtt-unittest.cc",
"hardware-common-unittest.cc",
"i2c/gmbus-gpio-unittest.cc",
"intel-display-driver-test.cc",
"intel-display-test.cc",
"interrupts-unittest.cc",
"pch-engine-unittest.cc",
"pipe-manager-unittest.cc",
"pipe-unittest.cc",
"power-controller-unittest.cc",
"power-unittest.cc",
"registers-arbiter-unittest.cc",
"registers-arbiter.h",
"registers-ddi-phy-tiger-lake-unittest.cc",
"registers-ddi-unittest.cc",
"registers-dpll-unittest.cc",
"registers-gmbus-unittest.cc",
"registers-memory-controller-unittest.cc",
"registers-memory-controller.h",
"registers-pipe-scaler-unittest.cc",
"registers-pipe-unittest.cc",
"registers-transcoder-unittest.cc",
"registers-typec-unittest.cc",
"registers-unittest.cc",
]
deps = [
":common_srcs",
"testing:fake-framebuffer",
"testing:mock-allocator",
"//sdk/fidl/fuchsia.hardware.sysmem:fuchsia.hardware.sysmem_cpp_testing",
"//sdk/fidl/fuchsia.kernel:fuchsia.kernel_cpp",
"//sdk/fidl/fuchsia.sysmem2:fuchsia.sysmem2_cpp",
"//sdk/fidl/fuchsia.sysmem2:fuchsia.sysmem2_cpp_testing",
"//sdk/fidl/fuchsia.system.state:fuchsia.system.state_cpp",
"//sdk/lib/async-loop:async-loop-cpp",
"//sdk/lib/async-loop:async-loop-default",
"//sdk/lib/async-loop-testing/cpp",
"//sdk/lib/async_patterns/testing/cpp",
"//sdk/lib/component/outgoing/cpp",
"//sdk/lib/driver/fake-mmio-reg/cpp",
"//sdk/lib/driver/mmio/testing/cpp",
"//sdk/lib/driver/mock-mmio/cpp",
"//sdk/lib/driver/runtime:driver_runtime_cpp",
"//sdk/lib/driver/testing/cpp",
"//sdk/lib/driver/testing/cpp:scoped_global_logger",
"//sdk/lib/zbi-format",
"//src/devices/bin/driver_runtime",
"//src/devices/bind/fuchsia:fuchsia_cpp",
"//src/devices/bind/fuchsia.display:fuchsia.display_cpp",
"//src/devices/bind/fuchsia.intel.platform.gpucore:fuchsia.intel.platform.gpucore_cpp",
"//src/devices/pci/testing:pci-protocol-fake",
"//src/devices/testing/fake-resource",
"//src/graphics/display/lib/api-types/cpp",
"//src/graphics/display/lib/edid-values",
"//src/lib/fsl",
"//src/lib/fxl/test:gtest_main",
"//src/lib/testing/predicates",
"//third_party/googletest:gmock",
"//third_party/googletest:gtest",
"//zircon/system/ulib/mmio-ptr",
]
}
group("tests") {
testonly = true
deps = [
":intel-display-bind_test",
":intel-display-tests-package",
"testing:tests",
]
}
fuchsia_unittest_package("intel-display-tests-package") {
package_name = "intel-display-tests"
deps = [ ":intel-display-tests" ]
manifest = "meta/intel-display-tests.cml"
test_specs = {
log_settings = {
max_severity = "ERROR"
}
}
}