Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp3991413ybz; Mon, 20 Apr 2020 13:22:07 -0700 (PDT) X-Google-Smtp-Source: APiQypJXLLxu2QXPqhuniofG2pObfEDhxj4hQ8LBOZMyLdeyb/w+GJVxCSZwjtv2cZ2bcxADBpNA X-Received: by 2002:a17:906:3f88:: with SMTP id b8mr18439400ejj.301.1587414126863; Mon, 20 Apr 2020 13:22:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587414126; cv=none; d=google.com; s=arc-20160816; b=RydyOoPLXa8gNQtZCTlNg30/zDq4lNTcyxxc0+Tr5OAH1QAJjg2rR67Hp3mHycw04K 8NCIYnlfCMsJLR+RFKL5U9LhU9HjJCQAHBzaoBCNBj8i/z3ZZiG7CgRLj3NX8AJ8lO/+ Ed6jOYQOVpRvhhVg+7P9Oepxap355lRNefeLP131K3VoO8OXOjZjNajJjX+2vJIt+GqR ipAUilmpUr/huvMUovcF/yh2kKA3Janodu2rvVGwQqr/oZWJtpL7f9NAirDJJ6ufQP+c /nY3ojeCiGod6s5YzMgsY1nyTEMOzj2Yw4od54itozKdu1NYWAJPrjvMD2pWcW6u2n86 Z7Fg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=WaNkYITjpr2SJjowiiyR8sRi3eo+gyei8bJaiA5cLw0=; b=f/7tip2oM8YGiGGk2B26avWNX4DjnA+/iX1zKWmB0uHOH5+joNX4D9FeWaPq5BbkRi tDTLPAY2K4HMNWqruMsEHhjw57K0WWDaNix9Bf7vQvoEOdJ2YUZ/r/fTAo8c75vSnAGV zDPNt3buRNc9ViJIthtdHEyfQ5AvQJgIlfEzGGKIeWQ9IPVTlRynytAtlETrYuYGQYg0 FpNoULIaZ/RtCcp4nuXIXW6ZiXZ0G/kkD7ylXRu6ZnDrCdnMvSagNJAR74vHJRfZdxro WG4050DVhUp5/EVLYZAh8/kP4eXW0M9DdZfL/K2/J2gOjx74SIHtzSsKcLgEp+ySH68D Kl2g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Y3EwKK9Y; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h4si301670edz.258.2020.04.20.13.21.42; Mon, 20 Apr 2020 13:22:06 -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=@gmail.com header.s=20161025 header.b=Y3EwKK9Y; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726055AbgDTUU0 (ORCPT + 99 others); Mon, 20 Apr 2020 16:20:26 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49122 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725897AbgDTUU0 (ORCPT ); Mon, 20 Apr 2020 16:20:26 -0400 Received: from mail-wr1-x444.google.com (mail-wr1-x444.google.com [IPv6:2a00:1450:4864:20::444]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 85D78C061A0C for ; Mon, 20 Apr 2020 13:20:24 -0700 (PDT) Received: by mail-wr1-x444.google.com with SMTP id k11so13833392wrp.5 for ; Mon, 20 Apr 2020 13:20:24 -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:mime-version :content-transfer-encoding; bh=WaNkYITjpr2SJjowiiyR8sRi3eo+gyei8bJaiA5cLw0=; b=Y3EwKK9Y5HCD6i0fmisN2pj7R3M+p4Ukl2HwAWgKkuyHdWJOKD3hAvOAs3MFDiaOmX SPpTk7WcQJIAQhUyNqkiLDyC88nU1aCgLqZke94+xejuqmQmQMYxmpdaYYWK24xtbfVH CMRWCyZ0/qhfHG6rQRRlj/JIrhY1I3JbsM3Js69YIS5plZecPEqRq1j2c559p2BIJNWg o7z+8IfmeUV7Z+MvizXjkbo5F8AU/5Oir5+W66XBFQEZdNxIuSw1vMCqd1UGd+MVTvsC p1w+LTV8fsKfE5joQamgpZdFJ+S8jCHXzFRolk+p83sJRHPf2THpkwlAme7aYtn8UBAw 9tOw== 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:mime-version :content-transfer-encoding; bh=WaNkYITjpr2SJjowiiyR8sRi3eo+gyei8bJaiA5cLw0=; b=gSanplsXgSpusfBSEKf6LZbxofJiVHKfm7SYQFQL6+cLzACHTGLHw0+o94oQ8Jgp1u osSYmbWqyjGnieGvSXIfrohBiFKVkLnXqq7qXc6u5v/lGjhM6GF2z6puufJxQeDmW649 c4eRRLoucl15KvN3ZKqhP7VnfzBE1uQY2IgKtAQR8j+aJvUDofxoeBBsomS6PTGxKce/ RZH2S6+Q/05C7Sq6GB0L+ZG+RKMdd4u9RtOtPEccRq5OMwtDi/3Ja4eYBQ4FLBaHN1u7 +S/sVrwUyVM1Aar0QDwLdfbHkVCxFoKDErepLR6ZrqmSt45Hk7OkAvqXldGHc7Mf5d/I x7zA== X-Gm-Message-State: AGi0PuYky9iRH2xHV4yjHpoxWxCNEJrODVnsABpIQxXmCaHyHyQOqWOo aF+yn5SHYtnC6yw3TjzYdlo= X-Received: by 2002:a5d:4b49:: with SMTP id w9mr20692680wrs.359.1587414023070; Mon, 20 Apr 2020 13:20:23 -0700 (PDT) Received: from localhost.localdomain ([91.221.170.230]) by smtp.googlemail.com with ESMTPSA id o18sm773682wrp.23.2020.04.20.13.20.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 20 Apr 2020 13:20:22 -0700 (PDT) From: Gregor Pintar To: tiwai@suse.com, perex@perex.cz Cc: linux-kernel@vger.kernel.org, alsa-devel@alsa-project.org, grpintar@gmail.com Subject: [PATCH] ALSA: usb-audio: Add quirk for Focusrite Scarlett 2i2 Date: Mon, 20 Apr 2020 22:19:37 +0200 Message-Id: <20200420201937.12634-1-grpintar@gmail.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Force it to use asynchronous playback. Same quirk has already been added for Focusrite Scarlett Solo (2nd gen) with a commit 46f5710f0b88 ("ALSA: usb-audio: Add quirk for Focusrite Scarlett Solo"). This also seems to prevent regular clicks when playing at 44100Hz on Scarlett 2i2 (2nd gen). I did not notice any side effects. Signed-off-by: Gregor Pintar --- sound/usb/quirks-table.h | 84 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 84 insertions(+) diff --git a/sound/usb/quirks-table.h b/sound/usb/quirks-table.h index e009d584e..bc936bf79 100644 --- a/sound/usb/quirks-table.h +++ b/sound/usb/quirks-table.h @@ -2840,6 +2840,90 @@ YAMAHA_DEVICE(0x7010, "UB99"), } } }, +{ + /* + * Focusrite Scarlett 2i2 2nd generation + * Reports that playback should use Synch: Synchronous + * while still providing a feedback endpoint. Synchronous causes + * snapping on some sample rates. + * Force it to use Synch: Asynchronous. + */ + USB_DEVICE(0x1235, 0x8202), + .driver_info = (unsigned long) &(const struct snd_usb_audio_quirk) { + .ifnum = QUIRK_ANY_INTERFACE, + .type = QUIRK_COMPOSITE, + .data = (const struct snd_usb_audio_quirk[]) { + { + .ifnum = 1, + .type = QUIRK_AUDIO_FIXED_ENDPOINT, + .data = &(const struct audioformat) { + .formats = SNDRV_PCM_FMTBIT_S32_LE, + .channels = 2, + .iface = 1, + .altsetting = 1, + .altset_idx = 1, + .attributes = 0, + .endpoint = 0x01, + .ep_attr = USB_ENDPOINT_XFER_ISOC | + USB_ENDPOINT_SYNC_ASYNC, + .protocol = UAC_VERSION_2, + .rates = SNDRV_PCM_RATE_44100 | + SNDRV_PCM_RATE_48000 | + SNDRV_PCM_RATE_88200 | + SNDRV_PCM_RATE_96000 | + SNDRV_PCM_RATE_176400 | + SNDRV_PCM_RATE_192000, + .rate_min = 44100, + .rate_max = 192000, + .nr_rates = 6, + .rate_table = (unsigned int[]) { + 44100, 48000, 88200, + 96000, 176400, 192000 + }, + .clock = 41 + } + }, + { + .ifnum = 2, + .type = QUIRK_AUDIO_FIXED_ENDPOINT, + .data = &(const struct audioformat) { + .formats = SNDRV_PCM_FMTBIT_S32_LE, + .channels = 2, + .iface = 2, + .altsetting = 1, + .altset_idx = 1, + .attributes = 0, + .endpoint = 0x82, + .ep_attr = USB_ENDPOINT_XFER_ISOC | + USB_ENDPOINT_SYNC_ASYNC | + USB_ENDPOINT_USAGE_IMPLICIT_FB, + .protocol = UAC_VERSION_2, + .rates = SNDRV_PCM_RATE_44100 | + SNDRV_PCM_RATE_48000 | + SNDRV_PCM_RATE_88200 | + SNDRV_PCM_RATE_96000 | + SNDRV_PCM_RATE_176400 | + SNDRV_PCM_RATE_192000, + .rate_min = 44100, + .rate_max = 192000, + .nr_rates = 6, + .rate_table = (unsigned int[]) { + 44100, 48000, 88200, + 96000, 176400, 192000 + }, + .clock = 41 + } + }, + { + .ifnum = 3, + .type = QUIRK_IGNORE_INTERFACE + }, + { + .ifnum = -1 + } + } + } +}, /* Access Music devices */ { -- 2.20.1