Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp708129imm; Wed, 19 Sep 2018 05:47:37 -0700 (PDT) X-Google-Smtp-Source: ANB0VdaLqoIKUASnU0OL1L2WxBwSXqa17opnxVO1u/5WQ/H1jv7TVp4Re405waeqNwnDvvyAJ5tx X-Received: by 2002:a65:4b88:: with SMTP id t8-v6mr32567948pgq.239.1537361257096; Wed, 19 Sep 2018 05:47:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537361257; cv=none; d=google.com; s=arc-20160816; b=dpwsw88ff6/i0DA+adutxr3WB5Ttg4ar4heIwIk7NZAsexWuLCJtw+gLKnwIEWpOXs QAZZxXTNXp5y8IzaHd6Draijyd05LNNZV7pOZHYwJEfl9JwRJe9w8YefO6diQEhLOWDz 5mb9UUiKQgXU+8HzhIq91zs1leZDD+2MeY1+bRVbhoOWXLhTDDH6tmyO6Zdtz/WE8jl5 ZceiWC5NqYjUVy05r1t2i5BtMV/vqZLmN7C6P0abXykDYfq8OUJWH7s3Zbqu9iSHB1Ww QLxoe4i0eQMZjT6o/U8D9bT4jx0M9FRpK2hlSzy826hfHUnBSRpVgcVAx9eZMLxdXBuA PR/w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:references:message-id :content-transfer-encoding:cc:date:in-reply-to:from:subject :mime-version; bh=SUtVogpXo6snn9O8f477HUnHxtwmtjvcuZX8kdNGfg4=; b=qq4ApW9BfjZxIRlsRlI9YNdxsxynAAesNUNMkYO8N9Ogr75+Hz0BrEhMF4Hdp+FPg7 nwlievwYDBp+cs1Q9QJAImzDCy9wKg1c6leNYBDBi088Xq+GFGK0/7Ki37VENiC0pJov uociF+A8/gWDtgqX4UhKv2H4Ekl4wkcwcuVUVlQOwtOjcVcTxIf0/0SQ+ozFok48AmPa k7l9kd0RN/ZMghW6Gxu1lAyDYVErRqEKJhi+2z2gMz5QZywk7AUOXdmTkT9CNijtoMCg SKwRwGUErDlq+qKGeBc4VF8Zsm95JKTokRxfYRXUBtEC+m9NV1pycsREi4MG27nyKYLx gM7Q== 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 c125-v6si21174176pga.268.2018.09.19.05.47.20; Wed, 19 Sep 2018 05:47:37 -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 S1731746AbeISSXy convert rfc822-to-8bit (ORCPT + 99 others); Wed, 19 Sep 2018 14:23:54 -0400 Received: from vie01a-dmta-pe05-2.mx.upcmail.net ([84.116.36.12]:13238 "EHLO vie01a-dmta-pe05-2.mx.upcmail.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731235AbeISSXy (ORCPT ); Wed, 19 Sep 2018 14:23:54 -0400 Received: from [172.31.216.44] (helo=vie01a-pemc-psmtp-pe02) by vie01a-dmta-pe05.mx.upcmail.net with esmtp (Exim 4.88) (envelope-from ) id 1g2brn-0000bT-Jg for linux-kernel@vger.kernel.org; Wed, 19 Sep 2018 14:46:03 +0200 Received: from helix.aillwee.com ([37.228.204.209]) by vie01a-pemc-psmtp-pe02 with SMTP @ mailcloud.upcmail.net id dQlw1y01E4XbgXZ01QlznR; Wed, 19 Sep 2018 14:46:00 +0200 X-SourceIP: 37.228.204.209 Received: from [192.168.2.4] (brady.scss.tcd.ie [134.226.35.12]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by helix.aillwee.com (Postfix) with ESMTPSA id 789014E607; Wed, 19 Sep 2018 13:45:56 +0100 (IST) Content-Type: text/plain; charset=us-ascii Mime-Version: 1.0 (Mac OS X Mail 11.5 \(3445.9.1\)) Subject: Re: [PATCH 17/29] staging: bcm2835-audio: Add 10ms period constraint From: Mike Brady In-Reply-To: <8866e22a-6cd7-d32d-92e5-9a4e60206d2f@i2se.com> Date: Wed, 19 Sep 2018 13:47:46 +0100 Cc: Takashi Iwai , Greg Kroah-Hartman , Eric Anholt , linux-rpi-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Phil Elwell Content-Transfer-Encoding: 8BIT Message-Id: <77C9E357-8B01-4CF1-ADA2-899D3E4D2085@eircom.net> References: <20180904155858.8001-1-tiwai@suse.de> <20180904155858.8001-18-tiwai@suse.de> <4c5f9aed-8fbe-fe22-0c8d-097d8915805c@i2se.com> <8866e22a-6cd7-d32d-92e5-9a4e60206d2f@i2se.com> To: Stefan Wahren X-Mailer: Apple Mail (2.3445.9.1) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Stefan. Thanks for this. > On 19 Sep 2018, at 13:41, Stefan Wahren wrote: > > Hi, > > [add Phil and Mike] > > Am 19.09.2018 um 11:52 schrieb Takashi Iwai: >> On Wed, 19 Sep 2018 11:42:22 +0200, >> Stefan Wahren wrote: >>> Hi Takashi, >>> >>> Am 04.09.2018 um 17:58 schrieb Takashi Iwai: >>>> It seems that the resolution of vc04 callback is in 10 msec; i.e. the >>>> minimal period size is also 10 msec. >>>> >>>> This patch adds the corresponding hw constraint. >>>> >>>> Signed-off-by: Takashi Iwai >>>> --- >>>> drivers/staging/vc04_services/bcm2835-audio/bcm2835-pcm.c | 5 +++++ >>>> 1 file changed, 5 insertions(+) >>>> >>>> diff --git a/drivers/staging/vc04_services/bcm2835-audio/bcm2835-pcm.c b/drivers/staging/vc04_services/bcm2835-audio/bcm2835-pcm.c >>>> index 9659c25b9f9d..6d89db6e14e4 100644 >>>> --- a/drivers/staging/vc04_services/bcm2835-audio/bcm2835-pcm.c >>>> +++ b/drivers/staging/vc04_services/bcm2835-audio/bcm2835-pcm.c >>>> @@ -145,6 +145,11 @@ static int snd_bcm2835_playback_open_generic( >>>> SNDRV_PCM_HW_PARAM_PERIOD_BYTES, >>>> 16); >>>> >>>> + /* position update is in 10ms order */ >>>> + snd_pcm_hw_constraint_minmax(runtime, >>>> + SNDRV_PCM_HW_PARAM_PERIOD_TIME, >>>> + 10 * 1000, UINT_MAX); >>>> + >>>> chip->alsa_stream[idx] = alsa_stream; >>>> >>>> chip->opened |= (1 << idx); >>> in the Foundation Kernel (Downstream) there is a patch to interpolate >>> the audio delay. So my questions is, does your patch above makes the >>> following patch obsolete? >> Through a quick glance, no, my patch is orthogonal to this. >> >> My patch adds a PCM hw constraint so that the period size won't go >> below 10ms, while the downstream patch provides the additional delay >> value that is calculated from the system clock. > > thanks for your explanation. So your patch must be reverted with > implementation of interpolate audio delay. > >> >>> [PATCH] bcm2835: interpolate audio delay >>> >>> It appears the GPU only sends us a message all 10ms to update >>> the playback progress. Other than this, the playback position >>> (what SNDRV_PCM_IOCTL_DELAY will return) is not updated at all. >>> Userspace will see jitter up to 10ms in the audio position. >>> >>> Make this a bit nicer for userspace by interpolating the >>> position using the CPU clock. >>> >>> I'm not sure if setting snd_pcm_runtime.delay is the right >>> approach for this. Or if there is maybe an already existing >>> mechanism for position interpolation in the ALSA core. >> That's OK, as long as the computation is accurate enough (at least not >> exceed the actual position) and is light-weight. >> >>> I only set SNDRV_PCM_INFO_BATCH because this appears to remove >>> at least one situation snd_pcm_runtime.delay is used, so I have >>> to worry less in which place I have to update this field, or >>> how it interacts with the rest of ALSA. >> Actually, this SNDRV_PCM_INFO_BATCH addition should be a separate >> patch. It has nothing to do with the runtime->delay calculation. >> (And, this "one situation" is likely called PulseAudio :) >> >>> In the future, it might be nice to use VC_AUDIO_MSG_TYPE_LATENCY. >>> One problem is that it requires sending a videocore message, and >>> waiting for a reply, which could make the implementation much >>> harder due to locking and synchronization requirements. >> This can be now easy with my patch series. By switching to non-atomic >> operation, we can issue the vc04 command inside the pointer callback, >> too. > > I think we should try to implement this later. > > @Mike: Do you want to write a patch series which upstream "interpolate > audio delay" and addresses Takashi's comments? > > I would help you, in case you have questions about setup a Raspberry Pi > with Mainline kernel or patch submission. Yeah, sure. I might need some of the handholding alright. Can you point me at any documentation please? Regards Mike > > Regards > Stefan > >> >> >> thanks, >> >> Takashi > >