Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp6979823rdb; Fri, 15 Dec 2023 13:59:25 -0800 (PST) X-Google-Smtp-Source: AGHT+IGvaNtAwlnROolxmVc93MrdW/A61KHL7fdKapfxc/HH4kBXjCDSIrZmkCsFRqMjWjJ+5Oen X-Received: by 2002:a05:620a:564:b0:77f:3832:1d0 with SMTP id p4-20020a05620a056400b0077f383201d0mr12078201qkp.85.1702677564571; Fri, 15 Dec 2023 13:59:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702677564; cv=none; d=google.com; s=arc-20160816; b=VhBAx/HIE4cZUzbPCmdJqF9T548kRtEoDRrwX8VvvoL0dh+PiJJVP/bVW1Et5E0TJ9 9p6Z+4Za5ce1N0Sxux0nwGlF+UJfOdJplFs7eTe3kff1tWtwS3Bs58S4Z6PPZJLDDGJs C/w08ZWJKRCB78GHstTdx3HZGxeTHwq80ZqCWgeJF2+n4gp62cJd/KN82R6CgOH9UWrW vc01PImgtl3fcujYwvnRjqTxha40KsJAw8kilhX0HuUmS1ni55U0Um+JpczmEvLGEOEx J3VnKvIFx4mH8snIPfsKo16RQ00dR34ulOvlK9d7Fvfg511oqeDPwQU4WX9Lh+pLNMie A2HA== ARC-Message-Signature: i=1; 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=GEq454iSwI48K4ZPgN9mT347jXotm2BjHdb8t2pxU4g=; fh=0KzismZj+xI0Z//ZGdqKIH/FO9LtSZM7Yj4P0VtrCz0=; b=zEO6h9voOakQc4xTVFfcBYfuAiFZ38e+aRpbTJmVNL/sgPLhhpSEFryhCMxDDCctDT 7zBYXvRqsD3Uz+IJmYfVE8ndfc9EyE43onYvzuwrtHP6aqAPdPAc/ucaOJiLwN01yyL/ OaiUvutThfkPl2OHdgfU1ijMD6a+UNYXGFfYe4De325BbHpPOcKr50O8CHhX6sqnR2IJ oSwAASwTLOCv7EcIkNdj58HqMfs2qkCQRZCQpRfBPqy/SiaAcnRUw4TbiG109+x2ptYI ZoAOBJUORfVedPPPZ5KIUGLEzq8bMpHYN/Qxv1k0Wn4bKPhBFa2OmlhUqRzSPmW1Dbs3 slkg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=aW19qmjn; spf=pass (google.com: domain of linux-kernel+bounces-1709-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-1709-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id vz6-20020a05620a494600b0077f059ff196si16919815qkn.151.2023.12.15.13.59.24 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Dec 2023 13:59:24 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-1709-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=aW19qmjn; spf=pass (google.com: domain of linux-kernel+bounces-1709-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-1709-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 ny.mirrors.kernel.org (Postfix) with ESMTPS id 44D701C2417D for ; Fri, 15 Dec 2023 21:59:24 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id C662D18EDA; Fri, 15 Dec 2023 21:50:36 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="aW19qmjn" X-Original-To: linux-kernel@vger.kernel.org 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 CCA056D1C4; Fri, 15 Dec 2023 21:50:32 +0000 (UTC) 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.17.1.24/8.17.1.24) with ESMTP id 3BFLMdLb005531; Fri, 15 Dec 2023 21:50:18 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=GEq454iSwI48K4ZPgN9m T347jXotm2BjHdb8t2pxU4g=; b=aW19qmjnu/IqNvGA8QR1Y75jMDc7Tv2C5o29 6Z90vktDsf28WFW4E///tM3wyVajYwtPquweQRSSNTBPZw3BgTPXilpMp9TPACrr iYH97kqCSbTboYOKtOtjq/zwzC+v2s69BqfV2awIaHcvAQriAa6HJgew6Ev3cclL Ikw1JZYNGUmVFqw2WI1CEbTOB6vejILsM3KXARl5Vv9KVOR+jaTNaKW451IFYV9F YVATtAikWWlA0K0rASwrmMOS7e501KVG153FAEDro33clTrBotS8gXK9Wd6BTPqi tHeVUx21B/JfA9ue+hqX/chqokEPLWdPszpSqPGNJx8PuYQfOw== Received: from nalasppmta05.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3v0m46hngj-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 15 Dec 2023 21:50:17 +0000 (GMT) Received: from nalasex01b.na.qualcomm.com (nalasex01b.na.qualcomm.com [10.47.209.197]) by NALASPPMTA05.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 3BFLoHVA000910 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 15 Dec 2023 21:50:17 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.1118.40; Fri, 15 Dec 2023 13:50:16 -0800 From: Wesley Cheng To: , , , , , , , , , , , , , , , CC: , , , , , , , Wesley Cheng Subject: [PATCH v10 37/41] ALSA: usb-audio: qcom: Use card and PCM index from QMI request Date: Fri, 15 Dec 2023 13:49:51 -0800 Message-ID: <20231215214955.12110-38-quic_wcheng@quicinc.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20231215214955.12110-1-quic_wcheng@quicinc.com> References: <20231215214955.12110-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: nalasex01c.na.qualcomm.com (10.47.97.35) 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: _jfq__OA6qmlpXaTvfX18vviMGX3U1R8 X-Proofpoint-ORIG-GUID: _jfq__OA6qmlpXaTvfX18vviMGX3U1R8 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.272,Aquarius:18.0.997,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2023-12-09_01,2023-12-07_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 suspectscore=0 adultscore=0 phishscore=0 mlxscore=0 clxscore=1015 mlxlogscore=986 impostorscore=0 malwarescore=0 bulkscore=0 spamscore=0 lowpriorityscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2311290000 definitions=main-2312150152 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 1104499f89f7..e0a010a40b97 100644 --- a/sound/usb/qcom/qc_audio_offload.c +++ b/sound/usb/qcom/qc_audio_offload.c @@ -106,8 +106,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 { @@ -1243,7 +1241,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"); @@ -1436,8 +1434,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; @@ -1646,7 +1643,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); mutex_unlock(&chip->mutex);