blob: 4e1c409d4815d9da27b81aa4a539be8051d88f1f [file] [log] [blame]
Angel Ponsae593872020-04-04 18:50:57 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Marc Jones24484842017-05-04 21:17:45 -06002
Furquan Shaikh76cedd22020-05-02 10:24:23 -07003#include <acpi/acpigen.h>
Marc Jones24484842017-05-04 21:17:45 -06004#include <device/device.h>
5#include <device/pci.h>
6#include <device/pci_ids.h>
Marshall Dawsone1a59dc2019-08-20 18:17:54 -06007#include <device/pci_ops.h>
8#include <device/azalia_device.h>
Marc Jones24484842017-05-04 21:17:45 -06009
10static const unsigned short pci_device_ids[] = {
Felix Singer43b7f412022-03-07 04:34:52 +010011 PCI_DID_AMD_SB900_HDA,
12 PCI_DID_AMD_CZ_HDA,
13 PCI_DID_AMD_FAM17H_HDA1,
Marc Jones24484842017-05-04 21:17:45 -060014 0
15};
16
Furquan Shaikhedfc5a92020-04-27 18:04:46 -070017static const char *hda_acpi_name(const struct device *dev)
18{
19 return "AZHD";
20}
21
Marc Jones24484842017-05-04 21:17:45 -060022static struct device_operations hda_audio_ops = {
Furquan Shaikh45f06c52020-04-27 18:02:21 -070023 .read_resources = pci_dev_read_resources,
24 .set_resources = pci_dev_set_resources,
25 .enable_resources = pci_dev_enable_resources,
26 .ops_pci = &pci_dev_ops_pci,
Furquan Shaikhedfc5a92020-04-27 18:04:46 -070027 .acpi_name = hda_acpi_name,
Felix Helde91785d2023-11-06 19:23:40 +010028 .acpi_fill_ssdt = acpi_device_write_pci_dev,
Marc Jones24484842017-05-04 21:17:45 -060029};
30
31static const struct pci_driver hdaaudio_driver __pci_driver = {
Furquan Shaikh45f06c52020-04-27 18:02:21 -070032 .ops = CONFIG(AZALIA_PLUGIN_SUPPORT) ?
33 &default_azalia_audio_ops : &hda_audio_ops,
Felix Singer43b7f412022-03-07 04:34:52 +010034 .vendor = PCI_VID_AMD,
Furquan Shaikh45f06c52020-04-27 18:02:21 -070035 .devices = pci_device_ids,
Marc Jones24484842017-05-04 21:17:45 -060036};