Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp4979886imm; Fri, 18 May 2018 14:10:53 -0700 (PDT) X-Google-Smtp-Source: AB8JxZo6BJygPi29Gf0oicf6rWyB39JSRjGm4mWqkgCazIStY/zMvb0kC1k8w53BtW0GE4L6JZSm X-Received: by 2002:a65:6005:: with SMTP id m5-v6mr8717098pgu.241.1526677853017; Fri, 18 May 2018 14:10:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526677852; cv=none; d=google.com; s=arc-20160816; b=Z8a7nGdmkE7meJh77Ign2cKYQJ+GvnSXbaMSm//axcseuXDcnakjGCBUxeoubK9ttG VUpESPNp9xxeKFDLGKQYA71EJjRWOshNeBO0mVH1ZOXk7J5mx2Q0D+oDDVWosWJeM3MJ 0XwyonbDZha4rvOvg/dfxU+rRqddNlQNhWNPtRv75iCzghGs/A1TYIckEPIK9MrPOGME 8DWfHFiQFypQDf5WuotWL+EmoYOyoik8pK0xfG5HU+fsaRVRQGgAmCxpysv1+jxJDT24 NnQbG+hR8duWefGlaIOYkbc2NKw1dNc8znK5/HrdVBTA1aEdQxFIlTtz6phsxtofBk3q oTAQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=kc0ysy7mbWeqpPAvgNwyFpzlu4rlVsNoqJPljj02VcU=; b=Dcs8mBb3hvLxT2Eichf+vyla8CdtB9cSKw5OoIUFSfv8l4g47b5fpGB07wyXlnx37x idvc3bKefgbyPCvNhbbKdVhiwYBF6P2tdQQWkvTmfdAAKxwigTj/PCgTv4ti85VcPfDy cuzJqKM5b7Qob++buURolkjEX1B7daVrUuFLzD7+/SrXUSCh396zCZJFdpDd1up2adrn P8xiHpMPje026OZc2PcHVdZOsajGOpQ4tbcoCtVJy4nXsG0dY3NHVdEbS1m9/xWI68RC NYHs7u2Zey+7Mu40ushj6SkJo4DuMqt63HD5fihVmczVYm7HNEgfaNajmWEpLxtvnuXG FDfg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=adR8LhGM; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x10-v6si6471751pgr.45.2018.05.18.14.10.38; Fri, 18 May 2018 14:10:52 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=adR8LhGM; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752263AbeERVKQ (ORCPT + 99 others); Fri, 18 May 2018 17:10:16 -0400 Received: from mail-lf0-f65.google.com ([209.85.215.65]:42070 "EHLO mail-lf0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751942AbeERVKI (ORCPT ); Fri, 18 May 2018 17:10:08 -0400 Received: by mail-lf0-f65.google.com with SMTP id b18-v6so15865520lfa.9; Fri, 18 May 2018 14:10:06 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=kc0ysy7mbWeqpPAvgNwyFpzlu4rlVsNoqJPljj02VcU=; b=adR8LhGMoEbYbloHK9UtNM2pKgH4DqNPYvPF6r/oi4C1jgWpcDljlRjz6NZYFSjYgm VXA5g70lZmrwymmSvyOE02lJEKWN9jAgsgdVPwO8V36j/E13dn93+oHIbzwFRP/SbAKX +QiPB5/3hPZpxphExUJwN1wyBbH4QLMqeirhjp9XRBvfIHk4dPWKIhr/T51UrCc8MosJ x/jED5tmhP/fup80HSAEK8M4Uqlik7TSGDDuu6tMmTbfXO1pzTDeIBmVAyv4z4MF19X6 B5jCiK1wNSOX9lDZuweGuDAMOas44mvQ/Pi7EmCKLyF7FHCrEUGVa91rqm9ZKRpVn2d3 agtA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=kc0ysy7mbWeqpPAvgNwyFpzlu4rlVsNoqJPljj02VcU=; b=U46Ko5K4RPooE0kTBnnPuECRJ5AUT06dDPmfPFzhUJc3CXga+zclzOvjfXXnDQgVuZ 0qF0A6CSpLfP/w05/zu3o/phhv+CGQGBt3rCMp47D5BBqO4jMTAP/CTVZpP0mjIm6EL+ iyfoSpm3RI+qy4mW1oY0qBjuERosjhO6SDy9wcNUcDW4FKv4XCzhsodEfmpvZiNcSOFt 3QMh4fgW2+jeUjsJqB/quSsPVxA8a8VmTI2VfR1ZdNOeJCp6VRoTBWBCrGi0nmqX7n3h RKo3YGu10qXqcbIqRfVogfCUR1cAMJm1S8bmJvi+KWZVVIPxLjFEZmJ9vSOzkgVgt5Fx Og6g== X-Gm-Message-State: ALKqPwcI2aIbZ2IWDMSRHEhdZS20oLamOTMwdpu9/qA4RcYYIA5IuJR/ d4W+4QMekZxSMHxXTOCcl3s= X-Received: by 2002:a19:5e4f:: with SMTP id z15-v6mr22840871lfi.129.1526677805861; Fri, 18 May 2018 14:10:05 -0700 (PDT) Received: from localhost.localdomain (apn-31-0-34-132.dynamic.gprs.plus.pl. [31.0.34.132]) by smtp.gmail.com with ESMTPSA id 23-v6sm2057026lfw.64.2018.05.18.14.10.02 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 18 May 2018 14:10:05 -0700 (PDT) From: Janusz Krzysztofik To: Tony Lindgren , Dmitry Torokhov , Boris Brezillon , Tomi Valkeinen , Mark Brown Cc: Aaro Koskinen , Richard Weinberger , Peter Ujfalusi , Jarkko Nikula , Liam Girdwood , linux-arm-kernel@lists.infradead.org, linux-omap@vger.kernel.org, linux-kernel@vger.kernel.org, linux-input@vger.kernel.org, linux-mtd@lists.infradead.org, linux-fbdev@vger.kernel.org, alsa-devel@alsa-project.org, Janusz Krzysztofik Subject: [PATCH 3/6] ASoC: ams_delta: use GPIO lookup table Date: Fri, 18 May 2018 23:09:51 +0200 Message-Id: <20180518210954.29044-3-jmkrzyszt@gmail.com> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180518210954.29044-1-jmkrzyszt@gmail.com> References: <20180518210954.29044-1-jmkrzyszt@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Now as the Amstrad Delta board provides GPIO lookup tables, switch from GPIO numbers to GPIO descriptors and use the table to locate required GPIO pins. The card uses two pins, one for jack and the other for voice modem codec DAI control. For jack pin, remove hardcoded GPIO number and use GPIO descriptor based variant of jack GPIO initialization. For modem_codec pin, declare static variable for storing its GPIO descriptor, obtain it on card initialization and replace obsolete ams_delta_latch2_write() with gpiod_set_value(). For that to work, don't request the modem_codec pin from the board init code anymore. If the modem_codec GPIO lookup fails, skip initialization of functionality of the card which depends on its availability. Pin naming used by the driver should be followed while respective GPIO lookup table is initialized by a board init code. Created and tested against linux-4.17-rc3, on top of patch 1/6 "ARM: OMAP1: ams-delta: add GPIO lookup tables" Signed-off-by: Janusz Krzysztofik --- arch/arm/mach-omap1/board-ams-delta.c | 5 ----- sound/soc/omap/ams-delta.c | 38 +++++++++++++++++++---------------- 2 files changed, 21 insertions(+), 22 deletions(-) diff --git a/arch/arm/mach-omap1/board-ams-delta.c b/arch/arm/mach-omap1/board-ams-delta.c index 4b78e73f8bf7..80f54cb54276 100644 --- a/arch/arm/mach-omap1/board-ams-delta.c +++ b/arch/arm/mach-omap1/board-ams-delta.c @@ -259,11 +259,6 @@ static const struct gpio latch_gpios[] __initconst = { .flags = GPIOF_OUT_INIT_LOW, .label = "scard_cmdvcc", }, - { - .gpio = AMS_DELTA_GPIO_PIN_MODEM_CODEC, - .flags = GPIOF_OUT_INIT_LOW, - .label = "modem_codec", - }, { .gpio = AMS_DELTA_LATCH2_GPIO_BASE + 14, .flags = GPIOF_OUT_INIT_LOW, diff --git a/sound/soc/omap/ams-delta.c b/sound/soc/omap/ams-delta.c index 77a30f0f0c96..4dce494dfbd3 100644 --- a/sound/soc/omap/ams-delta.c +++ b/sound/soc/omap/ams-delta.c @@ -22,7 +22,7 @@ * */ -#include +#include #include #include #include @@ -32,7 +32,6 @@ #include -#include #include #include "omap-mcbsp.h" @@ -213,7 +212,6 @@ static const struct snd_kcontrol_new ams_delta_audio_controls[] = { static struct snd_soc_jack ams_delta_hook_switch; static struct snd_soc_jack_gpio ams_delta_hook_switch_gpios[] = { { - .gpio = 4, .name = "hook_switch", .report = SND_JACK_HEADSET, .invert = 1, @@ -259,6 +257,7 @@ static struct timer_list cx81801_timer; static bool cx81801_cmd_pending; static bool ams_delta_muted; static DEFINE_SPINLOCK(ams_delta_lock); +static struct gpio_desc *gpiod_modem_codec; static void cx81801_timeout(struct timer_list *unused) { @@ -272,7 +271,7 @@ static void cx81801_timeout(struct timer_list *unused) /* Reconnect the codec DAI back from the modem to the CPU DAI * only if digital mute still off */ if (!muted) - ams_delta_latch2_write(AMS_DELTA_LATCH2_MODEM_CODEC, 0); + gpiod_set_value(gpiod_modem_codec, 0); } /* Line discipline .open() */ @@ -381,8 +380,7 @@ static void cx81801_receive(struct tty_struct *tty, /* Apply config pulse by connecting the codec to the modem * if not already done */ if (apply) - ams_delta_latch2_write(AMS_DELTA_LATCH2_MODEM_CODEC, - AMS_DELTA_LATCH2_MODEM_CODEC); + gpiod_set_value(gpiod_modem_codec, 1); break; } } @@ -432,8 +430,7 @@ static int ams_delta_digital_mute(struct snd_soc_dai *dai, int mute) spin_unlock_bh(&ams_delta_lock); if (apply) - ams_delta_latch2_write(AMS_DELTA_LATCH2_MODEM_CODEC, - mute ? AMS_DELTA_LATCH2_MODEM_CODEC : 0); + gpiod_set_value(gpiod_modem_codec, !!mute); return 0; } @@ -469,14 +466,6 @@ static int ams_delta_cx20442_init(struct snd_soc_pcm_runtime *rtd) /* Store a pointer to the codec structure for tty ldisc use */ cx20442_codec = rtd->codec_dai->component; - /* Set up digital mute if not provided by the codec */ - if (!codec_dai->driver->ops) { - codec_dai->driver->ops = &ams_delta_dai_ops; - } else { - ams_delta_ops.startup = ams_delta_startup; - ams_delta_ops.shutdown = ams_delta_shutdown; - } - /* Add hook switch - can be used to control the codec from userspace * even if line discipline fails */ ret = snd_soc_card_jack_new(card, "hook_switch", SND_JACK_HEADSET, @@ -486,7 +475,7 @@ static int ams_delta_cx20442_init(struct snd_soc_pcm_runtime *rtd) "Failed to allocate resources for hook switch, " "will continue without one.\n"); else { - ret = snd_soc_jack_add_gpios(&ams_delta_hook_switch, + ret = snd_soc_jack_add_gpiods(card->dev, &ams_delta_hook_switch, ARRAY_SIZE(ams_delta_hook_switch_gpios), ams_delta_hook_switch_gpios); if (ret) @@ -495,6 +484,21 @@ static int ams_delta_cx20442_init(struct snd_soc_pcm_runtime *rtd) "will continue with hook switch inactive.\n"); } + gpiod_modem_codec = devm_gpiod_get(card->dev, "modem_codec", + GPIOD_OUT_HIGH); + if (IS_ERR(gpiod_modem_codec)) { + dev_warn(card->dev, "Failed to obtain modem_codec GPIO\n"); + return 0; + } + + /* Set up digital mute if not provided by the codec */ + if (!codec_dai->driver->ops) { + codec_dai->driver->ops = &ams_delta_dai_ops; + } else { + ams_delta_ops.startup = ams_delta_startup; + ams_delta_ops.shutdown = ams_delta_shutdown; + } + /* Register optional line discipline for over the modem control */ ret = tty_register_ldisc(N_V253, &cx81801_ops); if (ret) { -- 2.16.1