Received: by 2002:ab2:69cc:0:b0:1fd:c486:4f03 with SMTP id n12csp31722lqp; Mon, 10 Jun 2024 17:07:33 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWgItmRiiYUbMzj/s7jAZs0sLl52Bqo73Fdtg+ctkKuSAjFAAffevj2dP0Ojc8mxFemlh4Kk0qOeQP6lE8tq/egNopj6Ure7OedR3zMIA== X-Google-Smtp-Source: AGHT+IE8+uhz6pbtVNgwX9CcjANqZfNaZ8UXP5rCJQKsZG3Sn/rg5u1LorOMlrKpboVYxw/FslG1 X-Received: by 2002:a17:907:7676:b0:a6f:2d9a:c963 with SMTP id a640c23a62f3a-a6f2d9acc5emr147734766b.45.1718064452904; Mon, 10 Jun 2024 17:07:32 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1718064452; cv=pass; d=google.com; s=arc-20160816; b=tkiWL5ur0cVsckR8+mK1UI7j5kv7hnea4VZVlOEnPTqfI3i4IXoBlghgC6wFbB7HAp TZ8NOAWhCNl97U6ZnLIXPIDa4F/HtyqiOKKuAawBP0T81R3959RiyLiNGtgt6VhaeNdI ERXZid/EJ+80ZIpqs4Mfds+FYtNkAvDkGlQmg19LVBkqpdoPwyOGZBtSfHEJz4kVDYxN nR9cIV++7ECNTBqrhdGpv/qUTDloXjIaHF+X/4O59DWtW1qmQvJefyj1Egl0cUTWZofO bTwfceevfX3do9lPdXgNbPn/7aJFQ4BVoVXT8xT3DwSLsfdoPGnCCIaaotzVT5p7tw0E 6gkA== 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=Xqts/jnVObPpCGOPtSbFgh8oSO8ZXHXIjKRBOx0jSSc=; fh=wtHMo7F9o0E380HmQ3oEdtbLMOdVnxgjuxg3Tsny7VY=; b=LAWSpgVRKYw7hnTQpDMCYIi0sIDn1SGSwaFvu1wwD2zDpkOzLk2smhmJFrHG0U13oK Dg4BxnmDmE+f4GS1LqZOEY19dRNE8bd2zDpm/ECNQDSkT0sd88JMBO8ziOhK5qjGi13/ 1Y3ffRSCLwMOzqU48+l9xQgF0486CEgbmR55hXjn3J9oaVefQYX0LZvMYauGBoAq4zww AuIryKV65kFeOLKtZX/G47MZdXCWpuv4ffjFXIsZ9L8cTs2qhb/8YDrPDtYCYjnbk7B8 iMlvQuOkB8xMQQ9VApsMkRZ0dVCQ5sTqYg9/cfnTDFzagkkBWjORqtz26zpL2GkVtuhz ENgw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=VwmdkW4n; 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-209099-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-209099-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [2604:1380:4601:e00::3]) by mx.google.com with ESMTPS id a640c23a62f3a-a6c80726a46si513187866b.724.2024.06.10.17.07.32 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 10 Jun 2024 17:07:32 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-209099-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) client-ip=2604:1380:4601:e00::3; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=VwmdkW4n; 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-209099-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:4601:e00::3 as permitted sender) smtp.mailfrom="linux-kernel+bounces-209099-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 am.mirrors.kernel.org (Postfix) with ESMTPS id 9B2161F2137D for ; Tue, 11 Jun 2024 00:07:32 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 5C2EB15FA7B; Mon, 10 Jun 2024 23:58:56 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="VwmdkW4n" Received: from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com [205.220.180.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 3CEFC158842; Mon, 10 Jun 2024 23:58:48 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.180.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718063931; cv=none; b=VmnMQ6q1dTfoqrrb8hbOuAHaZodAXuBNxBMAOA2bG8HChMwZC6B7BHy68VL7H/kJgTxtrZdBAMuYXXpU6Qa1arEEpRFv0VpPLphfXQkbQ5gBnA7QAK4/RCSwqnnsNxCoiYmVmul/rp882aAFHIjXCj51b22gyD2BJ7txJGsY3co= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718063931; c=relaxed/simple; bh=Yltz0HBMufJ04qixuQjOlmiu1K3qsfKz866rVfzeVcA=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=EEIYuCA3Ily0/KkBY6Kqyrpgau7WwfqzbwfXOb7erdq0/Rm1IfgTsZDUCO8fX8nNV0Zs2T6EYgB7joECEZz5fLvFRFDkZ7egiFVlwz7xfoqAHVC+lFD8olFaomf2ya2rtxEBDXU2El3LLmdKrVzYom+rpQFNaq3V35FAls7R48M= 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=VwmdkW4n; arc=none smtp.client-ip=205.220.180.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 (m0279871.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 45ACTtAu001863; Mon, 10 Jun 2024 23:58:29 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h= cc:content-type:date:from:in-reply-to:message-id:mime-version :references:subject:to; s=qcppdkim1; bh=Xqts/jnVObPpCGOPtSbFgh8o SO8ZXHXIjKRBOx0jSSc=; b=VwmdkW4nrcZ1tu1L8xEdh75bRYsUtiL8LAFGt+my R7+BZjpDAbMDoAskSqtLs7ko5L9mx9fzuluQPYgLECOBsWGwl4Dks0PPOvxzjkAq yTcYWcGAVxLp99drNniy7A5EYQWLariwYgcoeMv1Xn6woaixGOo5wB83FwQLnBW2 9KOZ5XJOz/0DDjxg09xdaISJ+nyPBQpj3xpTfpBSdj8xSHE/0XA1t/sN/T9VinQQ 4tw1DyE8DWdHDrW3U/wyMetlqbNA364d/kwjUIFPhTWDyKGysHYzFbvj4VFBtMtR uXkZnhbPRR03rYIlI7hMofRhpYm9X6zLT47mda/vOcm2Kg== Received: from nalasppmta03.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3ymevxcwt9-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 10 Jun 2024 23:58:28 +0000 (GMT) Received: from nalasex01b.na.qualcomm.com (nalasex01b.na.qualcomm.com [10.47.209.197]) by NALASPPMTA03.qualcomm.com (8.17.1.19/8.17.1.19) with ESMTPS id 45ANwR75023786 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 10 Jun 2024 23:58: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, 10 Jun 2024 16:58:27 -0700 From: Wesley Cheng To: , , , , , , , , , , , , CC: , , , , , , , Wesley Cheng Subject: [PATCH v23 30/32] ALSA: usb-audio: qcom: Use card and PCM index from QMI request Date: Mon, 10 Jun 2024 16:58:06 -0700 Message-ID: <20240610235808.22173-31-quic_wcheng@quicinc.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20240610235808.22173-1-quic_wcheng@quicinc.com> References: <20240610235808.22173-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: QspVd2TaWZZpss6mY0qfh6We6FypfzHL X-Proofpoint-GUID: QspVd2TaWZZpss6mY0qfh6We6FypfzHL X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1039,Hydra:6.0.680,FMLib:17.12.28.16 definitions=2024-06-10_07,2024-06-10_01,2024-05-17_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxlogscore=999 mlxscore=0 impostorscore=0 adultscore=0 phishscore=0 malwarescore=0 clxscore=1015 suspectscore=0 priorityscore=1501 spamscore=0 bulkscore=0 lowpriorityscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2405170001 definitions=main-2406100177 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 01aa0753ca83..37a90d2ac344 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); if (chip->num_interfaces == 1)