Received: by 2002:a25:ca44:0:0:0:0:0 with SMTP id a65csp1104887ybg; Mon, 27 Jul 2020 08:03:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyEEef6KLSgGuEPJgHTLn6HZN0cUHwzR+GxZs+Q12AhoqhZyod9/qunZis4BwplnRiC3kvR X-Received: by 2002:a17:906:3a04:: with SMTP id z4mr20806297eje.441.1595862218858; Mon, 27 Jul 2020 08:03:38 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1595862218; cv=pass; d=google.com; s=arc-20160816; b=oHPEgkkvubGoNK8AjQybR+bhql7lX/ta/s09j+5DtCrmcvy7cfSJROwiwm4IAfHE2G f60s9Na0EhMSw9aFxWb9DIMHH9E2I1X9mZ2MxFAu04C4k5oaNNNqPedOLg6dvRDFjyZ9 fqaLwaOVd9yedyGBmfZe681OJ7/L+aJYLh23t9KnQtWQ1vCzDZBJuS+eDpZ5K8Oxn1uK +qzhS0vzuuTHdMCFS6faQkcE3gUPNAMLgckprhmApkv5L2DAt7jiVCSLt8yO6ms7CPd1 F/yyL6n6B0+GaNeRp/TjiCi3OSCx6zVXlsgvnk9MS7vi/5dMdkK2obkGU8VB0z9yq5UI j2qg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:mime-version:references:in-reply-to :message-id:date:subject:cc:from:dkim-signature; bh=pjpHPW4m4qtDpibv0qHdCBCVCb/Ry0z/U6zuWOCnkLc=; b=TNq9cmZEZ5SNuUYBrZRy19qQsPax27zsjjFjLWTEdhYp1KXPzbTRuu2p8zoTbW/1cq KG5APFo1tx6Wh/tRvKZYIeNkm4Na4zfxI4G9trIIujOqvC+ykKU/u7UJe7uW2ZzcEO0o jRukUbu3dtaWohUqREQDlHc+sqCzhioHxQJVtuOmMECkVMy/YZ28+ku9vnvPmj3AO7an uOc85FmtfB6O2RDqYSkoZbuuBvLOriosHTSXnn+HPJ3gpCzY20qFrwiJwk56FTZbxK89 OORJ2J83LP2wPf1UFQiMi2LbOHfmwk1MAvWoSsoZT+UpqGIuvbHTyLjl5Dm/OEIPprbn 29hQ== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@amdcloud.onmicrosoft.com header.s=selector2-amdcloud-onmicrosoft-com header.b=yGQErhdG; arc=pass (i=1); spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id c19si5788094ejr.522.2020.07.27.08.03.14; Mon, 27 Jul 2020 08:03:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@amdcloud.onmicrosoft.com header.s=selector2-amdcloud-onmicrosoft-com header.b=yGQErhdG; arc=pass (i=1); spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729860AbgG0PCN (ORCPT + 99 others); Mon, 27 Jul 2020 11:02:13 -0400 Received: from mail-mw2nam10on2044.outbound.protection.outlook.com ([40.107.94.44]:53472 "EHLO NAM10-MW2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726983AbgG0PCM (ORCPT ); Mon, 27 Jul 2020 11:02:12 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=HLOZ/zJwoSJ6WE30kKIOU53c8OXQgdyM1LQLSAPB5o/bhfseAOZ4ZjSKaNXVSjanWjl5nsaXOmUtk/gWLGkCR9rJ73rE5BvsoFmcirDGynedF2CnqBV7Lf/ivEfC8ubOdHBuT61YfySoEnyaYT+6KqayZrok7Idwk9cW+vUcs/W19PiC4mlk39hVH5SkEsxI5uHEOmm3gdctsnEuuXM0vGuSKZeoZMUw+CbVTh4ETHu+SyiQBsUHgS9nFkTf+/4Njs9Sq4A+Z5x1V6Yc7HkmDzrk/GJ8EXoVcING25wtCYaa+U1y+vhb5saG3yInv5WrV2/DH/SldkLxiCHl2zDqYg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=pjpHPW4m4qtDpibv0qHdCBCVCb/Ry0z/U6zuWOCnkLc=; b=MXrFWUa8vB12C8WPxOeX54txr0CAfo3KIKjinT08YLDkUuj+N0T2qb0YtpxVmwHjccbwFfWDECi+voBhS4LcysRdDee+EYvorReVgDpa3Ef/J2HWukr9/w5m96uWYDHUdLqeiqIwHMNW3cQi05G6oNah30YzNL/1PQ8mwQ/y0lrYfYxrxBMdCLdPNjbJnCVVqKb/DHw70sw1t6jmO37VaS6sbEYUcAqNiAORbZWlY/mNfK/wTX1c8ke7s4DkFg0EBIsh5Ru1KWFdvhepihF1hrDubSFBJwZKBsTlZBWwnbnQ8OVsgn5jGtc1vpCasCMkmlUYVk+lFzi8w8FYO2PWYg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none (sender ip is 165.204.84.17) smtp.rcpttodomain=gmail.com smtp.mailfrom=amd.com; dmarc=permerror action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amdcloud.onmicrosoft.com; s=selector2-amdcloud-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=pjpHPW4m4qtDpibv0qHdCBCVCb/Ry0z/U6zuWOCnkLc=; b=yGQErhdGXZ/qyjYLz/EffWkb4xj8AbRHZGUdxbIe+eJtfkT2W8B9aniKrAEBms7gJD6RO4w35cN9LV/Kz7Y+LmpgwEeDVeJ5ZkoOJlm63saYDz3+8pYoBSf8qZzDdssRVoA59MRgBh+dBVpZzFOa6vZKyN3MZxQ/K2G+9qscSHk= Received: from DM5PR12CA0011.namprd12.prod.outlook.com (2603:10b6:4:1::21) by BN6PR12MB1826.namprd12.prod.outlook.com (2603:10b6:404:106::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3216.23; Mon, 27 Jul 2020 15:02:09 +0000 Received: from DM6NAM11FT057.eop-nam11.prod.protection.outlook.com (2603:10b6:4:1:cafe::cc) by DM5PR12CA0011.outlook.office365.com (2603:10b6:4:1::21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3216.22 via Frontend Transport; Mon, 27 Jul 2020 15:02:09 +0000 X-MS-Exchange-Authentication-Results: spf=none (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; gmail.com; dkim=none (message not signed) header.d=none;gmail.com; dmarc=permerror action=none header.from=amd.com; Received-SPF: None (protection.outlook.com: amd.com does not designate permitted sender hosts) Received: from SATLEXMB01.amd.com (165.204.84.17) by DM6NAM11FT057.mail.protection.outlook.com (10.13.172.252) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.3216.10 via Frontend Transport; Mon, 27 Jul 2020 15:02:09 +0000 Received: from SATLEXMB02.amd.com (10.181.40.143) by SATLEXMB01.amd.com (10.181.40.142) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5; Mon, 27 Jul 2020 10:02:08 -0500 Received: from vishnu-All-Series.amd.com (10.180.168.240) by SATLEXMB02.amd.com (10.181.40.143) with Microsoft SMTP Server id 15.1.1713.5 via Frontend Transport; Mon, 27 Jul 2020 10:02:04 -0500 From: Ravulapati Vishnu vardhan rao CC: , Ravulapati Vishnu vardhan rao , Liam Girdwood , Mark Brown , Jaroslav Kysela , "Takashi Iwai" , Pierre-Louis Bossart , Vijendar Mukunda , Enric Balletbo i Serra , Arnd Bergmann , Akshu Agrawal , YueHaibing , "Kuninori Morimoto" , "moderated list:SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEM..." , "open list" Subject: [PATCH 4/6] ASoC: amd: Adding support for ALC1015 codec in machine driver Date: Mon, 27 Jul 2020 20:28:29 +0530 Message-ID: <20200727145840.25142-4-Vishnuvardhanrao.Ravulapati@amd.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200727145840.25142-1-Vishnuvardhanrao.Ravulapati@amd.com> References: <20200727145840.25142-1-Vishnuvardhanrao.Ravulapati@amd.com> MIME-Version: 1.0 Content-Type: text/plain X-EOPAttributedMessage: 0 X-MS-Office365-Filtering-HT: Tenant X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: c2029c26-1794-48ae-a620-08d8323e091d X-MS-TrafficTypeDiagnostic: BN6PR12MB1826: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:1227; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 1Q/Kkx92Etz9yppikYjxzuOo0p+LXE3YFC54BIjbKFnXaxNmNHAaopYAjmkZDw9f1xz77lX3151DC7xPQAg3xgNmKfQo6slcLkDXtvbV6D0hUrfRP3nlDpF3/FXbiBNcFYVLh1P6KiamuBckA0v0DDgd5HX4SxVW18CeXTr+bbVpZCTAhsvL9jtmFVQqoJM9NyAZf+gmToHtT9RFv3Njsal7TjztMSK7esWfZIMGFep553WC0DwfncMcTccud5ElSZXXCTIIxhJTzP+LSH1fiUYKl1reeJPXNzRGP0XiK/P5HK7voVwTsU1h2BpUiJUqtCBM1ZRm4d9zSPPTAbodH3RKex7dM2RBMPoPeyrpTnjz/nCmtJizFltkWyZD7E+Pfdl9lmLJ8Tzl5qLjCS2K+8YV5A5dGEyQB4J+nXt+zjc= X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:SATLEXMB01.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFTY:;SFS:(4636009)(396003)(376002)(136003)(346002)(39860400002)(46966005)(82310400002)(86362001)(83380400001)(82740400003)(47076004)(356005)(81166007)(336012)(426003)(2616005)(5660300002)(70206006)(36756003)(70586007)(1076003)(2906002)(316002)(109986005)(4326008)(54906003)(8676002)(186003)(6666004)(7696005)(26005)(7416002)(478600001)(8936002)(266003);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Jul 2020 15:02:09.4364 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: c2029c26-1794-48ae-a620-08d8323e091d X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB01.amd.com] X-MS-Exchange-CrossTenant-AuthSource: DM6NAM11FT057.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BN6PR12MB1826 To: unlisted-recipients:; (no To-header on input) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Adding support for ALC1015 RTK codec in machine driver. Passing specific card structure based on its ACPI ID. Signed-off-by: Ravulapati Vishnu vardhan rao --- sound/soc/amd/Kconfig | 1 + sound/soc/amd/acp3x-rt5682-max9836.c | 63 ++++++++++++++++++++++++++-- 2 files changed, 60 insertions(+), 4 deletions(-) diff --git a/sound/soc/amd/Kconfig b/sound/soc/amd/Kconfig index 77ffdb41bee5..3e19995a74bc 100644 --- a/sound/soc/amd/Kconfig +++ b/sound/soc/amd/Kconfig @@ -30,6 +30,7 @@ config SND_SOC_AMD_ACP3x config SND_SOC_AMD_RV_RT5682_MACH tristate "AMD RV support for RT5682" select SND_SOC_RT5682 + select SND_SOC_RT1015 select SND_SOC_MAX98357A select SND_SOC_CROS_EC_CODEC select I2C_CROS_EC_TUNNEL diff --git a/sound/soc/amd/acp3x-rt5682-max9836.c b/sound/soc/amd/acp3x-rt5682-max9836.c index 1e446e4bab25..ac96ef70aafa 100644 --- a/sound/soc/amd/acp3x-rt5682-max9836.c +++ b/sound/soc/amd/acp3x-rt5682-max9836.c @@ -21,6 +21,7 @@ #include "raven/acp3x.h" #include "../codecs/rt5682.h" +#include "../codecs/rt1015.h" #define PCO_PLAT_CLK 48000000 #define RT5682_PLL_FREQ (48000 * 512) @@ -246,7 +247,18 @@ SND_SOC_DAILINK_DEF(cros_ec, SND_SOC_DAILINK_DEF(platform, DAILINK_COMP_ARRAY(COMP_PLATFORM("acp3x_rv_i2s_dma.0"))); -static struct snd_soc_dai_link acp3x_dai_5682_98357[] = { +static struct snd_soc_codec_conf rt1015_conf[] = { + { + .dlc = COMP_CODEC_CONF("i2c-10EC1015:00"), + .name_prefix = "Left", + }, + { + .dlc = COMP_CODEC_CONF("i2c-10EC1015:01"), + .name_prefix = "Right", + }, +}; + +static struct snd_soc_dai_link acp3x_dai[] = { { .name = "acp3x-5682-play", .stream_name = "Playback", @@ -316,8 +328,8 @@ static const struct snd_kcontrol_new acp3x_5682_mc_controls[] = { static struct snd_soc_card acp3x_5682 = { .name = "acp3xalc5682m98357", .owner = THIS_MODULE, - .dai_link = acp3x_dai_5682_98357, - .num_links = ARRAY_SIZE(acp3x_dai_5682_98357), + .dai_link = acp3x_dai, + .num_links = ARRAY_SIZE(acp3x_dai), .dapm_widgets = acp3x_5682_widgets, .num_dapm_widgets = ARRAY_SIZE(acp3x_5682_widgets), .dapm_routes = acp3x_5682_audio_route, @@ -326,6 +338,47 @@ static struct snd_soc_card acp3x_5682 = { .num_controls = ARRAY_SIZE(acp3x_5682_mc_controls), }; +static const struct snd_soc_dapm_widget acp3x_1015_widgets[] = { + SND_SOC_DAPM_HP("Headphone Jack", NULL), + SND_SOC_DAPM_MIC("Headset Mic", NULL), + SND_SOC_DAPM_MUX("Dmic Mux", SND_SOC_NOPM, 0, 0, + &acp3x_dmic_mux_control), + SND_SOC_DAPM_SPK("Left Spk", NULL), + SND_SOC_DAPM_SPK("Right Spk", NULL), +}; + +static const struct snd_soc_dapm_route acp3x_1015_route[] = { + {"Headphone Jack", NULL, "HPOL"}, + {"Headphone Jack", NULL, "HPOR"}, + {"IN1P", NULL, "Headset Mic"}, + {"Dmic Mux", "Front Mic", "DMIC"}, + {"Dmic Mux", "Rear Mic", "DMIC"}, + {"Left Spk", NULL, "Left SPO"}, + {"Right Spk", NULL, "Right SPO"}, +}; + +static const struct snd_kcontrol_new acp3x_mc_1015_controls[] = { + SOC_DAPM_PIN_SWITCH("Headphone Jack"), + SOC_DAPM_PIN_SWITCH("Headset Mic"), + SOC_DAPM_PIN_SWITCH("Left Spk"), + SOC_DAPM_PIN_SWITCH("Right Spk"), +}; + +static struct snd_soc_card acp3x_1015 = { + .name = "acp3xalc56821015", + .owner = THIS_MODULE, + .dai_link = acp3x_dai, + .num_links = ARRAY_SIZE(acp3x_dai), + .dapm_widgets = acp3x_1015_widgets, + .num_dapm_widgets = ARRAY_SIZE(acp3x_1015_widgets), + .dapm_routes = acp3x_1015_route, + .num_dapm_routes = ARRAY_SIZE(acp3x_1015_route), + .codec_conf = rt1015_conf, + .num_configs = ARRAY_SIZE(rt1015_conf), + .controls = acp3x_mc_1015_controls, + .num_controls = ARRAY_SIZE(acp3x_mc_1015_controls), +}; + void *soc_is_rltk_max(struct device *dev) { const struct acpi_device_id *match; @@ -374,6 +427,7 @@ static int acp3x_probe(struct platform_device *pdev) static const struct acpi_device_id acp3x_audio_acpi_match[] = { { "AMDI5682", (unsigned long)&acp3x_5682}, + { "AMDI1015", (unsigned long)&acp3x_1015}, {}, }; MODULE_DEVICE_TABLE(acpi, acp3x_audio_acpi_match); @@ -390,5 +444,6 @@ static struct platform_driver acp3x_audio = { module_platform_driver(acp3x_audio); MODULE_AUTHOR("akshu.agrawal@amd.com"); -MODULE_DESCRIPTION("ALC5682 & MAX98357 audio support"); +MODULE_AUTHOR("Vishnuvardhanrao.Ravulapati@amd.com"); +MODULE_DESCRIPTION("ALC5682 ALC1015 & MAX98357 audio support"); MODULE_LICENSE("GPL v2"); -- 2.17.1