1 // Copyright 2017 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 
5 #include <ddk/device.h>
6 #include <ddk/driver.h>
7 #include <ddk/binding.h>
8 #include <ddk/protocol/pci.h>
9 
10 #include "binding.h"
11 
12 extern zx_status_t ihda_init_hook(void**);
13 extern zx_status_t ihda_bind_hook(void*, zx_device_t*);
14 extern void        ihda_release_hook(void*);
15 
16 static zx_driver_ops_t intel_hda_driver_ops = {
17     .version = DRIVER_OPS_VERSION,
18     .init = ihda_init_hook,
19     .bind = ihda_bind_hook,
20     .release = ihda_release_hook,
21 };
22 
23 ZIRCON_DRIVER_BEGIN(intel_hda, intel_hda_driver_ops, "zircon", "0.1", 8)
24     BI_ABORT_IF(NE, BIND_PROTOCOL, ZX_PROTOCOL_PCI),
25     BI_ABORT_IF(NE, BIND_PCI_VID, INTEL_HDA_PCI_VID),
26     BI_MATCH_IF(EQ, BIND_PCI_DID, INTEL_HDA_PCI_DID_STANDARD),
27     BI_MATCH_IF(EQ, BIND_PCI_DID, INTEL_HDA_PCI_DID_BROADWELL),
28     BI_MATCH_IF(EQ, BIND_PCI_DID, INTEL_HDA_PCI_DID_100_C230),
29     BI_MATCH_IF(EQ, BIND_PCI_DID, INTEL_HDA_PCI_DID_200_C400),
30     BI_MATCH_IF(EQ, BIND_PCI_DID, INTEL_HDA_PCI_DID_SKYLAKE),
31     BI_MATCH_IF(EQ, BIND_PCI_DID, INTEL_HDA_PCI_DID_KABYLAKE),
32 ZIRCON_DRIVER_END(intel_hda)
33