Received: by 2002:ab2:6991:0:b0:1f7:f6c3:9cb1 with SMTP id v17csp87312lqo; Tue, 7 May 2024 13:03:06 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCV7LH6L8eGCCngywnMWQ/b1XBNK/Z9qv3vOSYDSkhltdbnTf6KQxw9sBf5/4Lh96oglCUtA0J1htRQicS7SBQAMxIETcnBkt2MHnO2HGg== X-Google-Smtp-Source: AGHT+IFvilGWsIZbpQu66Csek7NxTxn6MDLL/Pa2QK2nm+75GqpxT7DYwAB93JZro5HeE7On2bPi X-Received: by 2002:ac8:5805:0:b0:43a:cfc5:f0a0 with SMTP id d75a77b69052e-43dbec04a04mr7168291cf.13.1715112186202; Tue, 07 May 2024 13:03:06 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1715112186; cv=pass; d=google.com; s=arc-20160816; b=vi07WGs+Ryf2cvQ1DzY/74I1WOInxXSwkDE5NbWQRJZIuEiQCnSnktrlctQSZfsl9Q 31ZeATemrxUu0qWH90YZ91Mks8UuOJReXstknYbHm92ttNiBoFuyAWMzz+PkdBB+rtqK r1KCLACgAZ6mpBO+nwE55rEQQYQjo+2hvUX2zRlDcq7TYGV/LqB1LJT9V824LtzyHCmx fSGyGduPCKRdP8UUTmU9d3qAhoIZ7h3YDgXq3Js6t979mMmpuboohteUfZ10cnYjMZ+v R4g4S0nLfR94DG9g8uF3vF1s8eX6xX6a/OHEeviGRIw2OPbNH7aRi1PyijbjOQMoXbik 6Lyw== 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=av4iEBQ/j6FzZ117TY/T91Akowl4mLc+koTA/yystYo=; fh=tk8sqZoIP78riW3PYc75n3+DQFkqFrW+9GPE0/sstVA=; b=r/vUKCGY8/zcNZ/zoSH0P6n1TJHFtlvHoG9aS4JerSDg/SlP39s3pA/uZjZdIV6oH3 XgF1fCdFsdX19I7kQensVbAQimM0a9RnciVmbEkN6ajh+A5v3M+8SYQjPwfj41ZgElGY pfjfmjg/N2AuA7SLRrY0xlrtnOi45eCc3ssJXZXm0fO9LLmVQB3vA90jSaOm+7dz1UYp Mzf6NVQhh4IVFl3sXBOi9HnKDdZewP66B2sVWzjmoGWS8KyMkb0VWGQ7XhyUoTszEtvE 62pow5x6hVzVGITTaOwfgNp+3sP0ax7osXmAOYHvqjVKYhEZzjeCL6Hg3RnAxCO8QOCy vsYA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=Cqu91nKo; 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-172106-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-172106-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 4-20020ac85904000000b0043ab1af4061si13084892qty.50.2024.05.07.13.03.06 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 07 May 2024 13:03:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-172106-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=Cqu91nKo; 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-172106-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-172106-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 04ADE1C21745 for ; Tue, 7 May 2024 20:03:02 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id D64DD20125B; Tue, 7 May 2024 19:52:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="Cqu91nKo" 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 74D7D17EB81; Tue, 7 May 2024 19:52:11 +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=1715111532; cv=none; b=q8h0IbwrdLhQpTzGxUROt+RG6Cq2AibaMkEDxeP7Ka+BErPvg3G7dNJuANXIf3v5rAPAowzMZRtZ0abqeYx+DTd+A0wzLE1voJcZBZ92nebaebbd9kufFNE6WC4fUZPPExbSMcO9c/KPh6dEWU1PvXNlhhVlu7BRfPKmmQeDU7I= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715111532; c=relaxed/simple; bh=3oPiBOcaENitVPAvzdxQkB83ESZQWN6dJTLsMFwygx4=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=kYO3n1aflpRSIIJOOZ5hV541ewAKPyd7UwLELdhaYk9GrVT+db9KzuT5FhPj/K+kw7jD7yxMfKjcNSoIXjHff65HvwJb6BFDhKiO8jMLsG3caR5xOxp06+eKmwh37/th0doQOBBcrWLhIViVT9usIzeV6C1LFERcjWc+WYOqhwc= 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=Cqu91nKo; 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 (m0279863.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 447JiXl8029328; Tue, 7 May 2024 19:51:38 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=av4iEBQ/j6FzZ117TY/T 91Akowl4mLc+koTA/yystYo=; b=Cqu91nKoY9AzreHV9FhuAxf2ms4nCqqiQHsC s6/mRGYh90F1oi1eqFlW55SD2lf5xMOlvJyxBJ2Qslo1wF2ogDJ4KiTdmshXxjKT DYkq0HCStYeF79H2gbIoJr1SDejqASemEyxbd2FdIrdBUcxsYQGcgJAw+iBFuUEc ABCEDJxviF2eZSO02Y7Pbc3YvribgXbG6Rx4lEHeOOCYbmyhUNa0PKNPXLR97RcR 3sJBLfrvkQt8/uzw8BW7K4FsRow6eTGv/dR7ayhj0I9KqMJIg7J/f5gfZT4dwEKq FYG7hF10+Tvs/Lq5twSPwo5wSPJQkLH3lIm6QMoWPU7/q3DQWg== Received: from nalasppmta04.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3xysg9g5x1-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 07 May 2024 19:51:38 +0000 (GMT) Received: from nalasex01b.na.qualcomm.com (nalasex01b.na.qualcomm.com [10.47.209.197]) by NALASPPMTA04.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 447Jpb35019848 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 7 May 2024 19:51:37 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; Tue, 7 May 2024 12:51:37 -0700 From: Wesley Cheng To: , , , , , , , , , , , , , , , CC: , , , , , , , Wesley Cheng Subject: [PATCH v21 36/39] ALSA: usb-audio: qcom: Use card and PCM index from QMI request Date: Tue, 7 May 2024 12:51:13 -0700 Message-ID: <20240507195116.9464-37-quic_wcheng@quicinc.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20240507195116.9464-1-quic_wcheng@quicinc.com> References: <20240507195116.9464-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: nalasex01a.na.qualcomm.com (10.47.209.196) 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: jiE1Btq8d5fpvtrLL2L7Z31wFimhwj7h X-Proofpoint-ORIG-GUID: jiE1Btq8d5fpvtrLL2L7Z31wFimhwj7h X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1039,Hydra:6.0.650,FMLib:17.11.176.26 definitions=2024-05-07_12,2024-05-06_02,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 phishscore=0 malwarescore=0 bulkscore=0 mlxscore=0 suspectscore=0 impostorscore=0 lowpriorityscore=0 adultscore=0 spamscore=0 priorityscore=1501 clxscore=1015 mlxlogscore=999 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2405010000 definitions=main-2405070138 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 2659d8776bed..d08870f22fae 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);