Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp446594pxb; Wed, 3 Feb 2021 09:05:24 -0800 (PST) X-Google-Smtp-Source: ABdhPJww1R+YXfqUS5pUdYWTD62UkoITh0V2JR3e6dj39qQa69sYgzJeIB4MjCdyCKTgzD360Gs0 X-Received: by 2002:a17:906:6951:: with SMTP id c17mr4059592ejs.395.1612371924540; Wed, 03 Feb 2021 09:05:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612371924; cv=none; d=google.com; s=arc-20160816; b=qe6B2DjCJgIhwT6E+AIrHYOLf/yTvAtGfVzNF5qn+IDX+xxhd9mo+Owdrd7tMPtt5q JlOcEQ7zrCEvBQ9F5DAo34KF33m45hvDGqZS3Ho1lR3eQNHCGWss9GOfce4WdSy7W17d w06xLKxZrnLk4tB9iTuCDdwDqXxikxlaOayFruyDfEajG/J3BqisHZmoIORiTNwSh91T XiOty8Z+jyxJylPpAZ9Yi+ZuLM2HH3YJ0mTp3YxaiyYBlJQTcsfdxMKDOPT3wUVwNgzM +7Gb6kTH/mX1XyYWBOYsQj2Q81+yBcpH4Nh8lq0BtN/pIOG4u8YZgHjKBfEQ8Vzr8DHv OOvQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:references:in-reply-to :subject:cc:to:from:message-id:date; bh=CPoZKfIeUQO2uLob/MxkmhmGf/F5X9s5IFz3WXeinX8=; b=IPTP2THXfd+/eW3LrC4aLBlnwevV+Rw/rqrSIQNOiuqetZiNPz/IKBFkb5JnFIZaGy lk/UXDxeMYHfIWBCLTfu3/Ucn2KgKM4h966nHtfjUcv7UZ0H9aMwaUQOUtU5oGzJFsVw pew2WPa9pNV+8V9Fc91qWImMpE2SIXgyMAaV4iS3SO3WuU+nG0W/TiSbenRA5XYDq8zK dxD77haU3YOMsAgQmmDrRsnnzoJlPvg8VZZYOE3E1xkHiUFtq0tldqXPKgwrD0K0pABN mzYpq+6pPZKBoKtRb4EDbN9P50YptF+mJ4HnRKQgGfGc0KBm0QQAks6HfJcklMOZtaeO sv0w== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v4si1577788ejw.738.2021.02.03.09.04.55; Wed, 03 Feb 2021 09:05:24 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231211AbhBCRBb (ORCPT + 99 others); Wed, 3 Feb 2021 12:01:31 -0500 Received: from mx2.suse.de ([195.135.220.15]:54412 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231927AbhBCRAO (ORCPT ); Wed, 3 Feb 2021 12:00:14 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 2230CACB0; Wed, 3 Feb 2021 16:59:32 +0000 (UTC) Date: Wed, 03 Feb 2021 17:59:31 +0100 Message-ID: From: Takashi Iwai To: Anton Yakovlev Cc: Guennadi Liakhovetski , , , , , Jaroslav Kysela , Takashi Iwai , "Michael S. Tsirkin" Subject: Re: [virtio-dev] Re: [PATCH v2 2/9] ALSA: virtio: add virtio sound driver In-Reply-To: <52f71ac6-3ec7-2884-7a64-1995f416d20a@opensynergy.com> References: <20210124165408.1122868-1-anton.yakovlev@opensynergy.com> <20210124165408.1122868-3-anton.yakovlev@opensynergy.com> <8754dae8-114-6383-510-de2ba9dc4fa@intel.com> <52f71ac6-3ec7-2884-7a64-1995f416d20a@opensynergy.com> User-Agent: Wanderlust/2.15.9 (Almost Unreal) SEMI/1.14.6 (Maruoka) FLIM/1.14.9 (=?UTF-8?B?R29qxY0=?=) APEL/10.8 Emacs/25.3 (x86_64-suse-linux-gnu) MULE/6.0 (HANACHIRUSATO) MIME-Version: 1.0 (generated by SEMI 1.14.6 - "Maruoka") Content-Type: text/plain; charset=US-ASCII Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 02 Feb 2021 00:18:09 +0100, Anton Yakovlev wrote: > >> +/** > >> + * virtsnd_reset_fn() - Kernel worker's function to reset the device. > >> + * @work: Reset device work. > >> + * > >> + * Context: Process context. > >> + */ > >> +static void virtsnd_reset_fn(struct work_struct *work) > >> +{ > >> + struct virtio_snd *snd = > >> + container_of(work, struct virtio_snd, reset_work); > >> + struct virtio_device *vdev = snd->vdev; > >> + struct device *dev = &vdev->dev; > >> + int rc; > >> + > >> + dev_info(dev, "sound device needs reset\n"); > >> + > >> + /* > >> + * It seems that the only way to properly reset the device is to > >> remove > >> + * and re-create the ALSA sound card device. > >> + * > >> + * Also resetting the device involves a number of steps with > >> setting the > >> + * status bits described in the virtio specification. And the > >> easiest > >> + * way to get everything right is to use the virtio bus interface. > >> + */ > >> + rc = dev->bus->remove(dev); > >> + if (rc) > >> + dev_warn(dev, "bus->remove() failed: %d", rc); > >> + > >> + rc = dev->bus->probe(dev); > >> + if (rc) > >> + dev_err(dev, "bus->probe() failed: %d", rc); > > > > This looks very suspicious to me. Wondering what ALSA maintainers > will say > > to this. > > I'm also wondering what the virtio people have to say. This part is a > purely virtio specific thing. And since none of the existing virtio > drivers processes the request to reset the device, it is not clear what > is the best way to proceed here. For this reason, the most > straightforward and simple solution was chosen. What is this "reset" actually supposed to do? Reconfguring everything, or changing only certain parameters, devices, whatever? thanks, Takashi