Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1868101ybz; Thu, 30 Apr 2020 06:57:54 -0700 (PDT) X-Google-Smtp-Source: APiQypKczuzu5Z0rI7nAXRSUxrw0fCZav1d4HJAl7MxwdLXCJprRs1eSGG5p4LMkokp9hhcIySOm X-Received: by 2002:a17:906:315a:: with SMTP id e26mr2755824eje.53.1588255073967; Thu, 30 Apr 2020 06:57:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588255073; cv=none; d=google.com; s=arc-20160816; b=Lj2F+zd2EboEDQ1oxSKi0aom1htgZqqNE9+mbBpRvtKUNxsNf2yrfS9sCTEKKLuQ8L nIEFZhpHLnEhnYCQgmHYYX350R/NiIPP4wmU1N+38LHx2bKKfJsKFdaoPRQ/IAHFmz4a 2BAgpjODp3gMU+jROl3nVcdOxNWnw+OF528xmVN4jbvf+dsbOWqW7x0VmMH2YInpH1Rw LGhnx6APcwT1YXnz5qXDFC6AOflO5buQS7wE0FOQXQQs8yI5pKc0cq7OAOOUB1HJG/ap rHeMErUUmqZYaX16mTW/24QskO87FAbmbKLRHAro/5nCuCjItb/9DQdx4xeo7NUMltv1 ObcA== 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; bh=SYnTKe2vRVzWGeCnK87ZuWj7swEio0YRDaV/TK8ZKys=; b=KVj+ubUIp2Fpvj2wfkQAN9mM+6jAc1QqLS/I8sBgyWyT1vg3r9b5myjpetfGFl5Fcw AGHGrEFVO2d6uRh0gk7jdKDQ3pNhmbE5pVJyDzm+ewD/wRadGbYU774hdgVFmgwBihCz XiClGZu4v8K14wKHdD/bItLaMJXMcY2anJ34MQxxTijsw1MEZgiXJUbwHT67zQOp4kf/ GPzwhcC3ZfKqh9TYJo/WYoF48d9WvSSvWDU8ylSe/Idan9pONSIjrT47rEpg0sKsMC4y jADPPfe0eZECL0ucBw/aTvoof6z9DmEODFDVkMz163uyEoyFZcU4Nr6utv1q9z6QfaIH udVg== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i20si5342198eds.581.2020.04.30.06.57.30; Thu, 30 Apr 2020 06:57:53 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728658AbgD3NxP (ORCPT + 99 others); Thu, 30 Apr 2020 09:53:15 -0400 Received: from youngberry.canonical.com ([91.189.89.112]:48478 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728470AbgD3Nwm (ORCPT ); Thu, 30 Apr 2020 09:52:42 -0400 Received: from 61-220-137-37.hinet-ip.hinet.net ([61.220.137.37] helo=localhost) by youngberry.canonical.com with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.86_2) (envelope-from ) id 1jU9bs-0004lc-NW; Thu, 30 Apr 2020 13:52:17 +0000 From: Kai-Heng Feng To: tiwai@suse.com Cc: Kai-Heng Feng , Jaroslav Kysela , Kailang Yang , Hui Wang , Jian-Hong Pan , Tomas Espeleta , Thomas Hebb , =?UTF-8?q?Micha=C5=82=20Miros=C5=82aw?= , alsa-devel@alsa-project.org (moderated list:SOUND), linux-kernel@vger.kernel.org (open list) Subject: [PATCH v2 3/3] ALSA: hda/realtek - Add LED class support for micmute LED Date: Thu, 30 Apr 2020 21:52:07 +0800 Message-Id: <20200430135209.14703-1-kai.heng.feng@canonical.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200430083255.5093-3-kai.heng.feng@canonical.com> References: <20200430083255.5093-3-kai.heng.feng@canonical.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently DMIC controls micmute LED via "audio mute LED trigger". However, unlike Dell and Lenovo platforms, HP platforms don't provide a way to control micmute LED via ACPI, it's controlled by HDA codec instead. So let's register an LED class for micmute so other subsystems like DMIC can facilitate the codec-controlled LED. Signed-off-by: Kai-Heng Feng --- v2: - Only compile the code when CONFIG_LEDS_TRIGGER_AUDIO is reachable. sound/pci/hda/patch_realtek.c | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index 6f164ccddde3..eae672cb6118 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c @@ -17,6 +17,7 @@ #include #include #include +#include #include #include #include @@ -4103,6 +4104,26 @@ static void alc_gpio_micmute_update(struct hda_codec *codec) spec->gen.micmute_led.led_value); } +#if IS_REACHABLE(CONFIG_LEDS_TRIGGER_AUDIO) +static int micmute_led_set(struct led_classdev *led_cdev, + enum led_brightness brightness) +{ + struct hda_codec *codec = dev_to_hda_codec(led_cdev->dev->parent); + struct alc_spec *spec = codec->spec; + + alc_update_gpio_led(codec, spec->gpio_mic_led_mask, + spec->micmute_led_polarity, !!brightness); + return 0; +} + +static struct led_classdev micmute_led_cdev = { + .name = "hda::micmute", + .max_brightness = 1, + .brightness_set_blocking = micmute_led_set, + .default_trigger = "audio-micmute", +}; +#endif + /* setup mute and mic-mute GPIO bits, add hooks appropriately */ static void alc_fixup_hp_gpio_led(struct hda_codec *codec, int action, @@ -4110,6 +4131,7 @@ static void alc_fixup_hp_gpio_led(struct hda_codec *codec, unsigned int micmute_mask) { struct alc_spec *spec = codec->spec; + int err; alc_fixup_gpio(codec, action, mute_mask | micmute_mask); @@ -4122,6 +4144,13 @@ static void alc_fixup_hp_gpio_led(struct hda_codec *codec, if (micmute_mask) { spec->gpio_mic_led_mask = micmute_mask; snd_hda_gen_add_micmute_led(codec, alc_gpio_micmute_update); + +#if IS_REACHABLE(CONFIG_LEDS_TRIGGER_AUDIO) + micmute_led_cdev.brightness = ledtrig_audio_get(LED_AUDIO_MICMUTE); + err = devm_led_classdev_register(&codec->core.dev, &micmute_led_cdev); + if (err) + codec_warn(codec, "failed to register micmute LED\n"); +#endif } } -- 2.17.1