Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp96290pxb; Tue, 2 Mar 2021 20:36:25 -0800 (PST) X-Google-Smtp-Source: ABdhPJytQjjYeHGDgHnNbGPMI1U5U7+DuMbu58+9efGnHc19QOFWg0E0ZFSo8i7u9iRMGjjcEQ0E X-Received: by 2002:a17:906:6a06:: with SMTP id o6mr8136653ejr.306.1614746185088; Tue, 02 Mar 2021 20:36:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614746185; cv=none; d=google.com; s=arc-20160816; b=f2rgZlNx2HXD6CM6zHZcnYBPoAulzLb+QyfbOT51XlU1f73LOO7s+Yp1Vc1reWhq9u NjV0i2turwRjI5wGdYB6Hh/P7qt4l2ivCkXzfYWdGiNv3E+2NYV73ODnd+Ny9VWPNeXn Az/BNzjyveozY7UvL8XFJYHbEaQ8aCoMcdT0WXzkER0rLzM9PB+B4nGTj28SWyfrPuqB rfge6AqtsDM6KLBRL6xcpqeoN2wQVJJXL83LNBwS1PmTF3q1MjILA5MfV9gngHBDvLy3 2vi7DOQuGf4vgBIPojHRx0hTrXF6YQj+efxRSLcEjat0Le2PFb30ZSLWvy5YSfj3fmal NLtw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:date:message-id:from:references:cc:to :subject:dkim-signature; bh=v4QKZoyEhUUl8eHO+sgtVV5pWRE+dBrdSzOgE4nihEc=; b=FTEXCkfGcjgMRge726tH9tfa6YcwsC+oXUw3qj/bysag7a6E40IG3U7jc0WvkC8oNj 1EIove2GKS/dAd8LWNvX18mstZXur1yzNoRB6XcC7TkMeASnIpC46O8+AS7iboDTRmLZ 4nA8CVO+/UlkFwS7F3RKh+bCfrojB6uMNj0P4JONYDJ5qYKovLQvb+tk0h7m8OxlnfAw 6uRv2ak4nOWX11e46JhDzAu61uRpERNhQG0ZnsqmRs60dZrkJOe7so/s0DjoI2Jyup3m sGkK3zEbf9i2S9Zuji2Budc0nWO5bJaO4TggT772HgtExr6H4WxAI0Vx3JeWeGXVhCeu Ftyw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@opensynergy.com header.s=srmailgate02 header.b=1xa44Ndf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=opensynergy.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bu17si16324617ejb.22.2021.03.02.20.36.03; Tue, 02 Mar 2021 20:36:25 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@opensynergy.com header.s=srmailgate02 header.b=1xa44Ndf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=opensynergy.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237246AbhCAPcy (ORCPT + 99 others); Mon, 1 Mar 2021 10:32:54 -0500 Received: from mx1.opensynergy.com ([217.66.60.4]:27670 "EHLO mx1.opensynergy.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237240AbhCAPbw (ORCPT ); Mon, 1 Mar 2021 10:31:52 -0500 Received: from SR-MAILGATE-02.opensynergy.com (localhost.localdomain [127.0.0.1]) by mx1.opensynergy.com (Proxmox) with ESMTP id D0845A135A; Mon, 1 Mar 2021 16:30:56 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=opensynergy.com; h=cc:cc:content-transfer-encoding:content-type:content-type :date:from:from:in-reply-to:message-id:mime-version:references :reply-to:subject:subject:to:to; s=srmailgate02; bh=v4QKZoyEhUUl 8eHO+sgtVV5pWRE+dBrdSzOgE4nihEc=; b=1xa44NdfhI89Ixk8UlhPryNc5vVr 4AUZxU2udGJCZaGsHMNXmaddj45tBMOdTsmcvJeksOl8/01R78QdAn6nlGWgSb9f MLBxVr0kjriaw5bp56t4krjwhqW1JiNvlqhUSvLQ9oiUJshRjVOMUegd66Ai0pbE XjdKowsTuAUMxWYtb05K5AB9enxtcNfaBm/8kHPSqsnf/Zb1EXz5deTlDOFqS94M SSkySeIvlKsQqZ88iMFWB0zAE3b2Jn6zmVU7641+Wvz6ccXo0+XoLlxlgV2f66ah +ZUQFPSjMCYH5OzgYs5jPK+VyfYQ5U848MolYZbvrNS3FoDN15gqBPStwQ== Subject: Re: [PATCH v6 9/9] ALSA: virtio: introduce device suspend/resume support To: Takashi Iwai CC: , , , "Michael S. Tsirkin" , Jaroslav Kysela , Takashi Iwai , References: <20210227085956.1700687-1-anton.yakovlev@opensynergy.com> <20210227085956.1700687-10-anton.yakovlev@opensynergy.com> <54854cb9-99c3-4c05-3b43-f41d89a29aec@opensynergy.com> From: Anton Yakovlev Message-ID: <438961dc-b546-562a-26dc-53cf46ee74b6@opensynergy.com> Date: Mon, 1 Mar 2021 16:30:55 +0100 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-ClientProxiedBy: SR-MAIL-02.open-synergy.com (10.26.10.22) To SR-MAIL-01.open-synergy.com (10.26.10.21) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 01.03.2021 14:38, Takashi Iwai wrote: > On Mon, 01 Mar 2021 11:03:04 +0100, > Anton Yakovlev wrote: >> >> On 28.02.2021 13:05, Takashi Iwai wrote: >>> On Sat, 27 Feb 2021 09:59:56 +0100, >>> Anton Yakovlev wrote: >>>> >>>> All running PCM substreams are stopped on device suspend and restarted >>>> on device resume. >>>> >>>> Signed-off-by: Anton Yakovlev >>>> --- >>>> sound/virtio/virtio_card.c | 56 +++++++++++++++++++++++++++++++++++ >>>> sound/virtio/virtio_pcm.c | 1 + >>>> sound/virtio/virtio_pcm_ops.c | 41 ++++++++++++++++++++----- >>>> 3 files changed, 90 insertions(+), 8 deletions(-) >>>> >>>> diff --git a/sound/virtio/virtio_card.c b/sound/virtio/virtio_card.c >>>> index 59455a562018..c7ae8801991d 100644 >>>> --- a/sound/virtio/virtio_card.c >>>> +++ b/sound/virtio/virtio_card.c >>>> @@ -323,6 +323,58 @@ static void virtsnd_remove(struct virtio_device *vdev) >>>> kfree(snd->event_msgs); >>>> } >>>> >>>> +#ifdef CONFIG_PM_SLEEP >>>> +/** >>>> + * virtsnd_freeze() - Suspend device. >>>> + * @vdev: VirtIO parent device. >>>> + * >>>> + * Context: Any context. >>>> + * Return: 0 on success, -errno on failure. >>>> + */ >>>> +static int virtsnd_freeze(struct virtio_device *vdev) >>>> +{ >>>> + struct virtio_snd *snd = vdev->priv; >>>> + >>>> + virtsnd_ctl_msg_cancel_all(snd); >>>> + >>>> + vdev->config->del_vqs(vdev); >>>> + vdev->config->reset(vdev); >>>> + >>>> + kfree(snd->event_msgs); >>>> + >>>> + /* >>>> + * If the virtsnd_restore() fails before re-allocating events, then we >>>> + * get a dangling pointer here. >>>> + */ >>>> + snd->event_msgs = NULL; >>>> + >>>> + return 0; >>> >>> I suppose some cancel of inflight works is needed? >>> Ditto for the device removal, too. >> >> It's not necessary here, since the device is reset and all of this are >> happened automatically. > > Hrm, but the reset call itself might conflict with the inflight reset > work? I haven't see any work canceling or flushing, so... There maybe the following: 1. Some pending control requests -> these are cancelled in the virtsnd_ctl_msg_cancel_all() call. 2. PCM messages -> these must not be cancelled, since they will be requeued by driver on resume (starting with suspended position). 3. Some pending events from the device. These will be lost. Yeah, I think we can process all pending events before destroying virtqueue. Other that these, there are no other inflight works or so. >> But in the device remove it makes sense also to >> disable events before calling snd_card_free(), since the device is still >> able to send notifications at that moment. Thanks! >> >> >>>> --- a/sound/virtio/virtio_pcm.c >>>> +++ b/sound/virtio/virtio_pcm.c >>>> @@ -109,6 +109,7 @@ static int virtsnd_pcm_build_hw(struct virtio_pcm_substream *vss, >>>> SNDRV_PCM_INFO_BATCH | >>>> SNDRV_PCM_INFO_BLOCK_TRANSFER | >>>> SNDRV_PCM_INFO_INTERLEAVED | >>>> + SNDRV_PCM_INFO_RESUME | >>>> SNDRV_PCM_INFO_PAUSE; >>> >>> Actually you don't need to set SNDRV_PCM_INFO_RESUME. >>> This flag means that the driver supports the full resume procedure, >>> which isn't often the case; with this, the driver is supposed to >>> resume the stream exactly from the suspended position. >> >> If I understood you right, that's exactly how resume is implemented now >> in the driver. Although we fully restart substream on the device side, >> from an application point of view it is resumed exactly at the same >> position. >> >> >>> Most drivers don't set this but implement only the suspend-stop >>> action. Then the application (or the sound backend) will re-setup the >>> stream and restart accordingly. >> >> And an application must be aware of such possible situation? Since I >> have no doubt in alsa-lib, but I don't think that for example tinyalsa >> can handle this right. > > Tiny ALSA should work, too. Actually there are only few drivers that > have the full PCM resume. The majority of drivers are without the > resume support (including a large one like HD-audio). Then it's a great news! Since we can simplify code a lot. > And, with the resume implementation, I'm worried by the style like: > >>>> @@ -309,6 +318,21 @@ static int virtsnd_pcm_trigger(struct snd_pcm_substream *substream, int command) >>>> int rc; >>>> >>>> switch (command) { >>>> + case SNDRV_PCM_TRIGGER_RESUME: { >>>> + /* >>>> + * We restart the substream by executing the standard command >>>> + * sequence. >>>> + */ >>>> + rc = virtsnd_pcm_hw_params(substream, NULL); >>>> + if (rc) >>>> + return rc; >>>> + >>>> + rc = virtsnd_pcm_prepare(substream); >>>> + if (rc) >>>> + return rc; > > ... and this is rather what the core code should do, and it's exactly > the same procedure that would be done without RESUME flag. > > > Takashi > -- Anton Yakovlev Senior Software Engineer OpenSynergy GmbH Rotherstr. 20, 10245 Berlin