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