Received: by 2002:ac0:aa62:0:0:0:0:0 with SMTP id w31-v6csp308327ima; Wed, 24 Oct 2018 01:24:15 -0700 (PDT) X-Google-Smtp-Source: AJdET5eh/vgth4/y9HilUnW5ME8y+6HZiSckACuFd3vfclL3UqNjA5LIPVSTbSJ/2kiYYVHpe/ji X-Received: by 2002:a65:6144:: with SMTP id o4-v6mr1645462pgv.387.1540369455692; Wed, 24 Oct 2018 01:24:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540369455; cv=none; d=google.com; s=arc-20160816; b=1EUaRHWDIT8jnm7Ze31XJP1h9gs7FCl0sFxVpCrO/+RtKgps4zurnc700rBDY+tqKD auJKETpHqkuSbjadeoh3OdORgQ0K1OHzr1bmlOvoBkAh1WIiUJ3g1awOhHwR1ar7SlMP q0fz8LAowdlVqtPerGRmDGhsMHXolij8WoAMiENvbK6lXcuEifwxhinXeGT2QZQWiJ+m 0KaTlCdnTiV5SXfc3nuW60RBbehXYx+Z33Y1JNC19F6ebGJ9yIqph62xPArXKTUiTcq/ +w3MbIfyhBx2AKCAa8O6t+f6gkjAktycgYfc3SEeTloahPqvMGS/nwAOL4FPBC/tfcKj 1tRA== 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=geIF3N9/sDcwqMHCx4hnBSwR8usj3okpJftg0Eozn10=; b=xJH1ZIYeKqqex8l+BIedUe/Zh+/4eKZ1DS/yiya9UelN2TtHr8ThP6ihetAaMvYQHo 4XIyVypJRnWoOvsoZ053GDUV+wigY7Y7B9wpfWNbRyd+CHojy3ft4npdC3meNIPYxAUe DOixGg/dA/7b7deTcl/DKIOKHA6ANZAb01ZUOzeXLCBT7sHWLZq7ENivw5Qh8V9rJvI/ tzJdGg4dZdUWos1mXAuny8sxcRr6/uA1qNeNhxWBDyAxEhTrNKKUuRZSDFMYP5TwjvP8 RAYBcaIcRvf5WaW1Nb0rOtG+wBBlxKL0RaoWZS62kWrgDwpk/vxycBkLKSHnA+5CewrI c9oQ== 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 23-v6si4041743pgs.356.2018.10.24.01.24.00; Wed, 24 Oct 2018 01:24:15 -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 S1727619AbeJXQrU convert rfc822-to-8bit (ORCPT + 99 others); Wed, 24 Oct 2018 12:47:20 -0400 Received: from vie01a-dmta-pe08-3.mx.upcmail.net ([84.116.36.22]:31584 "EHLO vie01a-dmta-pe08-3.mx.upcmail.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726531AbeJXQrU (ORCPT ); Wed, 24 Oct 2018 12:47:20 -0400 Received: from [172.31.216.235] (helo=vie01a-pemc-psmtp-pe12.mail.upcmail.net) by vie01a-dmta-pe08.mx.upcmail.net with esmtp (Exim 4.88) (envelope-from ) id 1gFEOh-000183-6B for linux-kernel@vger.kernel.org; Wed, 24 Oct 2018 10:20:11 +0200 Received: from helix.aillwee.com ([37.228.204.209]) by vie01a-pemc-psmtp-pe12.mail.upcmail.net with ESMTP id FEOfgQA8ukosQFEOggF1UE; Wed, 24 Oct 2018 10:20:11 +0200 X-Env-Mailfrom: mikebrady@eircom.net X-Env-Rcptto: linux-kernel@vger.kernel.org X-SourceIP: 37.228.204.209 X-CNFS-Analysis: v=2.3 cv=NNQEBHyg c=1 sm=1 tr=0 a=/+iDkf0alGTUGXENEoGzTg==:117 a=/+iDkf0alGTUGXENEoGzTg==:17 a=IkcTkHD0fZMA:10 a=smKx5t2vBNcA:10 a=pGLkceISAAAA:8 a=NEAV23lmAAAA:8 a=k7f7euTfAAAA:8 a=foHCeV_ZAAAA:8 a=y0jdxBOuuxOgm-QiZ8EA:9 a=AAWk5B1plMHTeopH:21 a=HwXA8Gq0tMqA7mWy:21 a=QEXdDO2ut3YA:10 a=h8a9FgHX5U4dIE3jaWyr:22 Received: from [172.20.10.4] (unknown [77.75.241.4]) (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 85B5D4E607; Wed, 24 Oct 2018 09:20:08 +0100 (IST) Content-Type: text/plain; charset=utf-8 Mime-Version: 1.0 (Mac OS X Mail 12.0 \(3445.100.39\)) Subject: Re: [alsa-devel] [PATCH v2] staging: bcm2835-audio: interpolate audio delay From: Mike Brady In-Reply-To: Date: Wed, 24 Oct 2018 09:20:09 +0100 Cc: stefan.wahren@i2se.com, devel@driverdev.osuosl.org, alsa-devel@alsa-project.org, f.fainelli@gmail.com, julia.lawall@lip6.fr, tiwai@suse.de, gregkh@linuxfoundation.org, linux-kernel@vger.kernel.org, eric@anholt.net, linux-rpi-kernel@lists.infradead.org, nishka.dasgupta_ug18@ashoka.edu.in, linux-arm-kernel@lists.infradead.org Content-Transfer-Encoding: 8BIT Message-Id: References: <20181022191708.GA4659@ubuntu> To: Kirill Marinushkin X-Mailer: Apple Mail (2.3445.100.39) X-CMAE-Envelope: MS4wfEwWJmYGFcdTp+qKYun7Wv3/P3lnJAO0r0xg1QBxIZUQKiLP4FhcxlXnSJi+LZGVugtcvSQzLZE0gKjx3ty+JbOp1UP9Y+IZRItaR9LaEim8RM+DcIma aR4k30rTYeFXhic7Ausi5S2C/elhqHFSeJ568mJtV++CPK1ruCHsSKpaFvqk+7AxTNLcVqU9fDPwrX54v2xF2qjit6YPLO7RO48KPIOrvec3kJZMEXL7l57U kmYtWm0uRtOGgsKGEUs1wzaUXFwMDGLU85OyMWfm09o9Hg5QzB6dtLoaql6K7IcZcqBPtnpKdE54iN5QHM3KQGrIf/wtVhRsbut3TiWJeuvAc5BsTABBjw9t 2GRV0/ehd3t7KFRRSd5qDDmG5qavcux3L41SSJ0cz11AYVhajQBY1umuWxvMq6prVtSeNMcVAHEvK5gDNFy1XC6o4ACEJlXkesC8/ZIEMNOi/ESkVcRe24Ap PgMWQzlkKHjHdTJ4ZMG49uug9CNVtCiXz1WZiJg7eAMKBwTCZxVEoODnQIl37BpRfA3etwTSfgZWd/9+/nQ5YyppWd45hLVMkkpDVnta9sH+vi/ehM+OXIcX bRiHuMMcz+Su1WJnb+iUVUWi5SCcO+XN0M5aQUk1mvkkIUjk4LcN7A9DMp2ZZ+Zqq4c= Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Kirill. Thanks for your comments. > On 22 Oct 2018, at 23:25, Kirill Marinushkin wrote: > > AFAIU, this patch is wrong. Please correct me, maybe I misunderstand something. > >> The problem that this patch seeks to resolve is that when userland asks for >> the delay > > The userspace asks not for delay, but for the pointer. The call in question is snd_pcm_delay. I presume this delay is calculated from knowledge of the stream position “pos", the period (buffer?) number (and period/buffer size) and the snd_pcm_runtime structure’s “delay" field (“runtime->delay”). > You modify the function, which is called `snd_bcm2835_pcm_pointer`. Here you are > supposed to increase `alsa_stream->pos` with the proper offset. Instead, you > imitate a delay, but in fact the delay is not increased. > > So, the proper solution should be to fix the reported pointer. I think there is a difficulty with this. The “pos” pointer looks to have to be modulo the buffer size. This causes a problem, as I see it, in that if the calculated (pos + interpolated delay in bytes) is longer than the buffer size, it must be wrapped, but AFAIK we are unable to increment a buffer index used in the snd_pcm_delay calculation. Hence the calculation of the actual position would be wrong. This is why the snd_pcm_runtime delay field is used. On reflection, BTW, the patch assumes that the field's original value was zero — that can be rectified. > As a result, > userspace will recieve the correct delay, instead of these crazy 10 ms. Just to point out that with the proposed patch, it appears that the correct delay is being reported, (apart, possibly, from any delay originally set in the snd_pcm_delay field, as mentioned above). All the best, Mike > FYI, there is >> a discussion of the effects of a downstream equivalent of this suggested patch >> at: >> https://github.com/raspberrypi/firmware/issues/1026#issuecomment-415746016. > > Thank you for the link, it clarified for me what you try to achieve. > > On 10/22/18 21:17, Mike Brady wrote: >> When the BCM2835 audio output is used, userspace sees a jitter up to 10ms >> in the audio position, aka "delay" -- the number of frames that must >> be output before a new frame would be played. >> Make this a bit nicer for userspace by interpolating the position >> using the CPU clock. >> The overhead is small -- an extra ktime_get() every time a GPU message >> is sent -- and another call and a few calculations whenever the delay >> is sought from userland. >> At 48,000 frames per second, i.e. approximately 20 microseconds per >> frame, it would take a clock inaccuracy of >> 20 microseconds in 10 milliseconds -- 2,000 parts per million -- >> to result in an inaccurate estimate, whereas >> crystal- or resonator-based clocks typically have an >> inaccuracy of 10s to 100s of parts per million. >> >> Signed-off-by: Mike Brady >> --- >> Changes in v2 -- remove inappropriate addition of SNDRV_PCM_INFO_BATCH flag >> >> .../vc04_services/bcm2835-audio/bcm2835-pcm.c | 20 +++++++++++++++++++ >> .../vc04_services/bcm2835-audio/bcm2835.h | 1 + >> 2 files changed, 21 insertions(+) >> >> diff --git a/drivers/staging/vc04_services/bcm2835-audio/bcm2835-pcm.c b/drivers/staging/vc04_services/bcm2835-audio/bcm2835-pcm.c >> index e66da11af5cf..9053b996cada 100644 >> --- a/drivers/staging/vc04_services/bcm2835-audio/bcm2835-pcm.c >> +++ b/drivers/staging/vc04_services/bcm2835-audio/bcm2835-pcm.c >> @@ -74,6 +74,7 @@ void bcm2835_playback_fifo(struct bcm2835_alsa_stream *alsa_stream, >> atomic_set(&alsa_stream->pos, pos); >> >> alsa_stream->period_offset += bytes; >> + alsa_stream->interpolate_start = ktime_get(); >> if (alsa_stream->period_offset >= alsa_stream->period_size) { >> alsa_stream->period_offset %= alsa_stream->period_size; >> snd_pcm_period_elapsed(substream); >> @@ -243,6 +244,7 @@ static int snd_bcm2835_pcm_prepare(struct snd_pcm_substream *substream) >> atomic_set(&alsa_stream->pos, 0); >> alsa_stream->period_offset = 0; >> alsa_stream->draining = false; >> + alsa_stream->interpolate_start = ktime_get(); >> >> return 0; >> } >> @@ -292,6 +294,24 @@ snd_bcm2835_pcm_pointer(struct snd_pcm_substream *substream) >> { >> struct snd_pcm_runtime *runtime = substream->runtime; >> struct bcm2835_alsa_stream *alsa_stream = runtime->private_data; >> + ktime_t now = ktime_get(); >> + >> + /* Give userspace better delay reporting by interpolating between GPU >> + * notifications, assuming audio speed is close enough to the clock >> + * used for ktime >> + */ >> + >> + if ((ktime_to_ns(alsa_stream->interpolate_start)) && >> + (ktime_compare(alsa_stream->interpolate_start, now) < 0)) { >> + u64 interval = >> + (ktime_to_ns(ktime_sub(now, >> + alsa_stream->interpolate_start))); >> + u64 frames_output_in_interval = >> + div_u64((interval * runtime->rate), 1000000000); >> + snd_pcm_sframes_t frames_output_in_interval_sized = >> + -frames_output_in_interval; >> + runtime->delay = frames_output_in_interval_sized; >> + } >> >> return snd_pcm_indirect_playback_pointer(substream, >> &alsa_stream->pcm_indirect, >> diff --git a/drivers/staging/vc04_services/bcm2835-audio/bcm2835.h b/drivers/staging/vc04_services/bcm2835-audio/bcm2835.h >> index e13435d1c205..595ad584243f 100644 >> --- a/drivers/staging/vc04_services/bcm2835-audio/bcm2835.h >> +++ b/drivers/staging/vc04_services/bcm2835-audio/bcm2835.h >> @@ -78,6 +78,7 @@ struct bcm2835_alsa_stream { >> unsigned int period_offset; >> unsigned int buffer_size; >> unsigned int period_size; >> + ktime_t interpolate_start; >> >> struct bcm2835_audio_instance *instance; >> int idx; >> > _______________________________________________ > Alsa-devel mailing list > Alsa-devel@alsa-project.org > http://mailman.alsa-project.org/mailman/listinfo/alsa-devel