From nobody Tue Feb 8 09:15:57 2022 X-Original-To: dev-commits-ports-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id C8D39198A7E5; Tue, 8 Feb 2022 09:15:59 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4JtHRy2r02z4XCD; Tue, 8 Feb 2022 09:15:57 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1644311758; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=vB7RMzr3kQv2vLNy66DoZpyQI6LwLwuqCohgPOhfB0g=; b=YLvxrcuphClBvBypTTROp/H7HxHDNcKBGrkGv8KyPABcAoD6BlZoymPInutyVGRzxJvdWs QYvO1TG2u5qh35ERd9TjitGAP+2KI11xzHW8trpPgTbdz0W+YtOxZF130K8+IXqK9hmyOG 0KcHk9jpS6tE2X+JxEmiEZM/rT4YsRQpj/d3aNVxeTeL4wmU5oXKPmtJUGl/UedEYFRQw1 owNux3BJZUhmNlGT1xgUaYmW0jHGCvrQ3UC6Sm/LviUx5mWONIDvPSyR8DMZH6ITjaY4o+ QF8ETHDv5Joc1f0sY1khPlLCc5y5vIA6XLGQAEaMRzuZ/UsamQxdMi/KNJDFng== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id B69AC16F02; Tue, 8 Feb 2022 09:15:57 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.16.1/8.16.1) with ESMTP id 2189FvuE040901; Tue, 8 Feb 2022 09:15:57 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.16.1/8.16.1/Submit) id 2189FvL9040900; Tue, 8 Feb 2022 09:15:57 GMT (envelope-from git) Date: Tue, 8 Feb 2022 09:15:57 GMT Message-Id: <202202080915.2189FvL9040900@gitrepo.freebsd.org> To: ports-committers@FreeBSD.org, dev-commits-ports-all@FreeBSD.org, dev-commits-ports-main@FreeBSD.org From: Hans Petter Selasky Subject: git: e66a5ac7ef61 - main - audio/alsa-plugins: Fix more oss_pointer() calculation bugs. List-Id: Commit messages for all branches of the ports repository List-Archive: https://lists.freebsd.org/archives/dev-commits-ports-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-ports-all@freebsd.org X-BeenThere: dev-commits-ports-all@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: hselasky X-Git-Repository: ports X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: e66a5ac7ef614d579dcb68d7213b87fec617eee7 Auto-Submitted: auto-generated ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1644311758; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=vB7RMzr3kQv2vLNy66DoZpyQI6LwLwuqCohgPOhfB0g=; b=ChzjuvUQcObQiGUC+c2wfVbmScvXuNpBhKoqHqgGvc3TX3RwHN8w6EAiZDiY7aiXS6Tdg1 /h4jbb/byghkhdiCSJ8ys0CVAtipqnRIzoinDkZuw/DsPCYAiGc/EQPxPZrHQZ+tPORdoY /f4etWm/lL4AKzamTaDvF8c16HNcLNeW779bYmHVgihD4E45vLqKCY7TcDXDjEjzn8aQ7/ lvd6FBcxpR62xD1WrFq/r9H9b5zeV3VSIP2nayeXRg3LTA2vuEhINuTtnnPxdNwuSndoE5 i1a9+an85c9OZJpfkMfemD26X4lOBEbUBUnY3upRj4QlgrwS2JjJfxrlR7c/HQ== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1644311758; a=rsa-sha256; cv=none; b=i2IRzdRKmY2cI9mEpqGknuDjRVasAy3GSlEBi+txqvHIUDu2CXfZ6Ujh1zfpvaBUF28sIv +FFu4N5eJdRYZMJiQpiJ303JKZvxykmp87wxyxmreDWG5UgQ+iL96lfNjsL+824cUOergn 1HFRAxAA5LMmODk2ZLyyZeoQ6nQUQ7WFF1EsvOdPZQxLnsCFA9WZIEvaSCCpvW92IzemdT Jt43kAdRvuZ8Aq7xPr2mExDlNVBp64mheXev0MqjglSFkN2CviLFNh2sw9LqG8UK2+IfK6 9SXh4BeNLASMibX1gx0e0qcogIgQvCCPnzOy1GyjOAPJyKvP6QCPEQyKx3D79A== ARC-Authentication-Results: i=1; mx1.freebsd.org; none X-ThisMailContainsUnwantedMimeParts: N The branch main has been updated by hselasky: URL: https://cgit.FreeBSD.org/ports/commit/?id=e66a5ac7ef614d579dcb68d7213b87fec617eee7 commit e66a5ac7ef614d579dcb68d7213b87fec617eee7 Author: Hans Petter Selasky AuthorDate: 2022-02-07 23:23:21 +0000 Commit: Hans Petter Selasky CommitDate: 2022-02-08 09:15:40 +0000 audio/alsa-plugins: Fix more oss_pointer() calculation bugs. Correctly set the water level based on min_avail to avoid infinite polling loops. Applications tested: chrome, musescore, aplay and arecord . PR: 261767 Approved by: pi (implicit) --- audio/alsa-plugins/Makefile | 2 +- audio/alsa-plugins/files/patch-oss_pcm__oss.c | 129 +++++++++++++++----------- 2 files changed, 76 insertions(+), 55 deletions(-) diff --git a/audio/alsa-plugins/Makefile b/audio/alsa-plugins/Makefile index 8b38f3b0bf13..cb092103d9ca 100644 --- a/audio/alsa-plugins/Makefile +++ b/audio/alsa-plugins/Makefile @@ -2,7 +2,7 @@ PORTNAME= alsa-plugins PORTVERSION= 1.2.2 -PORTREVISION= 6 +PORTREVISION= 7 DISTVERSIONPREFIX= v CATEGORIES= audio MASTER_SITES= GH diff --git a/audio/alsa-plugins/files/patch-oss_pcm__oss.c b/audio/alsa-plugins/files/patch-oss_pcm__oss.c index ca325bb68905..df0d91c02417 100644 --- a/audio/alsa-plugins/files/patch-oss_pcm__oss.c +++ b/audio/alsa-plugins/files/patch-oss_pcm__oss.c @@ -72,7 +72,7 @@ return result / oss->frame_bytes; } -@@ -67,24 +101,60 @@ static snd_pcm_sframes_t oss_read(snd_pcm_ioplug_t *io +@@ -67,37 +101,122 @@ static snd_pcm_sframes_t oss_read(snd_pcm_ioplug_t *io buf = (char *)areas->addr + (areas->first + areas->step * offset) / 8; size *= oss->frame_bytes; result = read(oss->fd, buf, size); @@ -101,56 +101,97 @@ snd_pcm_oss_t *oss = io->private_data; - struct count_info info; - int ptr; ++ snd_pcm_sframes_t frames; + audio_buf_info bi; -+ ssize_t bytes; - if (ioctl(oss->fd, io->stream == SND_PCM_STREAM_PLAYBACK ? - SNDCTL_DSP_GETOPTR : SNDCTL_DSP_GETIPTR, &info) < 0) { - fprintf(stderr, "*** OSS: oss_pointer error\n"); -- return 0; ++ switch (io->state) { ++ case SND_PCM_STATE_XRUN: ++ return -EPIPE; ++ case SND_PCM_STATE_RUNNING: ++ case SND_PCM_STATE_DRAINING: ++ break; ++ default: + return 0; + } +- ptr = snd_pcm_bytes_to_frames(io->pcm, info.ptr); +- return ptr; ++ + if (io->stream == SND_PCM_STREAM_PLAYBACK) { + if (ioctl(oss->fd, SNDCTL_DSP_GETOSPACE, &bi) < 0) + return -EINVAL; + } else { + if (ioctl(oss->fd, SNDCTL_DSP_GETISPACE, &bi) < 0) + return -EINVAL; - } -- ptr = snd_pcm_bytes_to_frames(io->pcm, info.ptr); -- return ptr; ++ } + + /* check for over- and under- run */ + if (bi.bytes != oss->bufsz) { + oss->buffer_used = true; + } else { -+ /* only report error once */ -+ if (oss->buffer_used == true) { -+ oss->buffer_used = false; ++ if (oss->buffer_used) + return -EPIPE; -+ } + } + -+ if (io->stream == SND_PCM_STREAM_PLAYBACK) -+ bi.bytes = oss->bufsz - bi.bytes; ++ frames = bi.bytes / oss->frame_bytes; + -+ /* -+ * Return exactly how many bytes can be read or written, -+ * relative to the current application pointer. -+ */ -+ bytes = snd_pcm_frames_to_bytes(io->pcm, io->appl_ptr) + bi.bytes; -+ bytes %= io->buffer_size * oss->frame_bytes; ++ /* range check */ ++ if (frames < 0) ++ frames = 0; ++ else if (frames > io->buffer_size) ++ frames = io->buffer_size; + -+ return snd_pcm_bytes_to_frames(io->pcm, bytes); ++ /* set hw_ptr directly */ ++ if (io->stream == SND_PCM_STREAM_PLAYBACK) { ++ io->hw_ptr = io->appl_ptr + frames - io->buffer_size; ++ } else { ++ io->hw_ptr = io->appl_ptr + frames; ++ } ++ return 0; } ++static int oss_prepare(snd_pcm_ioplug_t *io) ++{ ++ snd_pcm_oss_t *oss = io->private_data; ++ snd_pcm_sw_params_t *swparams; ++ snd_pcm_uframes_t min_avail; ++ int tmp; ++ ++ snd_pcm_sw_params_alloca(&swparams); ++ ++ if (snd_pcm_sw_params_current(io->pcm, swparams) == 0) { ++ snd_pcm_sw_params_get_avail_min(swparams, &min_avail); ++ snd_pcm_sw_params_alloca(&swparams); ++ } else { ++ min_avail = io->period_size; ++ } ++ ++ tmp = min_avail * oss->frame_bytes; ++ if (tmp > oss->bufsz) ++ tmp = oss->bufsz; ++ else if (tmp < 1) ++ tmp = 1; ++ ++#ifdef SNDCTL_DSP_LOW_WATER ++ if (ioctl(oss->fd, SNDCTL_DSP_LOW_WATER, &tmp) < 0) ++ return -EINVAL; ++#endif ++ oss->buffer_used = false; ++ ++ return 0; ++} ++ static int oss_start(snd_pcm_ioplug_t *io) -@@ -93,12 +163,23 @@ static int oss_start(snd_pcm_ioplug_t *io) + { + snd_pcm_oss_t *oss = io->private_data; int tmp = io->stream == SND_PCM_STREAM_PLAYBACK ? PCM_ENABLE_OUTPUT : PCM_ENABLE_INPUT; +#ifdef ALSA_OSS_DEBUG_VERBOSE + fprintf(stderr, "%s()\n", __func__); +#endif -+ if (ioctl(oss->fd, SNDCTL_DSP_SETTRIGGER, &tmp) < 0) { fprintf(stderr, "*** OSS: trigger failed\n"); +#ifdef __FreeBSD__ @@ -161,13 +202,9 @@ read(oss->fd, &tmp, 0); +#endif } -+ -+ oss->buffer_used = false; -+ return 0; } - -@@ -107,6 +188,10 @@ static int oss_stop(snd_pcm_ioplug_t *io) +@@ -107,6 +226,10 @@ static int oss_stop(snd_pcm_ioplug_t *io) snd_pcm_oss_t *oss = io->private_data; int tmp = 0; @@ -178,7 +215,7 @@ ioctl(oss->fd, SNDCTL_DSP_SETTRIGGER, &tmp); return 0; } -@@ -115,101 +200,176 @@ static int oss_drain(snd_pcm_ioplug_t *io) +@@ -115,101 +238,164 @@ static int oss_drain(snd_pcm_ioplug_t *io) { snd_pcm_oss_t *oss = io->private_data; @@ -224,7 +261,7 @@ - return -EINVAL; - } - return 0; -+ *delayp = snd_pcm_bytes_to_frames(io->pcm, tmp); ++ *delayp = tmp / oss->frame_bytes; + + return (0); } @@ -290,7 +327,6 @@ - oss->format = AFMT_S16_BE; - break; - default: -+ + oss->format = 0; + for (i = 0; i != ARRAY_SIZE(oss_formats_tab); i++) { + if (oss_formats_tab[i].alsa_format == io->format) { @@ -310,8 +346,8 @@ + + ioctl(oss->fd, SNDCTL_DSP_RESET); + -+ /* use a 16ms HW buffer by default */ -+ tmp = ((16 * io->rate) / 1000) * oss->frame_bytes; ++ /* use a 8ms HW buffer by default */ ++ tmp = ((8 * io->rate) / 1000) * oss->frame_bytes; + + /* round up to nearest power of two */ + while (tmp & (tmp - 1)) @@ -395,17 +431,6 @@ + + oss->bufsz = bi.fragsize * bi.fragstotal; + -+#ifdef SNDCTL_DSP_LOW_WATER -+ tmp = io->period_size * oss->frame_bytes; -+ if (tmp > oss->bufsz) -+ tmp = oss->bufsz; -+ else if (tmp < bi.fragsize) -+ tmp = bi.fragsize; -+ -+ if (ioctl(oss->fd, SNDCTL_DSP_LOW_WATER, &tmp) < 0) -+ perror("SNDCTL_DSP_LOW_WATER"); -+#endif -+ +#ifdef ALSA_OSS_DEBUG_VERBOSE + fprintf(stderr, + "\n\n[%lu -> %d] %lu ~ %d -> %d, %lu ~ %d -> %d [d:%ld lw:%d]\n\n", @@ -420,7 +445,7 @@ if ((flags = fcntl(oss->fd, F_GETFL)) < 0) { err = -errno; perror("F_GETFL"); -@@ -229,16 +389,148 @@ static int oss_hw_params(snd_pcm_ioplug_t *io, +@@ -229,16 +415,148 @@ static int oss_hw_params(snd_pcm_ioplug_t *io, return 0; } @@ -571,7 +596,7 @@ unsigned int format[5]; unsigned int nchannels; unsigned int channel[6]; -@@ -317,6 +609,7 @@ static int oss_hw_constraint(snd_pcm_oss_t *oss) +@@ -317,6 +635,7 @@ static int oss_hw_constraint(snd_pcm_oss_t *oss) return err; return 0; @@ -579,7 +604,7 @@ } -@@ -324,6 +617,10 @@ static int oss_close(snd_pcm_ioplug_t *io) +@@ -324,6 +643,10 @@ static int oss_close(snd_pcm_ioplug_t *io) { snd_pcm_oss_t *oss = io->private_data; @@ -590,27 +615,23 @@ close(oss->fd); free(oss->device); free(oss); -@@ -337,8 +634,8 @@ static const snd_pcm_ioplug_callback_t oss_playback_ca - .pointer = oss_pointer, - .close = oss_close, +@@ -339,6 +662,7 @@ static const snd_pcm_ioplug_callback_t oss_playback_ca .hw_params = oss_hw_params, -- .prepare = oss_prepare, + .prepare = oss_prepare, .drain = oss_drain, + .delay = oss_delay, }; static const snd_pcm_ioplug_callback_t oss_capture_callback = { -@@ -348,8 +645,8 @@ static const snd_pcm_ioplug_callback_t oss_capture_cal - .pointer = oss_pointer, - .close = oss_close, +@@ -350,6 +674,7 @@ static const snd_pcm_ioplug_callback_t oss_capture_cal .hw_params = oss_hw_params, -- .prepare = oss_prepare, + .prepare = oss_prepare, .drain = oss_drain, + .delay = oss_delay, }; -@@ -360,6 +657,10 @@ SND_PCM_PLUGIN_DEFINE_FUNC(oss) +@@ -360,6 +685,10 @@ SND_PCM_PLUGIN_DEFINE_FUNC(oss) int err; snd_pcm_oss_t *oss;