Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1574268ybz; Thu, 30 Apr 2020 01:37:32 -0700 (PDT) X-Google-Smtp-Source: APiQypIGhtDdcb2eOefQ8XVl48A2WFUtrg1yD7HpTP2yBPl0eKUHVRTjfxlPyNViHAlKrx4nRuBf X-Received: by 2002:a50:f1d6:: with SMTP id y22mr1559830edl.298.1588235852179; Thu, 30 Apr 2020 01:37:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588235852; cv=none; d=google.com; s=arc-20160816; b=IwZ/cHXbGjHBLMDt7pXDFzVufb6PeYSZMADMpIcYPKDRVbLJIEPDn7N9yXCNg2eOnE qoHv+tv4Nuxz9YhzRxUZM0odXiOG9GuWL8gjrKTZSnkwXhL+fHcR5BsygZpkTFr+tPR7 SJG9PN3Zy7HDHpVrjn/26E8BfkCOvcS+vO+IzCN2JUUDehbeSeUrwztSlPGg5K7F8BGd SnzJDXZx9WvvBb1PBgLKjWD0y1YoeMJPU6/QD7wRsUtOj4aSdWSx/DQD65RkBWS5ejbB nVyZhyntLA8J06mj6cnfqVGSQkg70pknqC6zxkAACGQLvWScYEWrS3E/YZ2LUZsnTFP+ sWlw== 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=/TG5irCx4/nv0rA3PAo8sOpr7/XEn5Yg8PncgwSkuxw=; b=dyo2Znl1c6qzkOyqTuJ0W+lc0tgPZjLydK9YrHBBc8kTAmR7emSicy4F6i+KkxMs7l atLvomB0ilAfNG3WrANCiR7BBqHHGTucwquJAGADcAleWR6C/lG3CLhgTS5gi5m8XxX3 vHX2L/NrHgScYSi7nhDdnXgZ1jB4AXcPmMTWynZaeFGRtKznXPFIVbuNLgP9w3rfKaPF fB/WH9in3tA1dtW8IuVUYgmtPiLuIiBAGCqu6FuliOylaUazzu/AUHAIy+qMSUW6rYPA XFQDk/eXETzlw5VXVBdstCcoXy8xs5xlO67MTkv8A0kAWxBQiQRjZzOhnB/z06I5auOh j9pQ== 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 dp18si6811981ejc.498.2020.04.30.01.37.08; Thu, 30 Apr 2020 01:37:32 -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 S1726816AbgD3IdY (ORCPT + 99 others); Thu, 30 Apr 2020 04:33:24 -0400 Received: from youngberry.canonical.com ([91.189.89.112]:38539 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726412AbgD3IdX (ORCPT ); Thu, 30 Apr 2020 04:33:23 -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 1jU4d5-0002xY-Dn; Thu, 30 Apr 2020 08:33:12 +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 3/3] ALSA: hda/realtek - Add LED class support for micmute LED Date: Thu, 30 Apr 2020 16:32:53 +0800 Message-Id: <20200430083255.5093-3-kai.heng.feng@canonical.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200430083255.5093-1-kai.heng.feng@canonical.com> References: <20200430083255.5093-1-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 --- sound/pci/hda/patch_realtek.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index 6f164ccddde3..82eb7624bbba 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,24 @@ static void alc_gpio_micmute_update(struct hda_codec *codec) spec->gen.micmute_led.led_value); } +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", +}; + /* 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 +4129,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 +4142,11 @@ 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); + + 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"); } } -- 2.17.1