Received: by 2002:a5d:9c59:0:0:0:0:0 with SMTP id 25csp93288iof; Sun, 5 Jun 2022 22:08:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwV6mDt2bHes/mo0GNBXrgeCP74HvLy6zZxUEWb5t26NkamocJ0xJc2T/8rtQpR7yN4tzT8 X-Received: by 2002:a17:90b:390c:b0:1e2:d499:8899 with SMTP id ob12-20020a17090b390c00b001e2d4998899mr46044696pjb.161.1654492123859; Sun, 05 Jun 2022 22:08:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654492123; cv=none; d=google.com; s=arc-20160816; b=GUX3TXCF3CtpVKgNsgWNmpOhOtn6BN+ljeFfiUlxKMdcveUQN0XFWL/AKxFne+Zw/d oJSrYt0JWSUvgI4KWOYV/sg6/lq8fIa3Jl/b0TNNizHi3hO++KNB+GWgIUzKdXM/oaMo KYjEdxJO4wF6+qaVvSfIrKeK8wKotB2hw+ghARH9m/qG069CAHG8icXUp0qFOGr3c89k 7IeLGtvuMxSnwT7TD4GD9HL9kQ6W82jxTwCiMyB8LUQx3W5QJkDK64KNGIRffhijHlXR gTF7wKzTB3o8X0r7tK/41kkfQaXmmz/xxu53xiX5aFb6lJkGiM3LcKTOib6SunsqhTu8 bb8g== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=rN4uSGBUZ3RdZR/PEkQRxWRTSnzwFgkSIMknkFqSH+c=; b=DJnQ8tNHGeVSRis+GJlhXwb0cylmUJBbKR94XhEkhi0sq5qmIZAe0dhBkMht3kC0YX Ty1YVY5HfFfLVP/fM8G9yru5e/BoVr0fjgVRXbQMz8kMlc6zSfP93nf9YCa+fvbgAuNX G4b83NTZZRAEBwg3wXSdAwDMSGTSyK+PvZKkpPcTXIsct19bnfcT7fV2Ep1RoqS3S5an Wd2kgs2peagmfz0hny+WZYNuRnaHokVwBf35fe2fnUKi73a6I6G9NhtLrmLhSNx5OOLC UVafP8e7z7N1bg60TLr0kVPm9ntF+/7sTHpUd+6A1fc67hMU0UppdCRHwcs7ulcSe7Qi yqEw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=wkDp1dJc; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id n17-20020a170903111100b0015892288d6asi20893203plh.386.2022.06.05.22.08.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 05 Jun 2022 22:08:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=wkDp1dJc; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id E2C13168D28; Sun, 5 Jun 2022 21:21:16 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346457AbiFCSDa (ORCPT + 99 others); Fri, 3 Jun 2022 14:03:30 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58420 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1347270AbiFCRwK (ORCPT ); Fri, 3 Jun 2022 13:52:10 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A3B8113D16; Fri, 3 Jun 2022 10:51:55 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 67851B82419; Fri, 3 Jun 2022 17:51:54 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id BEB3CC385A9; Fri, 3 Jun 2022 17:51:52 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1654278713; bh=xF4TwzXvI/vuD2ZvHNLqd2yjZu07Y0fkHy+dpnoz9IY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=wkDp1dJcD5SSNhf+DLlVz8jsBdsVQMLkBxRErVY6TFjTiR2xOZW0zG6al8MXiuo4J WDdy5VGovXDMNSVVH+M0H5N86BWkTlfSMoAXrwuc1pTguTKKpCkFepVzPcqsycE/sl 0ndQq5z8VKpMrN+kTtE6bP6Gb1fVZpToOOiBhoH0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Craig McLure , Jaroslav Kysela , Takashi Iwai Subject: [PATCH 5.15 39/66] ALSA: usb-audio: Configure sync endpoints before data Date: Fri, 3 Jun 2022 19:43:19 +0200 Message-Id: <20220603173821.802500760@linuxfoundation.org> X-Mailer: git-send-email 2.36.1 In-Reply-To: <20220603173820.663747061@linuxfoundation.org> References: <20220603173820.663747061@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable 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: Craig McLure commit 0e85a22d01dfe9ad9a9d9e87cd4a88acce1aad65 upstream. Devices such as the TC-Helicon GoXLR require the sync endpoint to be configured in advance of the data endpoint in order for sound output to work. This patch simply changes the ordering of EP configuration to resolve this. Fixes: bf6313a0ff76 ("ALSA: usb-audio: Refactor endpoint management") BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=215079 Signed-off-by: Craig McLure Reviewed-by: Jaroslav Kysela Cc: Link: https://lore.kernel.org/r/20220524062115.25968-1-tiwai@suse.de Signed-off-by: Takashi Iwai Signed-off-by: Greg Kroah-Hartman --- sound/usb/pcm.c | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/sound/usb/pcm.c b/sound/usb/pcm.c index 6d699065e81a..b470404a5376 100644 --- a/sound/usb/pcm.c +++ b/sound/usb/pcm.c @@ -439,16 +439,21 @@ static int configure_endpoints(struct snd_usb_audio *chip, /* stop any running stream beforehand */ if (stop_endpoints(subs, false)) sync_pending_stops(subs); + if (subs->sync_endpoint) { + err = snd_usb_endpoint_configure(chip, subs->sync_endpoint); + if (err < 0) + return err; + } err = snd_usb_endpoint_configure(chip, subs->data_endpoint); if (err < 0) return err; snd_usb_set_format_quirk(subs, subs->cur_audiofmt); - } - - if (subs->sync_endpoint) { - err = snd_usb_endpoint_configure(chip, subs->sync_endpoint); - if (err < 0) - return err; + } else { + if (subs->sync_endpoint) { + err = snd_usb_endpoint_configure(chip, subs->sync_endpoint); + if (err < 0) + return err; + } } return 0; -- 2.36.1