Received: by 2002:ab2:6203:0:b0:1f5:f2ab:c469 with SMTP id o3csp2606676lqt; Mon, 22 Apr 2024 16:26:57 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUdc6+FLHIOYThKxQVsBSTuS0TwUhT4CNNEB19qohsnUTabU5H240WaeRne7XzK6Hy/8If1e61DToPIsLOYR8ewBzILwKxgnD4hqAD4vw== X-Google-Smtp-Source: AGHT+IHvlhRgJhJooXCgNCHiKvQl5nnQyQl56VKn5RT5WKQ9J2CKsjHvVuEO/MzGkWJp/4cUzAA8 X-Received: by 2002:a05:6a20:2d20:b0:1a3:dd15:dacb with SMTP id g32-20020a056a202d2000b001a3dd15dacbmr15563111pzl.52.1713828417419; Mon, 22 Apr 2024 16:26:57 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1713828417; cv=pass; d=google.com; s=arc-20160816; b=rVOe/vOmRrGZFIWJSlaEDT5wMsd/rXy12ASzw9LcN0SMAdEpOdsZSpV91I/cUKJUag 4NSUdI4QbRX3iL9/+K5oQv+csfySGVGLW/dWhQtblpdfTVCVEzD/uXzeFjivin4+CJoA +lMN4GWjLjxMQB0PMF40ofntz3vrrvDEfDd6mxq5As0nikqK7WE6NUUi18xthbKfqR1f G+VE/XPAqLVbAi41g64KhZPOKoTEPFzISlNuNEWbId2G0v0x1fCBOQFi9MKM134/0Dxe h+OV/0/SwqSB/gxWRdn5KMYa6/p/fRKGktQHccdnW5F2n7gT5S7NKRWLz0Q5veqcAZVg yi5g== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=mime-version:list-unsubscribe:list-subscribe:list-id:precedence :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=NDrpeuvQzpNKSXUjYjE9Ra56mCk6MtHuqcQ0JaHaO1s=; fh=usWEz1eJjYCle08WABmDyuqCrJGq9m48/LVlmybnzRs=; b=ywniiCYjpygf8T4zMhRzkUXUV0wyapZJrpaD0v66HWMElAErELhpd6hZTX+MTrAwkx 1hkigj4ERPQski0wM0kngzjJMWZkMUMhxGxXqQETqKK/NZRkJfzzyj/XV/dPE1qYqixq cgOf1HWfwGFwxWaQQGEaDAXQzBLu5mj2SgBKlbDbYEOSwf1SCyLnQRrU3IvaLiQB+Gdo CgBWWK7xqHH6bG6+QwVRcWAljnmh6fFVQV83ArQAuHClt1vxHrCuJF3vRXlM2ic1Ai7w yXw90tzAEHDiyF91kEGrOpdxBI7UN5kJG5V0a+2QkT5ILtUp+9wHn1iawZd1q7Bj+SjC ocpw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=MASJayVH; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-kernel+bounces-154123-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-154123-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id cj19-20020a056a00299300b006ed5655a03csi8674528pfb.125.2024.04.22.16.26.56 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 22 Apr 2024 16:26:57 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-154123-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=MASJayVH; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-kernel+bounces-154123-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-154123-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 17F1BB257C7 for ; Mon, 22 Apr 2024 23:09:10 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 204B9155752; Mon, 22 Apr 2024 22:50:07 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="MASJayVH" Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 2ECE138FBC; Mon, 22 Apr 2024 22:50:00 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.168.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713826202; cv=none; b=DLYFY+4UMkuo0gKlWfzeYUT+Obq2PjOhXREmERNB8yS3rVqqnu6SqsiH88nAoTm2tdLWBxnCD8OouR0TKYtTbT+r+KxUDCtVIuvnRomcH6Fn1T1aNvINfMWcINCr9mJXzyDcVX8jRl0Pey0V8Pp7YOgnTPKcIXm2t4Ma32P/wuY= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713826202; c=relaxed/simple; bh=xS9j6x5p5jHrcgEvjcv3lSyIp2BuwyTzIcR8hTQv7Lg=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=WgIXM8irmVbPcs0/R6eapi+FILPO6BPVSjQFtqudUGdLVuEz7X7eTpYUi5QQJlTeALPm8RWy6/2kQNYMbZ0HdyepLq0mWBaTnzrbVNIhnIFJO5SwwPMxcbE49R5/+C0ze8s7L8NA4cQP7HdC7LUOf8g3iDYJtyISDluVlhAZchg= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com; spf=pass smtp.mailfrom=quicinc.com; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b=MASJayVH; arc=none smtp.client-ip=205.220.168.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=quicinc.com Received: from pps.filterd (m0279865.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 43MLvBdh018227; Mon, 22 Apr 2024 22:49:44 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h= from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-type; s=qcppdkim1; bh=NDrpeuvQzpNKSXUjYjE9 Ra56mCk6MtHuqcQ0JaHaO1s=; b=MASJayVH9+Me7/ciJbcugkCjUEU0F1b1B1AO C/sHbBQVEHu8pPymPQhaKAViI0dFWKKhlCEPGbBRSTVEZVAoYf8X2YI8zDTQheXi dreFndJOnWY1u2cKQx5A6udqY+zUdpCln8LXDG8MO7qeHhzbVXTWe7OzgT+fkh4H JrlXku/5Xsl7KMUHgDKcKG3SSMdskckCbLqodiW54rjy2EwAYTS8dO4PSCUgjt+h dhzu3ZSMPsRM+oa6sLdoQzb2ORKIeTxKA1oPRSESzgE/IgxS9PmTQIMqsHarOHxH SInRN3X6uzawHP2+LRo0rHJsgDcZBRMRvoa+x8TcsFzMVtZRFg== Received: from nalasppmta03.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3xnet7ajvh-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 22 Apr 2024 22:49:43 +0000 (GMT) Received: from nalasex01b.na.qualcomm.com (nalasex01b.na.qualcomm.com [10.47.209.197]) by NALASPPMTA03.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 43MMnRZS012111 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 22 Apr 2024 22:49:27 GMT Received: from hu-wcheng-lv.qualcomm.com (10.49.16.6) by nalasex01b.na.qualcomm.com (10.47.209.197) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.9; Mon, 22 Apr 2024 15:49:26 -0700 From: Wesley Cheng To: , , , , , , , , , , , , , , CC: , , , , , , , Wesley Cheng Subject: [PATCH v19 38/41] ALSA: usb-audio: qcom: Use card and PCM index from QMI request Date: Mon, 22 Apr 2024 15:49:03 -0700 Message-ID: <20240422224906.15868-39-quic_wcheng@quicinc.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20240422224906.15868-1-quic_wcheng@quicinc.com> References: <20240422224906.15868-1-quic_wcheng@quicinc.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain X-ClientProxiedBy: nalasex01b.na.qualcomm.com (10.47.209.197) To nalasex01b.na.qualcomm.com (10.47.209.197) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-GUID: 3beHfZvVjJrQtqJix1Ds8W_AnU7pW1PL X-Proofpoint-ORIG-GUID: 3beHfZvVjJrQtqJix1Ds8W_AnU7pW1PL X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1011,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2024-04-22_16,2024-04-22_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 malwarescore=0 mlxlogscore=999 suspectscore=0 spamscore=0 priorityscore=1501 mlxscore=0 bulkscore=0 lowpriorityscore=0 clxscore=1015 impostorscore=0 phishscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2404010003 definitions=main-2404220096 Utilize the card and PCM index coming from the USB QMI stream request. This field follows what is set by the ASoC USB backend, and could potentially carry information about a specific device selected through the ASoC USB backend. The backend also has information about the last USB sound device plugged in, so it can choose to select the last device plugged in, accordingly. Signed-off-by: Wesley Cheng --- sound/usb/qcom/qc_audio_offload.c | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/sound/usb/qcom/qc_audio_offload.c b/sound/usb/qcom/qc_audio_offload.c index 9695bf0ac1cd..5e7da9a033e5 100644 --- a/sound/usb/qcom/qc_audio_offload.c +++ b/sound/usb/qcom/qc_audio_offload.c @@ -107,8 +107,6 @@ struct uaudio_qmi_dev { bool er_mapped; /* reference count to number of possible consumers */ atomic_t qdev_in_use; - /* idx to last udev card number plugged in */ - unsigned int last_card_num; }; struct uaudio_dev { @@ -1256,7 +1254,7 @@ static int prepare_qmi_response(struct snd_usb_substream *subs, pcm_dev_num = (req_msg->usb_token & QMI_STREAM_REQ_DEV_NUM_MASK) >> 8; xfer_buf_len = req_msg->xfer_buff_size; - card_num = uaudio_qdev->last_card_num; + card_num = (req_msg->usb_token & QMI_STREAM_REQ_CARD_NUM_MASK) >> 16; if (!uadev[card_num].ctrl_intf) { dev_err(&subs->dev->dev, "audio ctrl intf info not cached\n"); @@ -1449,8 +1447,7 @@ static void handle_uaudio_stream_req(struct qmi_handle *handle, direction = (req_msg->usb_token & QMI_STREAM_REQ_DIRECTION); pcm_dev_num = (req_msg->usb_token & QMI_STREAM_REQ_DEV_NUM_MASK) >> 8; - pcm_card_num = req_msg->enable ? uaudio_qdev->last_card_num : - ffs(uaudio_qdev->card_slot) - 1; + pcm_card_num = (req_msg->usb_token & QMI_STREAM_REQ_CARD_NUM_MASK) >> 16; if (pcm_card_num >= SNDRV_CARDS) { ret = -EINVAL; goto response; @@ -1658,7 +1655,6 @@ static void qc_usb_audio_offload_probe(struct snd_usb_audio *chip) sdev->num_capture = usb_qmi_get_pcm_num(chip, 1); uadev[chip->card->number].sdev = sdev; - uaudio_qdev->last_card_num = chip->card->number; snd_soc_usb_connect(usb_get_usb_backend(udev), sdev); snd_usb_offload_create_ctl(chip);