1 // Copyright 2018 The Fuchsia Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 #include <ddk/binding.h> 5 #include <ddk/device.h> 6 #include <ddk/driver.h> 7 #include <ddk/platform-defs.h> 8 9 extern zx_status_t aml_pcie_bind(void* ctx, zx_device_t* parent); 10 11 static zx_driver_ops_t aml_pcie_driver_ops = { 12 .version = DRIVER_OPS_VERSION, 13 .bind = aml_pcie_bind, 14 }; 15 16 // clang-format off 17 // Bind to ANY Amlogic SoC with a DWC PCIe controller. 18 ZIRCON_DRIVER_BEGIN(aml_pcie, aml_pcie_driver_ops, "zircon", "0.1", 4) 19 BI_ABORT_IF(NE, BIND_PROTOCOL, ZX_PROTOCOL_PDEV), 20 BI_ABORT_IF(NE, BIND_PLATFORM_DEV_VID, PDEV_VID_AMLOGIC), 21 BI_ABORT_IF(NE, BIND_PLATFORM_DEV_PID, PDEV_PID_GENERIC), 22 BI_MATCH_IF(EQ, BIND_PLATFORM_DEV_DID, PDEV_DID_DW_PCIE), 23 ZIRCON_DRIVER_END(aml_pcie) 24