Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp5138042imm; Tue, 31 Jul 2018 06:13:30 -0700 (PDT) X-Google-Smtp-Source: AAOMgpen/Lw60inlhGeKTF/Jn3QsH6Tl88ztC3lYL+4+O29ZvHnHLBVluhbqR6pOkLVVp3x7mwGr X-Received: by 2002:a17:902:934a:: with SMTP id g10-v6mr11331307plp.121.1533042810079; Tue, 31 Jul 2018 06:13:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533042810; cv=none; d=google.com; s=arc-20160816; b=vYfI87uh4r7EbxnTDyNbsOGoM2eC5Tcb2iypGXyEMQ6XGLS860kCJYbc3ptLWaO5dU sMCtjfR57boFvb659HTiOGMf9DMcZUCxDNltFtOIYh/pAIaqSbVYoUEM/0/KTn4oDoIK eOOjMTDx4WO9G0EP8+oAMSKfh/K7SCgVHKTm8EErC5TTxSkDY74PaKV0kSxw+Byrz4Uh ZT69pMyAdXI8lEIas2saC/+L31Mvq6vREcJboxIet5rMCze/xIRF7xMOI9bQrMnrsGas wVOocYyQE2h7bPKQabuoa2OqwOIX2Kua+dDvOyKxo4cwfJ/J6/KkmbcYgo98Mr3Fd73E uxtg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:subject:cc:to:from:message-id:date :arc-authentication-results; bh=Zdl0js2epsR42Nnt7UCmrgWClAqD6nzYqztIzkUwtik=; b=jkYL7Uby//sh7YfR4en4ZrmJ2pKH+6u/uNbx760x6VURKRP+CXB73N0Yglk3YiGUOV JfuhC2LkTZaBQPMyeRqfPGuapSeMljtqcfpLD4m1+JChaTv//00dWa4dtOzLUEvqp/3A lkkZT8UlDoiMwE0yhGVv/GfpETqrKZCrDLzSTxyOuHxGutkxgEdpzwP+k8HyililJnlL 33ldoIPJcvFIcRT2wYZFzal3rzE/nhKjCkFDxYLZwNpuBpchIf5OCdZySZBK2FR0Oxia m44IO5jSQEMwd4HAfV+nrWIAz/8Da8fOJlDAlJfNeU1FkqXT3vl38S+dDbTlSiLKgkgr ts+w== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x186-v6si12836181pgd.259.2018.07.31.06.13.15; Tue, 31 Jul 2018 06:13:30 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732222AbeGaOwY (ORCPT + 99 others); Tue, 31 Jul 2018 10:52:24 -0400 Received: from mx2.suse.de ([195.135.220.15]:33264 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1732068AbeGaOwX (ORCPT ); Tue, 31 Jul 2018 10:52:23 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 5C88FAD97; Tue, 31 Jul 2018 13:12:06 +0000 (UTC) Date: Tue, 31 Jul 2018 15:12:06 +0200 Message-ID: From: Takashi Iwai To: Jorge Sanjuan Cc: alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3 0/4] usb-audio: Add UAC3 Power Domains In-Reply-To: <20180731122845.4859-1-jorge.sanjuan@codethink.co.uk> References: <20180719112215.4219-1-jorge.sanjuan@codethink.co.uk> <20180731122845.4859-1-jorge.sanjuan@codethink.co.uk> 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/26 (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 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 31 Jul 2018 14:28:41 +0200, Jorge Sanjuan wrote: > > This is what's new in this v3: > - Add proper SPDX identifier for new source file. > - Add delay unit in comment for BADD inferred recovery > times and specify the actual delay time for them. > - Suspend the usb stream *after* alsa has supended its stuff. > - Make sure Power State changes to D0 happen *before* stream > format is set. > - Try to set the Power State to D0 on .prepare callback too as > recovery from suspend state doesn't need .hw_params call. > > This patchset adds support for UAC3 Power Domains. This feature > of the USB audio class 3 allows the host to notify the device > what it is making use of so power comsumption can be optimized. > > This proposal implements this feature for Power Domains > that include an Input/Output Terminal associated to an > audio Streaming interface. This is the main usage of this > feature according to the spec. For that reason, the logic > for the Power Domain state change has been implemented > within the ALSA PCMs logic and the suspend/resume callbacks > of the usb_driver. The behaviour would be as follows: > > * Power Domain State D0: A Power Domain will reach this state > only when the audio substream associated to that domain is > being used (i,e. Audio playback/capture is happening). > * Power Domain State D1: This is the Idle state where the driver > is going to always want to be in order to reduce power > consumption. > * Power Domain State D2: This state is only set when the usb driver > asumes the device is not going to be used anymore and hence, it > wont care about getting any interrupts from the device. This > will only happen when power level is set to "auto" in sysfs > so the usb driver gets suspended when the interfaces are not in use. > > NOTE: The way this has been implemented will always try to put the > Power Domain in state D1 if the Power Domain exists. The patch > "ALSA: usb-audio: Operate UAC3 Power Domains in PCM callbacks" > puts the logic for doing so inside the PCM's logic. Something to > improve on that is to also tie up those D1<->D0 state changes > to runtime PM maybe. > > > Jorge Sanjuan (4): > ALSA: usb-audio: Initial Power Domain support > ALSA: usb-audio: AudioStreaming Power Domain parsing > ALSA: usb-audio: Add UAC3 Power Domains to suspend/resume > ALSA: usb-audio: Operate UAC3 Power Domains in PCM callbacks Now I merge all these four patches. Thanks! Takashi