blob: 1fbe195ac824ebcb25e969dd51ea7e8656608dbb [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")
group("tests") {
testonly = true
deps = [
":aml-gpu-test",
":aml_gpu_bind_test",
]
}
driver_bind_rules("aml_gpu_bind") {
rules = "aml_gpu.bind"
bind_output = "aml-gpu.bindbc"
tests = "bind_tests.json"
deps = [
"//sdk/fidl/fuchsia.hardware.clock:fuchsia.hardware.clock_bindlib",
"//sdk/fidl/fuchsia.hardware.registers:fuchsia.hardware.registers_bindlib",
"//src/devices/bind/fuchsia.amlogic.platform",
"//src/devices/bind/fuchsia.arm.platform",
"//src/devices/bind/fuchsia.devicetree",
"//src/devices/bind/fuchsia.platform",
]
}
source_set("sources") {
configs += [
"//build/config:all_source",
"//build/config/fuchsia:enable_zircon_asserts",
]
sources = [
"aml-gpu.cc",
"aml-gpu.h",
"s905d2-gpu.h",
"s912-gpu.h",
"t931-gpu.h",
]
public_deps = [
":aml_gpu_bind",
"//sdk/fidl/fuchsia.driver.compat:fuchsia.driver.compat_cpp",
"//sdk/fidl/fuchsia.hardware.clock:fuchsia.hardware.clock_cpp",
"//sdk/fidl/fuchsia.hardware.gpu.amlogic:fuchsia.hardware.gpu.amlogic_cpp",
"//sdk/fidl/fuchsia.hardware.gpu.mali:fuchsia.hardware.gpu.mali_cpp",
"//sdk/fidl/fuchsia.hardware.registers:fuchsia.hardware.registers_cpp",
"//sdk/lib/driver/component/cpp:cpp",
"//sdk/lib/driver/outgoing/cpp",
"//sdk/lib/driver/runtime:driver_runtime",
"//sdk/lib/inspect/component/cpp",
"//src/devices/bin/driver_runtime",
"//src/devices/bind/fuchsia.arm.platform:fuchsia.arm.platform_cpp",
"//src/devices/bind/fuchsia.platform:fuchsia.platform_cpp",
"//src/devices/bus/lib/device-protocol-pdev",
"//src/devices/lib/amlogic",
"//src/devices/lib/mmio",
"//src/devices/tee/drivers/optee:tee_smc",
"//zircon/system/ulib/inspect",
"//zircon/system/ulib/sync",
"//zircon/system/ulib/sync:sync-cpp",
"//zircon/system/ulib/trace",
]
}
fuchsia_driver("aml-gpu-driver") {
output_name = "aml-gpu"
deps = [ ":sources" ]
}
fuchsia_driver_component("aml-gpu") {
component_name = "aml-gpu"
deps = [ ":aml-gpu-driver" ]
info = "aml-gpu-info.json"
manifest = "meta/aml-gpu.cml"
}
fuchsia_driver_package("aml-gpu-package") {
driver_components = [ ":aml-gpu" ]
}
executable("aml-gpu-test-bin") {
testonly = true
output_name = "aml-gpu-test"
sources = [ "aml-gpu-test.cc" ]
deps = [
":sources",
"//sdk/lib/async_patterns/testing/cpp",
"//sdk/lib/driver/runtime/testing/cpp",
"//sdk/lib/driver/testing/cpp:cpp",
"//src/devices/registers/testing/mock-registers",
"//src/lib/fxl/test:gtest_main",
"//third_party/googletest:gtest",
"//zircon/system/ulib/async-loop:async-loop-cpp",
"//zircon/system/ulib/async-loop:async-loop-default",
]
}
fuchsia_unittest_package("aml-gpu-test") {
deps = [ ":aml-gpu-test-bin" ]
}