Received: by 2002:a05:7412:6592:b0:d7:7d3a:4fe2 with SMTP id m18csp2113275rdg; Sun, 13 Aug 2023 09:44:40 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEUx1nJ97ey1crCWfS1KCkMO7FoWJ6WQ8dK0Chp48CETzXHKFxLKanenNQ9QRDvrzefH9rO X-Received: by 2002:a05:6a00:24d3:b0:667:85e6:4e9 with SMTP id d19-20020a056a0024d300b0066785e604e9mr8089741pfv.24.1691945080347; Sun, 13 Aug 2023 09:44:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691945080; cv=none; d=google.com; s=arc-20160816; b=wHn23BRaXvyEwlpXyN1G3bxvdW8unwvodYpnNiZ3IrO0uR5Q0fLmAFclKCDvwa3VzK UxJjSlcW3gsDxi05XZIh4nlKpmjH8NefM5ZhON0L4BVqD1pFvTVChxoTKYj8Pcea63oc 64fiMfUC/+NFNEbUK1E4yZ29mtK5+svQ6pxZ/itcOx60DmHMgCQKkKnsK6SygKF0D3Li WdNd8ol2PpYecKVZgXcKOxTvy/7Og/vHxi5ycjInELuE8pgS+cjt1Q5i3ur2mkH09p/W OkxdZCs1gesjmRrAC9tn1cJao5H87Yv2FxEGAhacVkiQNK0PopiUC5uqjT5H2MyEIEvj 69tQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=6eFU5GDJtO+YQdzDnL0rf22SRUXfCmWFnLJw6z8xUWE=; fh=FbUp+93kJHEQASalhnZoI2ugLrZALYk8PmIKl7X2A70=; b=iFe4ZjWjjDup+9eTSQSZrSu3ZihJtFLIjSE2sjNYOtUuiC7wgVFp9JYOr4z8Y/rORw 2p9dub2ztRBls7qPz9na/Y7YJXP0ZaMfg4DqBPbSjgaflZiFU9PAsCPvUNrt9GtWQann 3iBHCEXhLnwvILpT4qHvTC16MiV+zGgU/It+BZm/BeDE8RzzhYePzgogHCf24PpWsVys HLNZCvuZK3FdnfksuW5EAdMKMdf/PNPiiM8headBTv8FxJ2pLvyF7ocl9PTaTm6E0YNf rZqnczuuX8BEKsvwRlzHMkjfywiQxUznj0IE3pxWALA+cn8EdeZLxDoDtEhwGUwiUVn9 RZjg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Jl4LESFG; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s7-20020a056a0008c700b0068760039afesi6921964pfu.99.2023.08.13.09.44.28; Sun, 13 Aug 2023 09:44:40 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Jl4LESFG; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232734AbjHMQKH (ORCPT + 99 others); Sun, 13 Aug 2023 12:10:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46244 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232742AbjHMQJn (ORCPT ); Sun, 13 Aug 2023 12:09:43 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EF9C31BD5; Sun, 13 Aug 2023 09:09:26 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 7B51A63930; Sun, 13 Aug 2023 16:08:33 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id EB8BEC433C8; Sun, 13 Aug 2023 16:08:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1691942912; bh=GS+Z5Ie8MPb08boeC76G752Mhn5+/4Pvwb++EA6lp+Y=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Jl4LESFGdfz1fzlrqwjfl3UplKx00kYmHpmYFxi5DiNHKDsC60Pa7vXsQ9+aZ8O53 rdYmuZjEtCDWv9QrT6g5h4obVyh7c1qLlo+FkNeBmbsOy0AbnDf7HNCvymzEX1VM1k /rXrkDVP5Un0k9kFrnkfyayFe4cjpvc0BsZj9U7CQ7hLpb40Rimg0dvUg+hMsblJBf +h5tlo9kuFhxne/sQ6tA4HpFPqJ+sLxy/uZAZBVMbw5DP8OPLnTyCgfPis03F5mIJ2 78HckGRm3UxivtwiWUCJu1AVGqceF9CvO8sJBTPW3JGkVONbQCKf3VxrTVH9sJ32pS Poup0qu4RLN+w== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Takashi Iwai , Sasha Levin , perex@perex.cz, tiwai@suse.com, jussi@sonarnerd.net, connerknoxpublic@gmail.com, ltyl@hem-e.com, aichao@kylinos.cn, alsa-devel@alsa-project.org Subject: [PATCH AUTOSEL 5.15 21/31] ALSA: usb-audio: Add quirk for Microsoft Modern Wireless Headset Date: Sun, 13 Aug 2023 12:05:54 -0400 Message-Id: <20230813160605.1080385-21-sashal@kernel.org> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20230813160605.1080385-1-sashal@kernel.org> References: <20230813160605.1080385-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore X-stable-base: Linux 5.15.126 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Takashi Iwai [ Upstream commit 3da435063777f8d861ba5a165344e3f75f839357 ] Microsoft Modern Wireless Headset (appearing on the host as "Microsoft USB Link") has a playback and a capture mixer volume/switch, but they are fairly broken. The descriptor reports wrong dB ranges for playback, and the capture volume/switch don't influence on the actual recording at all. Moreover, there seem instabilities in the connection, and at best, we should disable the runtime PM. So this ended up with a quirk entry for: - Correct the playback dB range; I picked up some reasonable values but it's a guess work - Disable the capture mixer; it's completely useless and confuses PA/PW - Suppress get-sample-rate, apply the delay for message handling, and suppress the auto-suspend The behavior of the wheel control on the headset is somehow flaky, too, but it's an issue of HID. Link: https://bugzilla.suse.com/show_bug.cgi?id=1207129 Link: https://lore.kernel.org/r/20230725092057.15115-1-tiwai@suse.de Signed-off-by: Takashi Iwai Signed-off-by: Sasha Levin --- sound/usb/mixer_maps.c | 14 ++++++++++++++ sound/usb/quirks.c | 3 +++ 2 files changed, 17 insertions(+) diff --git a/sound/usb/mixer_maps.c b/sound/usb/mixer_maps.c index 3f8f6056ff6a5..8e0915f02b26f 100644 --- a/sound/usb/mixer_maps.c +++ b/sound/usb/mixer_maps.c @@ -366,6 +366,15 @@ static const struct usbmix_name_map corsair_virtuoso_map[] = { { 0 } }; +/* Microsoft USB Link headset */ +/* a guess work: raw playback volume values are from 2 to 129 */ +static const struct usbmix_dB_map ms_usb_link_dB = { -3225, 0, true }; +static const struct usbmix_name_map ms_usb_link_map[] = { + { 9, NULL, .dB = &ms_usb_link_dB }, + { 10, NULL }, /* Headset Capture volume; seems non-working, disabled */ + { 0 } /* terminator */ +}; + /* ASUS ROG Zenith II with Realtek ALC1220-VB */ static const struct usbmix_name_map asus_zenith_ii_map[] = { { 19, NULL, 12 }, /* FU, Input Gain Pad - broken response, disabled */ @@ -625,6 +634,11 @@ static const struct usbmix_ctl_map usbmix_ctl_maps[] = { .id = USB_ID(0x1395, 0x0025), .map = sennheiser_pc8_map, }, + { + /* Microsoft USB Link headset */ + .id = USB_ID(0x045e, 0x083c), + .map = ms_usb_link_map, + }, { 0 } /* terminator */ }; diff --git a/sound/usb/quirks.c b/sound/usb/quirks.c index 8de572e774ddc..e5eab3b84b3f7 100644 --- a/sound/usb/quirks.c +++ b/sound/usb/quirks.c @@ -1747,6 +1747,9 @@ static const struct usb_audio_quirk_flags_table quirk_flags_table[] = { QUIRK_FLAG_IGNORE_CTL_ERROR), DEVICE_FLG(0x041e, 0x4080, /* Creative Live Cam VF0610 */ QUIRK_FLAG_GET_SAMPLE_RATE), + DEVICE_FLG(0x045e, 0x083c, /* MS USB Link headset */ + QUIRK_FLAG_GET_SAMPLE_RATE | QUIRK_FLAG_CTL_MSG_DELAY | + QUIRK_FLAG_DISABLE_AUTOSUSPEND), DEVICE_FLG(0x046d, 0x084c, /* Logitech ConferenceCam Connect */ QUIRK_FLAG_GET_SAMPLE_RATE | QUIRK_FLAG_CTL_MSG_DELAY_1M), DEVICE_FLG(0x046d, 0x0991, /* Logitech QuickCam Pro */ -- 2.40.1