blob: f1a5a3b64d83ac3ec58950bfa15d5e94797afb27 [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-i915-bind") {
rules = "intel-i915.bind"
tests = "bind_tests.json"
deps = [
"//sdk/fidl/fuchsia.hardware.pci:fuchsia.hardware.pci_bindlib",
"//sdk/fidl/fuchsia.hardware.sysmem:fuchsia.hardware.sysmem_bindlib",
"//src/devices/bind/fuchsia.acpi",
"//src/devices/bind/fuchsia.pci",
]
}
source_set("common_srcs") {
configs += [ "//build/config:all_source" ]
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",
"dp-display.cc",
"dp-display.h",
"dpcd.h",
"dpll-config.cc",
"dpll-config.h",
"dpll.cc",
"dpll.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-i915.cc",
"intel-i915.h",
"interrupts.cc",
"interrupts.h",
"pch-engine.cc",
"pch-engine.h",
"pci-ids.h",
"pipe-manager.cc",
"pipe-manager.h",
"pipe.cc",
"pipe.h",
"poll-until.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",
"scoped-value-change.cc",
"scoped-value-change.h",
"tiling.h",
]
public_deps = [
":intel-i915-bind",
"//sdk/banjo/fuchsia.hardware.display.controller:fuchsia.hardware.display.controller_banjo_cpp",
"//sdk/banjo/fuchsia.hardware.i2cimpl:fuchsia.hardware.i2cimpl_banjo_cpp",
"//sdk/banjo/fuchsia.hardware.intelgpucore:fuchsia.hardware.intelgpucore_banjo_cpp",
"//sdk/fidl/fuchsia.hardware.backlight:fuchsia.hardware.backlight_cpp",
"//sdk/fidl/fuchsia.hardware.sysmem:fuchsia.hardware.sysmem_cpp",
"//sdk/fidl/fuchsia.sysmem2:fuchsia.sysmem2_cpp",
"//sdk/lib/stdcompat",
"//sdk/lib/zbi-format",
"//src/devices/bind/fuchsia.sysmem.heap:fuchsia.sysmem.heap_cpp",
"//src/devices/lib/driver",
"//src/devices/lib/mmio",
"//src/devices/pci/lib/device-protocol-pci",
"//src/devices/pci/lib/pci",
"//src/graphics/display/lib/api-types-cpp",
"//src/lib/ddk",
"//src/lib/ddktl",
"//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/zircon-internal",
"//zircon/system/ulib/zx",
]
# TODO(https://fxbug.dev/42085293): delete the below and fix compiler warnings
configs += [ "//build/config:Wno-vla-cxx-extension" ]
}
fuchsia_driver("intel-i915-driver") {
output_name = "intel-i915"
deps = [ ":common_srcs" ]
}
fuchsia_driver_component("intel-i915") {
component_name = "intel-i915"
deps = [ ":intel-i915-driver" ]
info = "intel-i915-info.json"
manifest = "meta/intel-i915.cml"
}
fuchsia_driver_package("package") {
package_name = "intel-i915"
driver_components = [ ":intel-i915" ]
}
test("intel-i915-test") {
configs += [ "//build/config:all_source" ]
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",
"dp-capabilities-unittest.cc",
"dp-display-unittest.cc",
"dpll-config-unittest.cc",
"dpll-unittest.cc",
"fake-dpcd-channel.cc",
"fake-dpcd-channel.h",
"firmware-bridge-unittest.cc",
"fuse-config-unittest.cc",
"gtt-unittest.cc",
"hardware-common-unittest.cc",
"i2c/gmbus-gpio-unittest.cc",
"intel-i915-test.cc",
"interrupts-unittest.cc",
"pch-engine-unittest.cc",
"pipe-manager-unittest.cc",
"pipe-unittest.cc",
"poll-until-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",
"scoped-value-change-unittest.cc",
]
deps = [
":common_srcs",
"//sdk/fidl/fuchsia.hardware.sysmem:fuchsia.hardware.sysmem_cpp_testing",
"//sdk/fidl/fuchsia.sysmem2:fuchsia.sysmem2_cpp_testing",
"//sdk/lib/async-loop-testing/cpp",
"//sdk/lib/component/outgoing/cpp",
"//src/devices/lib/mmio:test_helper",
"//src/devices/pci/testing:pci-protocol-fake",
"//src/devices/testing/fake-mmio-reg",
"//src/devices/testing/mock-ddk",
"//src/devices/testing/mock-mmio-range",
"//src/lib/fsl",
"//src/lib/fxl/test:gtest_main",
"//third_party/googletest:gmock",
"//third_party/googletest:gtest",
"//zircon/system/ulib/async-loop:async-loop-cpp",
"//zircon/system/ulib/async-loop:async-loop-default",
"//zircon/system/ulib/mmio-ptr:mmio-ptr-fake",
]
}
group("tests") {
testonly = true
deps = [
":intel-i915-bind_test",
":intel-i915-test-package",
]
}
fuchsia_unittest_package("intel-i915-test-package") {
package_name = "intel-i915-test"
deps = [ ":intel-i915-test" ]
manifest = "meta/intel-i915-test.cml"
test_specs = {
log_settings = {
max_severity = "ERROR"
}
}
}