svn commit: r442097 - in head/audio/rsynth: . files
Tobias Kortkamp
tobik at FreeBSD.org
Tue May 30 16:18:56 UTC 2017
Author: tobik
Date: Tue May 30 16:18:54 2017
New Revision: 442097
URL: https://svnweb.freebsd.org/changeset/ports/442097
Log:
- Add Sndio backend from [1] and fix it
- Remove dead code
- Fix format selection and playback with raw devices
- Fix OSS backend
- Remove dead code
- Don't open the device in non-blocking mode. There is no error
handling for short writes and looking at how audio_play() is used in say.c
it is expected to block.
- Fix format selection
- Let the kernel handle sample conversion instead of doing it in the backend
- Make NAS support optional
- Make installing dictionary database tools optional
- Add LICENSE
Obtained from: OpenBSD [1] (based on)
Approved by: lme (mentor)
Differential Revision: https://reviews.freebsd.org/D10828
Added:
head/audio/rsynth/files/ossplay.c
- copied, changed from r442096, head/audio/rsynth/files/freebsdplay.c
head/audio/rsynth/files/patch-Makefile.in (contents, props changed)
head/audio/rsynth/files/sndioplay.c (contents, props changed)
Deleted:
head/audio/rsynth/files/freebsdplay.c
Modified:
head/audio/rsynth/Makefile
head/audio/rsynth/files/patch-configure.in
head/audio/rsynth/pkg-plist
Modified: head/audio/rsynth/Makefile
==============================================================================
--- head/audio/rsynth/Makefile Tue May 30 16:02:52 2017 (r442096)
+++ head/audio/rsynth/Makefile Tue May 30 16:18:54 2017 (r442097)
@@ -3,7 +3,7 @@
PORTNAME= rsynth
PORTVERSION= 2.0
-PORTREVISION= 4
+PORTREVISION= 5
CATEGORIES= audio accessibility
MASTER_SITES= ftp://svr-ftp.eng.cam.ac.uk/pub/comp.speech/synthesis/ \
ftp://ftp.enst.fr/pub/unix/multimedia/
@@ -11,14 +11,27 @@ MASTER_SITES= ftp://svr-ftp.eng.cam.ac.uk/pub/comp.spe
MAINTAINER= ports at FreeBSD.org
COMMENT= Speech synthesizer
-LIB_DEPENDS= libgdbm.so:databases/gdbm \
- libaudio.so:audio/nas
+LICENSE= PD
+OPTIONS_DEFINE= DB NAS SNDIO
+OPTIONS_SUB= yes
+
+DB_DESC= Build dictionary database tools
+DB_LIB_DEPENDS= libgdbm.so:databases/gdbm
+DB_CONFIGURE_ENV_OFF= ac_cv_lib_gdbm_gdbm_open=no
+NAS_LIB_DEPENDS= libaudio.so:audio/nas
+NAS_CONFIGURE_ENV_OFF= ac_cv_header_audio_audiolib_h=no
+SNDIO_LIB_DEPENDS= libsndio.so:audio/sndio
+SNDIO_MAKE_ENV= SAY_LIBS=-lsndio
+
USES= autoreconf
GNU_CONFIGURE= yes
-pre-configure:
- @${CP} ${FILESDIR}/freebsdplay.c ${WRKSRC}/config/freebsdplay.c
+pre-configure-SNDIO-on:
+ @${CP} ${FILESDIR}/sndioplay.c ${WRKSRC}/config/freebsdplay.c
+
+pre-configure-SNDIO-off:
+ @${CP} ${FILESDIR}/ossplay.c ${WRKSRC}/config/freebsdplay.c
post-configure:
@${REINPLACE_CMD} -E 's,(BIN|LIB)_DIR\),DESTDIR\)$$\(&,g' \
Copied and modified: head/audio/rsynth/files/ossplay.c (from r442096, head/audio/rsynth/files/freebsdplay.c)
==============================================================================
--- head/audio/rsynth/files/freebsdplay.c Tue May 30 16:02:52 2017 (r442096, copy source)
+++ head/audio/rsynth/files/ossplay.c Tue May 30 16:18:54 2017 (r442097)
@@ -29,112 +29,64 @@
#define SAMP_RATE 8000
long samp_rate = SAMP_RATE;
-/* Audio Parameters */
-
static int dev_fd = -1;
- /* file descriptor for audio device */
char *dev_file = "/dev/dsp";
-static int linear_fd = -1;
-
-static char *linear_file = NULL;
-
char *prog = "hplay";
-static int
-audio_open(void)
-{
- dev_fd = open(dev_file, O_WRONLY | O_NDELAY);
- if (dev_fd < 0)
- {
- perror(dev_file);
- return 0;
- }
- return 1;
-}
-
int
audio_init(int argc, char *argv[])
{
int rate_set = 0;
int use_audio = 1;
+ int fmt;
prog = argv[0];
- argc = getargs("freebsd Audio",argc, argv,
+ argc = getargs("Audio output",argc, argv,
"r", "%d", &rate_set, "Sample rate",
"a", NULL, &use_audio, "Audio enable",
NULL);
- if (help_only)
+ if (help_only || !use_audio)
return argc;
- if (use_audio)
- audio_open();
+ dev_fd = open(dev_file, O_WRONLY);
+ if (dev_fd < 0) {
+ perror(dev_file);
+ return argc;
+ }
if (rate_set)
samp_rate = rate_set;
- if (dev_fd > 0)
- {
- ioctl(dev_fd, SNDCTL_DSP_SPEED, &samp_rate);
- printf("Actual sound rate: %ld\n", samp_rate);
- }
+ fmt = AFMT_S16_NE;
+ if (ioctl(dev_fd, SNDCTL_DSP_SETFMT, &fmt) < 0)
+ perror("SNDCTL_DSP_SETFMT");
+ if (ioctl(dev_fd, SNDCTL_DSP_SPEED, &samp_rate) < 0)
+ perror("SNDCTL_DSP_SPEED");
+
return argc;
}
void
audio_term()
{
- int dummy;
-
- /* Close audio system */
if (dev_fd >= 0)
{
- ioctl(dev_fd, SNDCTL_DSP_SYNC, &dummy);
close(dev_fd);
dev_fd = -1;
}
-
- /* Finish linear file */
- if (linear_fd >= 0)
- {
- ftruncate(linear_fd, lseek(linear_fd, 0L, SEEK_CUR));
- close(linear_fd);
- linear_fd = -1;
- }
}
void
audio_play(int n, short *data)
{
- if (n > 0)
+ if (n > 0 && dev_fd >= 0)
{
- unsigned char *converted = (unsigned char *) malloc(n);
- int i;
-
- if (converted == NULL)
- {
- fprintf(stderr, "Could not allocate memory for conversion\n");
- exit(3);
- }
-
- for (i = 0; i < n; i++)
- converted[i] = (data[i] - 32768) / 256;
-
- if (linear_fd >= 0)
- {
- if (write(linear_fd, converted, n) != n)
- perror("write");
- }
-
- if (dev_fd >= 0)
- {
- if (write(dev_fd, converted, n) != n)
- perror("write");
- }
-
- free(converted);
+ size_t size = n * sizeof(short);
+ if (write(dev_fd, data, size) != size)
+ perror("write");
}
}
Added: head/audio/rsynth/files/patch-Makefile.in
==============================================================================
--- /dev/null 00:00:00 1970 (empty, because file is newly added)
+++ head/audio/rsynth/files/patch-Makefile.in Tue May 30 16:18:54 2017 (r442097)
@@ -0,0 +1,11 @@
+--- Makefile.in.orig 2017-05-20 02:25:06 UTC
++++ Makefile.in
+@@ -34,7 +34,7 @@ SAY_OBJS = say.o saynum.o darray.o ASCII.o phones.o te
+ getarg.o Revision.o
+
+ say : $(SAY_OBJS) hplay.o
+- $(CC) -o $@ $(LDFLAGS) $(SAY_OBJS) hplay.o $(LDLIBS)
++ $(CC) -o $@ $(LDFLAGS) $(SAY_OBJS) hplay.o $(SAY_LIBS) $(LDLIBS)
+
+ nasay : $(SAY_OBJS) naplay.o
+ $(CC) -o $@ $(LDFLAGS) $(SAY_OBJS) naplay.o $(XLIBS) $(LDLIBS)
Modified: head/audio/rsynth/files/patch-configure.in
==============================================================================
--- head/audio/rsynth/files/patch-configure.in Tue May 30 16:02:52 2017 (r442096)
+++ head/audio/rsynth/files/patch-configure.in Tue May 30 16:18:54 2017 (r442097)
@@ -27,7 +27,7 @@
PROGS="$PROGS mkdictdb dlookup"
else
DICTS=""
-@@ -126,7 +128,7 @@ if test "$ac_cv_header_audio_audiolib_h"
+@@ -126,7 +128,7 @@ if test "$ac_cv_header_audio_audiolib_h" = yes ; then
XLIBS="-laudio $XLIBS"
AC_DEFINE(HAVE_NAS)
],,$XLIBS $LIBS)
Added: head/audio/rsynth/files/sndioplay.c
==============================================================================
--- /dev/null 00:00:00 1970 (empty, because file is newly added)
+++ head/audio/rsynth/files/sndioplay.c Tue May 30 16:18:54 2017 (r442097)
@@ -0,0 +1,112 @@
+#include <config.h>
+
+/*****************************************************************/
+/*** ***/
+/*** Play out a file on OpenBSD ***/
+/*** (conf/linuxplay.c with changes) ***/
+/*** ***/
+/*****************************************************************/
+
+#include <useconfig.h>
+#include <stdio.h>
+#include <math.h>
+#include <ctype.h>
+
+#include <sys/file.h>
+#include <sys/stat.h>
+#include <sys/param.h>
+#include <sys/signal.h>
+
+#include <sndio.h>
+
+#include "proto.h"
+#include "getargs.h"
+#include "hplay.h"
+
+#define SAMP_RATE 8000
+long samp_rate = SAMP_RATE;
+
+static struct sio_hdl *hdl;
+static struct sio_par par;
+
+char *prog = "hplay";
+
+int
+audio_init(int argc, char *argv[])
+{
+ int rate_set = 0;
+ int use_audio = 1;
+
+ prog = argv[0];
+
+ argc = getargs("Audio output",argc, argv,
+ "r", "%d", &rate_set, "Sample rate",
+ "a", NULL, &use_audio, "Audio enable",
+ NULL);
+
+ if (help_only)
+ return argc;
+
+ if (rate_set)
+ samp_rate = rate_set;
+
+ if (!use_audio)
+ return argc;
+
+ hdl = sio_open(NULL, SIO_PLAY, 0);
+ if (hdl == NULL)
+ {
+ fprintf(stderr, "sio_open failed\n");
+ return argc;
+ }
+
+ sio_initpar(&par);
+ par.bits = 16;
+ par.sig = 1;
+ par.le = SIO_LE_NATIVE;
+ par.rate = samp_rate;
+ par.pchan = 1;
+
+ if (!sio_setpar(hdl, &par) || !sio_getpar(hdl, &par))
+ {
+ fprintf(stderr, "error setting sndio parameters\n");
+ hdl = NULL;
+ }
+
+ if (par.bits != 16 || par.le != SIO_LE_NATIVE || par.sig != 1 || par.pchan != 1)
+ {
+ fprintf(stderr, "returned incorrect sndio parameters\n");
+ hdl = NULL;
+ }
+
+ samp_rate = par.rate;
+
+ if (hdl && !sio_start(hdl))
+ {
+ fprintf(stderr, "error starting sndio\n");
+ hdl = NULL;
+ }
+
+ return argc;
+}
+
+void
+audio_term()
+{
+ if (hdl)
+ {
+ sio_close(hdl);
+ hdl = NULL;
+ }
+}
+
+void
+audio_play(int n, short *data)
+{
+ if (n > 0 && hdl)
+ {
+ size_t size = n * sizeof(short);
+ if (sio_write(hdl, data, size) != size)
+ fprintf(stderr, "sio_write: short write");
+ }
+}
Modified: head/audio/rsynth/pkg-plist
==============================================================================
--- head/audio/rsynth/pkg-plist Tue May 30 16:02:52 2017 (r442096)
+++ head/audio/rsynth/pkg-plist Tue May 30 16:18:54 2017 (r442097)
@@ -1,4 +1,4 @@
-bin/dlookup
-bin/mkdictdb
+%%DB%%bin/dlookup
+%%DB%%bin/mkdictdb
bin/say
-bin/nasay
+%%NAS%%bin/nasay
More information about the svn-ports-head
mailing list