Received: by 2002:a89:48b:0:b0:1f5:f2ab:c469 with SMTP id a11csp1408546lqd; Thu, 25 Apr 2024 15:00:12 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCXQRCkJ+MUvbztNl/Be5nAjgI/61J9OR5tXbwCGPZ7a929aRrgL5IyhtC0Et7orkSFy9lGxDOo02qFvW+ikfeqqX10ORYQLJ+xsrF4XFw== X-Google-Smtp-Source: AGHT+IGKlw5CfIR1D9f4WW2doCjF5vpFPJj/gUITpYDPg0qxmAjGRVpIJlSADsdTTcje1tyJS20U X-Received: by 2002:a05:6214:d43:b0:6a0:8c9a:c74b with SMTP id 3-20020a0562140d4300b006a08c9ac74bmr1366084qvr.28.1714082412611; Thu, 25 Apr 2024 15:00:12 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1714082412; cv=pass; d=google.com; s=arc-20160816; b=jW8lp0e4d8cfUcgJUtRcADPTcHHmPYHuiV3BHOe56eTK932ugVYOYwTqSrJyNCbYFC mLq5GrnL3kw++/Z4GZbSKXjXN0S5NqNC7EhzE7sIiMrSq9iOb9OCJEWRU6UIVxQ56kKS bEguSTcmGIb3JYJrRylg5Aia29QItwjXOwaDr2vt7L5J7lV98SULtZkS/2qxZau0iFLC TUdf3RbzEp5AWoX7zMnLUT2K1zMo11k9Oc3uD49tbsP7599dvH05TYbu7ZqiptQaED2j wnUTMqpvRWeXMO+D+QXTc9GYKQlLeHnSAOxGEbFUeVmysPQlkplfPUypYNkBgLT8ce+q 3wAA== 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=pazNt/Bka0BM6s8xA16X4Iln+RfHKNrEkR/CWQZI/Or5RSMEGa0Ok7rZUFdHw+bbL5 BZ0riFdDGobcIgZlHmmD9rlF90X4xsB2OyS9tyDjwECABp4Y1Av240f2UU0kLKoInyUG 6Wf88UuJGd2XbLpq9LN2FlY6bDd6u9xU3zjgOKDb1AQeKQk0U8PjoB9R/Yto4Ia8sJUX V8winrGnvWRNxNTnEAzp89z0DBJq6zQrLBdA73RqUAljR/gAF78TXgvPsarIwMS5ILB4 Yx/mOfs4Fz65x34mzDoPHbulIOdsKCOe2ZjfjTofw0W7ktOpWtV9Ap+nTGEKwnAjAGsg Rfeg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=LpcsS8SS; 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-159264-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-159264-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 c15-20020a05622a058f00b0043699dc7b56si18549444qtb.147.2024.04.25.15.00.12 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 25 Apr 2024 15:00:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-159264-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=LpcsS8SS; 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-159264-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-159264-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 54BC41C208A0 for ; Thu, 25 Apr 2024 22:00:12 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 41DA01836D8; Thu, 25 Apr 2024 21:52:23 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="LpcsS8SS" 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 74DC21802D1; Thu, 25 Apr 2024 21:52:18 +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=1714081940; cv=none; b=tefz13b8iyQqHFve73WUQFZ+bQG6E2egsoBQZL6uoKWFw/Bz1QreCkWnMnDJQL6I9rlSORlj9RlHMdlze/OlZcOqNAeGxfybO+GUqcRNZMW32FvtaDsWq0cqJmW0rend4YmRzyVia7THMA8tyce9KxTHWefw2Gn+BwxpvEyGH8s= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1714081940; c=relaxed/simple; bh=xS9j6x5p5jHrcgEvjcv3lSyIp2BuwyTzIcR8hTQv7Lg=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=f/HBQiMTHh+qso9U/gT4uk1YAhrNSlGjI1GJZkzq0TWPBkcBSREaX7KYcO28jE74Z493c2MFnAzZF+gxShPgbdD5/a07m/Kz+ZScHmSpoNqjvKz8/v+deLiT2ZFgcty2+Rfu7c7pS58v7HD6UVGnGwvPvXVgWsEXlEJTx4hWWGQ= 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=LpcsS8SS; 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 (m0279867.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 43PKjIj6031301; Thu, 25 Apr 2024 21:51:48 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=LpcsS8SSTFdocoSK97+kovS2nrh+hr2XYW4n 5iMutQ4bjBXwY1SS9MloBiO+fY+RThgyT6YCojEgytNJyskMfPRtl5h+T3dP8ZMG /8nZwfdilfh6yyLKiF423DaXroSvLW+T1BpNpU30A1iIy/obZVKoJ34iQvN0c09T NxQoKPEY9nfB1/sv74RHv0gQjHv0RXLo810TyijOuSkjZGBcvHFr/CKB6zTlgOkZ WRFXA3rNB+fHBJhU6SOvYvIl/rCb1xSzRvDUkME5DkSHQVvWh8kqDvFMmVj8jt6T wronWoLVPeZzjVO2zeVG6cFPo7SpYL2XvzqYXoWcMe2TwlxjHA== Received: from nalasppmta05.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3xqenhuthv-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 25 Apr 2024 21:51:48 +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 43PLplS2008055 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 25 Apr 2024 21:51:47 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; Thu, 25 Apr 2024 14:51:47 -0700 From: Wesley Cheng To: , , , , , , , , , , , , , , CC: , , , , , , , Wesley Cheng Subject: [PATCH v20 38/41] ALSA: usb-audio: qcom: Use card and PCM index from QMI request Date: Thu, 25 Apr 2024 14:51:22 -0700 Message-ID: <20240425215125.29761-39-quic_wcheng@quicinc.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20240425215125.29761-1-quic_wcheng@quicinc.com> References: <20240425215125.29761-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-ORIG-GUID: 4MNssuUYeR8-Y8gh7C_V_gU7XbjF32q5 X-Proofpoint-GUID: 4MNssuUYeR8-Y8gh7C_V_gU7XbjF32q5 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1011,Hydra:6.0.650,FMLib:17.11.176.26 definitions=2024-04-25_21,2024-04-25_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 impostorscore=0 mlxscore=0 lowpriorityscore=0 bulkscore=0 malwarescore=0 adultscore=0 clxscore=1015 priorityscore=1501 phishscore=0 mlxlogscore=999 suspectscore=0 spamscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2404010003 definitions=main-2404250159 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);