Received: by 2002:a89:d88:0:b0:1fa:5c73:8e2d with SMTP id eb8csp239294lqb; Thu, 23 May 2024 17:19:05 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCX1yXYl2PCiAC8ecb8aKcvy6oZdGIrObgbjox/7Jtmd7JannmoReFpbfAZabZTX86EF8Vn3hW0liSNOBSFQZ/dZK8bu7BCRRGhPKTMIFw== X-Google-Smtp-Source: AGHT+IGWQQBnWblSFk17JEHBQMqg9riYHfXWiSYZECCFbAATAd2SPkDCBqrG3oqdGoLT2Brzb5Eq X-Received: by 2002:a05:6214:3da1:b0:6aa:fdb6:7d9c with SMTP id 6a1803df08f44-6abbbcacb04mr7335806d6.37.1716509945399; Thu, 23 May 2024 17:19:05 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1716509945; cv=pass; d=google.com; s=arc-20160816; b=QhM0HJkND6+UIiOfzDws0vcaaK4MoBVLXPeGtD44c+/YTEazA+YWVHmZrxXIfzHBGY QKFurqMSGc81QS7qgoCot0EF7kY8J/FkWLMj+oKopvcZ/zQYXk1o+pPS33k58ERDh2yw RKvVDAwytp8N3c+XXC2vQZFmz4lVWt4Gpk7IhS8Lc9TmfvUNHaXCUTkv2hpl6KOb7DkK Nx1bDMgzoR1sXn0roDLOqGb26f2RQo+INtdxIgKfdroNYG+g+KEIGJyaWg/siUFbUJHG s6pfu3epsBzZsxayHvZdfsrl7/Mgthedn69M/aujB2M23AAB9IS0rrvFmf6Vygw0KY77 l/lQ== 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=gkgwHI3kwei94J8pWmry7o76uKy5cIhhnmC7ddLvP80=; fh=alya9RESAvST9l9KF9dhflA/rrEE+1L8tn280X7aOio=; b=zhvJ+ZYwrqCQjEKqwT/bjZAD3/dd1a9rZD0C+ul8sWteeVD0Q0L3nbqnKuQvxJ0wuj 70Szm8GB0BAbZUZpWFLX/iHvCLr8bf08dT7Y8AxDyB0K+dBT/AlTfdDpbA92ZD5Z0SzO JoRJzwNRUpTIEHHyopUIMYd2Lh8edlu9e9zf00kQiqnSYFvRICpjKu1ExVFt4c8gImy3 xmR2KVIvqyN5vkNRJdHpfpAomGZUD4gugJ7WW1MwXSLd0bcuuFxP6ZdU1yIv6rw8gkNp dBrBukFnAu+GnNsOIEa1Z9QNR17op943ErAIJx8f7P+P3K7ngVLlL437idR5lLC/pE0e ErSA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=pCL+1hkN; 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-188148-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-188148-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 d75a77b69052e-43fb17b99c5si6473731cf.74.2024.05.23.17.19.05 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 23 May 2024 17:19:05 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-188148-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=pCL+1hkN; 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-188148-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-188148-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 1558B1C21A52 for ; Fri, 24 May 2024 00:19:05 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id A9EE912D744; Fri, 24 May 2024 00:11:33 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="pCL+1hkN" 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 E621A3399B; Fri, 24 May 2024 00:11:21 +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=1716509484; cv=none; b=YdZGijlZdN4EBSlOn+lMsK4f1W9V0Oji/gKk7QpD1FCSj1UTt/07NOkVF689wgYJ/bo6r7/sGjMtbnKXkmBCgf8v/D+AOkJbHS1mtqfW4kvvc2pQ/sM5JfEUGbnxFVv6TLzCLS8XHOY0hlewngg0NV0reVV7LV7ndyGCkM2ajPI= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1716509484; c=relaxed/simple; bh=gFU1ePwlYhlzYWUxRjQ4ycd26Pc8/+kgoUs3ozS2g5M=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=J7fufDZRd68AHRmCYjQCGTTxPI3Np6qGFMjAfUymZrWnSd4A/RNRnCnUv1sNb5aMxLUUGCaLqs3ECkC8IvQPixTjAFC86TAMCGNmU5ndeb2EDx9kO198OkEx/v2X6Wy/c04ZPyA1N44QPaYMd3eiGx8SYd3zppXBRfcXNbOOIjw= 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=pCL+1hkN; 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 (m0279868.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 44NNPDoc007621; Fri, 24 May 2024 00:11:02 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=gkgwHI3kwei94J8pWmry7o76 uKy5cIhhnmC7ddLvP80=; b=pCL+1hkNVqrd6p/nBmcP/Ezg8kxtfkdbtezztK7T 1lIc2AUOEbA5pttpAL+XI986vuWgB22qRr1WiOu7LjXxzNsXSMKI2Ed/dEN/Xliq wD1yEsbgGdEx7fU5DBXY8J28EsHYdF8zO9WkfpZeIxfnii3lSHBNVVsvqGTFjorJ lwmv1g956d3Mtw0TwIL0Dxm389cV9nUw4hXJgvqTN7BNPsDSsKp/i+fevLCRc5HU CVV0UVU57jF3PqbWCNNA4M2TgjGg+fOrN4ZbgPcxPNTC9RuWp8cARrXptqFhFM6W Wxb8Q62Cr7eqCh5IGDcGtiA2pm1z0aV7UiMsNx3589HhuA== Received: from nalasppmta05.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3yaa9trqa3-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 24 May 2024 00:11:01 +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 44O0B0mc020552 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 24 May 2024 00:11:00 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, 23 May 2024 17:11:00 -0700 From: Wesley Cheng To: , , , , , , , , , , , , CC: , , , , , , , Wesley Cheng Subject: [PATCH v22 20/38] ASoC: usb: Add PCM format check API for USB backend Date: Thu, 23 May 2024 17:10:25 -0700 Message-ID: <20240524001043.10141-21-quic_wcheng@quicinc.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20240524001043.10141-1-quic_wcheng@quicinc.com> References: <20240524001043.10141-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: z7cC5dN7uyN6nB_s6JeeLD932y-pbrxP X-Proofpoint-ORIG-GUID: z7cC5dN7uyN6nB_s6JeeLD932y-pbrxP X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1039,Hydra:6.0.650,FMLib:17.12.28.16 definitions=2024-05-23_13,2024-05-23_01,2024-05-17_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 clxscore=1015 mlxscore=0 spamscore=0 bulkscore=0 priorityscore=1501 lowpriorityscore=0 malwarescore=0 adultscore=0 suspectscore=0 phishscore=0 impostorscore=0 mlxlogscore=999 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2405170001 definitions=main-2405230166 Introduce a helper to check if a particular PCM format is supported by the USB audio device connected. If the USB audio device does not have an audio profile which can support the requested format, then notify the USB backend. Signed-off-by: Wesley Cheng --- include/sound/soc-usb.h | 9 +++++++++ sound/soc/soc-usb.c | 25 +++++++++++++++++++++++++ 2 files changed, 34 insertions(+) diff --git a/include/sound/soc-usb.h b/include/sound/soc-usb.h index e8fe4439c234..4b1b992c8b27 100644 --- a/include/sound/soc-usb.h +++ b/include/sound/soc-usb.h @@ -39,6 +39,8 @@ struct snd_soc_usb { #if IS_ENABLED(CONFIG_SND_SOC_USB) const char *snd_soc_usb_get_components_tag(bool playback); +int snd_soc_usb_find_supported_format(int card_idx, + struct snd_pcm_hw_params *params, int direction); int snd_soc_usb_connect(struct device *usbdev, struct snd_soc_usb_device *sdev); int snd_soc_usb_disconnect(struct device *usbdev, struct snd_soc_usb_device *sdev); @@ -55,6 +57,13 @@ static inline const char *snd_soc_usb_get_components_tag(bool playback) return ""; } +static inline int snd_soc_usb_find_supported_format(int card_idx, + struct snd_pcm_hw_params *params, + int direction) +{ + return -EINVAL; +} + static inline int snd_soc_usb_connect(struct device *usbdev, struct snd_soc_usb_device *sdev) { diff --git a/sound/soc/soc-usb.c b/sound/soc/soc-usb.c index 8490715791a5..3bb66808f196 100644 --- a/sound/soc/soc-usb.c +++ b/sound/soc/soc-usb.c @@ -74,6 +74,31 @@ void *snd_soc_usb_find_priv_data(struct device *dev) } EXPORT_SYMBOL_GPL(snd_soc_usb_find_priv_data); +/** + * snd_soc_usb_find_supported_format() - Check if audio format is supported + * @card_idx: USB sound chip array index + * @params: PCM parameters + * @direction: capture or playback + * + * Ensure that a requested audio profile from the ASoC side is able to be + * supported by the USB device. + * + * Return 0 on success, negative on error. + * + */ +int snd_soc_usb_find_supported_format(int card_idx, + struct snd_pcm_hw_params *params, int direction) +{ + struct snd_usb_stream *as; + + as = snd_usb_find_suppported_substream(card_idx, params, direction); + if (!as) + return -EOPNOTSUPP; + + return 0; +} +EXPORT_SYMBOL_GPL(snd_soc_usb_find_supported_format); + /** * snd_soc_usb_allocate_port() - allocate a SOC USB device * @component: USB DPCM backend DAI component