// Copyright 2018 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. #include #include #include #include extern zx_status_t aml_pcie_bind(void* ctx, zx_device_t* parent); static zx_driver_ops_t aml_pcie_driver_ops = { .version = DRIVER_OPS_VERSION, .bind = aml_pcie_bind, }; // clang-format off // Bind to ANY Amlogic SoC with a DWC PCIe controller. ZIRCON_DRIVER_BEGIN(aml_pcie, aml_pcie_driver_ops, "zircon", "0.1", 4) BI_ABORT_IF(NE, BIND_PROTOCOL, ZX_PROTOCOL_PDEV), BI_ABORT_IF(NE, BIND_PLATFORM_DEV_VID, PDEV_VID_AMLOGIC), BI_ABORT_IF(NE, BIND_PLATFORM_DEV_PID, PDEV_PID_GENERIC), BI_MATCH_IF(EQ, BIND_PLATFORM_DEV_DID, PDEV_DID_DW_PCIE), ZIRCON_DRIVER_END(aml_pcie)