Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp6979722rdb; Fri, 15 Dec 2023 13:59:07 -0800 (PST) X-Google-Smtp-Source: AGHT+IEmHWLFLifql0mm8G5QaOZmU+QTo+I5kUAt43LngVydpblNZqbh19+TyizmjihAb2UPcqDc X-Received: by 2002:a50:ed16:0:b0:54c:4fec:116 with SMTP id j22-20020a50ed16000000b0054c4fec0116mr3288557eds.165.1702677547271; Fri, 15 Dec 2023 13:59:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702677547; cv=none; d=google.com; s=arc-20160816; b=Nv6XrgTgGa4aVi8Nv+AVqty3glV6QhobXrXyiB9MsuZUv3zIodDMG0vIlcDZC1ARQN 2L6aF9NlSLNJv0MmjoynZr01tyrqS6tQu1GtuAv82HLCg6f4/g3rthwOHKtuuH0vZx1V mNA7saiITk5iBJuEQLs/ggTt0bLgAGXRvaJ5/vqEbLif70vxOGvkbWSxNjnwSe/UXFR0 GFa8Ne/m70PzkANy++JwaeinlC1nELHdfg4lTuMTglJ8afkkCfR9SL+Pf52cq6XnHpdk MIJRKVWUUmPhmOIBktxTeDtJnhH/3kTJ6gJWdZ65iH70VaO1O4hecAPclXADqPb+0IzH eucA== 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=55ixrCvScNyoiF2MZa/Klm288e6OMTksZwvaSzERilQ=; fh=0KzismZj+xI0Z//ZGdqKIH/FO9LtSZM7Yj4P0VtrCz0=; b=mjHonf2fVS49piBmhRzKRCCWqtOcYpTcEnvCdzgxGpvtIHmVI2JQMJxiIU0iUAV9AR J0q9MOXOlnTPNc2mioLGbxlVg8zJiA06CVx0AhPEo4YLQseveNDoTVNlX8rzXJFkzOqy oWauq2MMdKbhvJ5hb4sUvV3rAn0FLj16qp5BlkHMblRVSwlAn8xtwcxdV5A4Ywghid9T 8tIb4uKOSP5JstxxKx4L8jsYz4rSY4T4iNUy4YDNzdffx01rvZ23mHyLwkPqRcegxRS4 jHfS+R1xtqDZqS+7LhXb5J31v6Jl+v2AXMiy0dqLWp8xVhbH2drv+xNZLmAhyVQFrXHi 1lOA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=exwxLsl5; spf=pass (google.com: domain of linux-kernel+bounces-1702-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-1702-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. [147.75.80.249]) by mx.google.com with ESMTPS id r21-20020a50c015000000b00551198f5116si5508929edb.238.2023.12.15.13.59.07 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Dec 2023 13:59:07 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-1702-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=exwxLsl5; spf=pass (google.com: domain of linux-kernel+bounces-1702-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-1702-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 D6FB61F23DF0 for ; Fri, 15 Dec 2023 21:59:06 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 930F318EB7; 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="exwxLsl5" 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 E4A6C69797; Fri, 15 Dec 2023 21:50:30 +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 (m0279864.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.24/8.17.1.24) with ESMTP id 3BFLgcpp026240; 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=55ixrCvScNyoiF2MZa/K lm288e6OMTksZwvaSzERilQ=; b=exwxLsl5nN2K+LbGixxsL9JCbOhv07ldPeYE QYjLVS3Q2IjXU5lNIR1Y/Dzm4IAYFN6GOJMZ1fXpZIbsbT47rwJHH9xxU5DU/H6m dxsgQXfoPCoI5JbbeL6klvUdlIlzKmT8JVyoEIp5Hu22j9g/XZErOfT0LbxfJ9KL rjzugyARjWykfuKI26u2K+BG42OOko5CzVaTEY6b+5vVuzDCU/fmjKXXsn1cFVtE 1iw1dp67bpFmvqH+kZIieigmcK2RB/BcWrWdEeHajoWh1dCLTsoytSuVA92QJVsk rHpJD50l5AmGDzurJhrpPMr15Sf4hcTRPhWXeH1cVnZKxqcylA== Received: from nalasppmta04.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3v0hqcj7bj-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 15 Dec 2023 21:50:18 +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 3BFLoHEH031502 (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:17 -0800 From: Wesley Cheng To: , , , , , , , , , , , , , , , CC: , , , , , , , Wesley Cheng Subject: [PATCH v10 38/41] ALSA: usb-audio: Allow for rediscovery of connected USB SND devices Date: Fri, 15 Dec 2023 13:49:52 -0800 Message-ID: <20231215214955.12110-39-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-ORIG-GUID: KPPMttJkLqkHWRlUtFlW_8G0XVo3FeC3 X-Proofpoint-GUID: KPPMttJkLqkHWRlUtFlW_8G0XVo3FeC3 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 malwarescore=0 mlxscore=0 phishscore=0 adultscore=0 priorityscore=1501 impostorscore=0 lowpriorityscore=0 mlxlogscore=999 clxscore=1015 suspectscore=0 spamscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2311290000 definitions=main-2312150152 In case of notifying SND platform drivers of connection events, some of these use cases, such as offloading, require an ASoC USB backend device to be initialized before the events can be handled. If the USB backend device has not yet been probed, this leads to missing initial USB audio device connection events. Expose an API that traverses the usb_chip array for connected devices, and to call the respective connection callback registered to the SND platform driver. Signed-off-by: Wesley Cheng --- sound/usb/card.c | 19 +++++++++++++++++++ sound/usb/card.h | 2 ++ sound/usb/qcom/qc_audio_offload.c | 2 ++ 3 files changed, 23 insertions(+) diff --git a/sound/usb/card.c b/sound/usb/card.c index 11b827b7a2a5..995b2df676ab 100644 --- a/sound/usb/card.c +++ b/sound/usb/card.c @@ -202,6 +202,25 @@ struct snd_usb_stream *snd_usb_find_suppported_substream(int card_idx, } EXPORT_SYMBOL_GPL(snd_usb_find_suppported_substream); +/* + * in case the platform driver was not ready at the time of USB SND + * device connect, expose an API to discover all connected USB devices + * so it can populate any dependent resources/structures. + */ +void snd_usb_rediscover_devices(void) +{ + int i; + + mutex_lock(®ister_mutex); + for (i = 0; i < SNDRV_CARDS; i++) { + if (usb_chip[i]) + if (platform_ops && platform_ops->connect_cb) + platform_ops->connect_cb(usb_chip[i]); + } + mutex_unlock(®ister_mutex); +} +EXPORT_SYMBOL_GPL(snd_usb_rediscover_devices); + /* * disconnect streams * called from usb_audio_disconnect() diff --git a/sound/usb/card.h b/sound/usb/card.h index 6d59995440c3..3a0d68f453a1 100644 --- a/sound/usb/card.h +++ b/sound/usb/card.h @@ -222,11 +222,13 @@ int snd_usb_unregister_platform_ops(void); #if IS_ENABLED(CONFIG_SND_USB_AUDIO) struct snd_usb_stream *snd_usb_find_suppported_substream(int card_idx, struct snd_pcm_hw_params *params, int direction); +void snd_usb_rediscover_devices(void); #else static struct snd_usb_stream *snd_usb_find_suppported_substream(int card_idx, struct snd_pcm_hw_params *params, int direction) { return NULL; } +static void snd_usb_rediscover_devices(void) { } #endif /* IS_ENABLED(CONFIG_SND_USB_AUDIO) */ #endif /* __USBAUDIO_CARD_H */ diff --git a/sound/usb/qcom/qc_audio_offload.c b/sound/usb/qcom/qc_audio_offload.c index e0a010a40b97..60b715e48508 100644 --- a/sound/usb/qcom/qc_audio_offload.c +++ b/sound/usb/qcom/qc_audio_offload.c @@ -1866,6 +1866,8 @@ static int __init qc_usb_audio_offload_init(void) if (ret < 0) goto release_qmi; + snd_usb_rediscover_devices(); + return 0; release_qmi: