blob: edc1f80d0e0604e3e99d3f41d48e94c40b8e9cb0 [file] [log] [blame]
Matt DeVillier3a4ac3a2023-01-17 10:57:42 -06001/* SPDX-License-Identifier: GPL-2.0-only */
2
3#include <acpi/acpi_device.h>
4#include <acpi/acpigen.h>
5#include <device/device.h>
6#include <device/path.h>
7#include <string.h>
8
9#include "chip.h"
10
Matt DeVillier4c5ec212023-05-15 10:32:00 -050011static const char *get_spkr_tplg_str(enum _spkr_tplg tplg)
Matt DeVillier3a4ac3a2023-01-17 10:57:42 -060012{
Matt DeVillier4c5ec212023-05-15 10:32:00 -050013 switch (tplg) {
14 case max98373: return "max98373";
15 case max98360a: return "max98360a";
16 case max98357a: return "max98357a";
17 case max98357a_tdm: return "max98357a-tdm";
18 case max98390: return "max98390";
19 case rt1011: return "rt1011";
20 case rt1015: return "rt1015";
21 default: return "default";
Matt DeVillier3a4ac3a2023-01-17 10:57:42 -060022 }
23}
24
Matt DeVillier4c5ec212023-05-15 10:32:00 -050025static const char *get_jack_tplg_str(enum _jack_tplg tplg)
Matt DeVillier3a4ac3a2023-01-17 10:57:42 -060026{
Matt DeVillier4c5ec212023-05-15 10:32:00 -050027 switch (tplg) {
28 case cs42l42: return "cs42l42";
29 case da7219: return "da7219";
30 case nau8825: return "nau8825";
31 case rt5682: return "rt5682";
32 default: return "default";
Matt DeVillier3a4ac3a2023-01-17 10:57:42 -060033 }
34}
35
Matt DeVillier4c5ec212023-05-15 10:32:00 -050036static const char *get_mic_tplg_str(enum _mic_tplg tplg)
Matt DeVillier3a4ac3a2023-01-17 10:57:42 -060037{
Matt DeVillier4c5ec212023-05-15 10:32:00 -050038 switch (tplg) {
39 case _1ch: return "1ch";
40 case _2ch_pdm0: return "2ch-pdm0";
41 case _2ch_pdm1: return "2ch-pdm1";
42 case _4ch: return "4ch";
43 default: return "default";
Matt DeVillier3a4ac3a2023-01-17 10:57:42 -060044 }
45}
46
47static void sof_fill_ssdt_generator(const struct device *dev)
48{
49 struct drivers_sof_config *config = dev->chip_info;
50 const char *scope = acpi_device_scope(dev);
51 struct acpi_dp *dsd;
52
53 if (!dev->enabled || !config || !scope)
54 return;
55
56 /* Device */
57 acpigen_write_scope(scope);
58
59 /* DSD */
60 dsd = acpi_dp_new_table("_DSD");
61 acpi_dp_add_string(dsd, "speaker-tplg",
62 get_spkr_tplg_str(config->spkr_tplg));
63 acpi_dp_add_string(dsd, "hp-tplg",
64 get_jack_tplg_str(config->jack_tplg));
65 acpi_dp_add_string(dsd, "mic-tplg",
66 get_mic_tplg_str(config->mic_tplg));
67 acpi_dp_write(dsd);
68 acpigen_pop_len(); /* Scope */
69}
70
71
72static struct device_operations sof_ops = {
73 .read_resources = noop_read_resources,
74 .set_resources = noop_set_resources,
75 .acpi_fill_ssdt = sof_fill_ssdt_generator,
76};
77
78static void sof_enable(struct device *dev)
79{
80 dev->ops = &sof_ops;
81}
82
83struct chip_operations drivers_sof_ops = {
84 CHIP_NAME("SOF")
85 .enable_dev = sof_enable
86};