blob: 00a5aea97750bdaaaa9f3f72dac62cbf5d7d7642 [file] [log] [blame]
Angel Ponsae593872020-04-04 18:50:57 +02001/* SPDX-License-Identifier: GPL-2.0-only */
2/* This file is part of the coreboot project. */
Marc Jones24484842017-05-04 21:17:45 -06003
Furquan Shaikh76cedd22020-05-02 10:24:23 -07004#include <acpi/acpigen.h>
Furquan Shaikh91a7abf2020-04-27 18:48:48 -07005#include <amdblocks/hda.h>
Marc Jones24484842017-05-04 21:17:45 -06006#include <device/device.h>
7#include <device/pci.h>
8#include <device/pci_ids.h>
Marshall Dawsone1a59dc2019-08-20 18:17:54 -06009#include <device/pci_ops.h>
10#include <device/azalia_device.h>
Marc Jones24484842017-05-04 21:17:45 -060011
12static const unsigned short pci_device_ids[] = {
13 PCI_DEVICE_ID_AMD_SB900_HDA,
14 PCI_DEVICE_ID_AMD_CZ_HDA,
Furquan Shaikha1cd7eb2020-04-15 23:58:22 -070015 PCI_DEVICE_ID_AMD_FAM17H_HDA1,
Marc Jones24484842017-05-04 21:17:45 -060016 0
17};
18
Furquan Shaikhedfc5a92020-04-27 18:04:46 -070019static const char *hda_acpi_name(const struct device *dev)
20{
21 return "AZHD";
22}
23
Furquan Shaikh91a7abf2020-04-27 18:48:48 -070024__weak void hda_soc_ssdt_quirks(const struct device *dev)
25{
26}
27
28static void hda_fill_ssdt(const struct device *dev)
29{
30 acpi_device_write_pci_dev(dev);
31 hda_soc_ssdt_quirks(dev);
32}
33
Marc Jones24484842017-05-04 21:17:45 -060034static struct device_operations hda_audio_ops = {
Furquan Shaikh45f06c52020-04-27 18:02:21 -070035 .read_resources = pci_dev_read_resources,
36 .set_resources = pci_dev_set_resources,
37 .enable_resources = pci_dev_enable_resources,
38 .ops_pci = &pci_dev_ops_pci,
Furquan Shaikhedfc5a92020-04-27 18:04:46 -070039 .acpi_name = hda_acpi_name,
Furquan Shaikh91a7abf2020-04-27 18:48:48 -070040 .acpi_fill_ssdt = hda_fill_ssdt,
Marc Jones24484842017-05-04 21:17:45 -060041};
42
43static const struct pci_driver hdaaudio_driver __pci_driver = {
Furquan Shaikh45f06c52020-04-27 18:02:21 -070044 .ops = CONFIG(AZALIA_PLUGIN_SUPPORT) ?
45 &default_azalia_audio_ops : &hda_audio_ops,
46 .vendor = PCI_VENDOR_ID_AMD,
47 .devices = pci_device_ids,
Marc Jones24484842017-05-04 21:17:45 -060048};