blob: 0ad1cf41b308466674044100bc6c1e7fd9ce3581 [file] [log] [blame]
Ajit Kumar Pandey9d8a7be2021-10-19 12:39:35 +05301// SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause)
2//
3// This file is provided under a dual BSD/GPLv2 license. When using or
4// redistributing this file, you may do so under either license.
5//
6// Copyright(c) 2021 Advanced Micro Devices, Inc.
7//
8// Authors: Ajit Kumar Pandey <AjitKumar.Pandey@amd.com>
9//
10
11/*
12 * Machine Driver Legacy Support for ACP HW block
13 */
14
15#include <sound/core.h>
16#include <sound/pcm_params.h>
17#include <sound/soc-acpi.h>
18#include <sound/soc-dapm.h>
19#include <linux/module.h>
20
21#include "acp-mach.h"
22
23static struct acp_card_drvdata rt5682_rt1019_data = {
24 .hs_cpu_id = I2S_SP,
25 .amp_cpu_id = I2S_SP,
26 .dmic_cpu_id = NONE,
27 .hs_codec_id = RT5682,
28 .amp_codec_id = RT1019,
29 .dmic_codec_id = NONE,
V sujith kumar Reddy5c5f08f2021-12-24 20:30:43 +053030 .gpio_spkr_en = EN_SPKR_GPIO_GB,
Ajit Kumar Pandey9d8a7be2021-10-19 12:39:35 +053031};
32
33static const struct snd_kcontrol_new acp_controls[] = {
34 SOC_DAPM_PIN_SWITCH("Headphone Jack"),
35 SOC_DAPM_PIN_SWITCH("Headset Mic"),
36 SOC_DAPM_PIN_SWITCH("Spk"),
37 SOC_DAPM_PIN_SWITCH("Left Spk"),
38 SOC_DAPM_PIN_SWITCH("Right Spk"),
39
40};
41
42static const struct snd_soc_dapm_widget acp_widgets[] = {
43 SND_SOC_DAPM_HP("Headphone Jack", NULL),
44 SND_SOC_DAPM_MIC("Headset Mic", NULL),
V sujith kumar Reddy5c5f08f2021-12-24 20:30:43 +053045 SND_SOC_DAPM_SPK("Spk", event_spkr_handler),
46 SND_SOC_DAPM_SPK("Left Spk", event_spkr_handler),
47 SND_SOC_DAPM_SPK("Right Spk", event_spkr_handler),
Ajit Kumar Pandey9d8a7be2021-10-19 12:39:35 +053048};
49
50static int acp_asoc_probe(struct platform_device *pdev)
51{
52 struct snd_soc_card *card = NULL;
53 struct device *dev = &pdev->dev;
V sujith kumar Reddy5c5f08f2021-12-24 20:30:43 +053054 unsigned int spkr_gpio;
Ajit Kumar Pandey9d8a7be2021-10-19 12:39:35 +053055 int ret;
56
57 if (!pdev->id_entry)
58 return -EINVAL;
59
60 card = devm_kzalloc(dev, sizeof(*card), GFP_KERNEL);
61 if (!card)
62 return -ENOMEM;
63
64 card->dev = dev;
65 card->owner = THIS_MODULE;
66 card->name = pdev->id_entry->name;
67 card->dapm_widgets = acp_widgets;
68 card->num_dapm_widgets = ARRAY_SIZE(acp_widgets);
69 card->controls = acp_controls;
70 card->num_controls = ARRAY_SIZE(acp_controls);
71 card->drvdata = (struct acp_card_drvdata *)pdev->id_entry->driver_data;
V sujith kumar Reddy5c5f08f2021-12-24 20:30:43 +053072 spkr_gpio = ((struct acp_card_drvdata *)(card->drvdata))->gpio_spkr_en;
Ajit Kumar Pandey9d8a7be2021-10-19 12:39:35 +053073
74 acp_legacy_dai_links_create(card);
75
V sujith kumar Reddy5c5f08f2021-12-24 20:30:43 +053076 if (gpio_is_valid(spkr_gpio)) {
77 ret = devm_gpio_request(dev, spkr_gpio, "spkren");
78 if (ret) {
79 dev_err(dev, "(%s) gpio request failed: %d\n",
80 __func__, ret);
81 return ret;
82 }
83 gpio_direction_output(spkr_gpio, 0);
84 }
85
Ajit Kumar Pandey9d8a7be2021-10-19 12:39:35 +053086 ret = devm_snd_soc_register_card(&pdev->dev, card);
87 if (ret) {
88 dev_err(&pdev->dev,
89 "devm_snd_soc_register_card(%s) failed: %d\n",
90 card->name, ret);
91 return ret;
92 }
93
94 return 0;
95}
96
97static const struct platform_device_id board_ids[] = {
98 {
99 .name = "rn_rt5682_rt1019",
100 .driver_data = (kernel_ulong_t)&rt5682_rt1019_data,
101 },
102 { }
103};
104static struct platform_driver acp_asoc_audio = {
105 .driver = {
106 .name = "acp_mach",
107 },
108 .probe = acp_asoc_probe,
109 .id_table = board_ids,
110};
111
112module_platform_driver(acp_asoc_audio);
113
114MODULE_IMPORT_NS(SND_SOC_AMD_MACH);
115MODULE_DESCRIPTION("ACP chrome audio support");
116MODULE_ALIAS("platform:rn_rt5682_rt1019");
117MODULE_LICENSE("GPL v2");