2009-10-11 09:36:23 -04:00
|
|
|
$OpenBSD: patch-stream_tvi_bsdbt848_c,v 1.2 2009/10/11 13:36:23 edd Exp $
|
|
|
|
--- stream/tvi_bsdbt848.c.orig Tue May 12 19:58:57 2009
|
|
|
|
+++ stream/tvi_bsdbt848.c Sat Jul 11 06:45:32 2009
|
|
|
|
@@ -37,9 +37,10 @@
|
2008-02-08 12:32:41 -05:00
|
|
|
#include <signal.h>
|
|
|
|
#include <string.h>
|
2009-10-11 09:36:23 -04:00
|
|
|
#include <errno.h>
|
|
|
|
+#include <sys/ioctl.h>
|
2008-02-08 12:32:41 -05:00
|
|
|
|
|
|
|
#include <sys/param.h>
|
2009-10-11 09:36:23 -04:00
|
|
|
-#ifdef CONFIG_SUN_AUDIO
|
|
|
|
+#if defined(CONFIG_SUN_AUDIO) && !defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
#include <sys/audioio.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
@@ -51,6 +52,9 @@
|
2008-02-08 12:32:41 -05:00
|
|
|
#include IOCTL_BT848_H_NAME
|
|
|
|
#endif
|
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
+#if defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
+#include <sndio.h>
|
|
|
|
+#else
|
2008-02-08 12:32:41 -05:00
|
|
|
#ifdef HAVE_SYS_SOUNDCARD_H
|
|
|
|
#include <sys/soundcard.h>
|
|
|
|
#else
|
2009-10-11 09:36:23 -04:00
|
|
|
@@ -60,6 +64,7 @@
|
2008-02-08 12:32:41 -05:00
|
|
|
#include <machine/soundcard.h>
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
+#endif
|
|
|
|
|
|
|
|
#include "libaf/af_format.h"
|
|
|
|
#include "libmpcodecs/img_format.h"
|
2009-10-11 09:36:23 -04:00
|
|
|
@@ -89,7 +94,12 @@ typedef struct {
|
|
|
|
/* Audio */
|
|
|
|
char *dspdev;
|
|
|
|
int dspready;
|
|
|
|
+#if defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
+ struct sio_hdl *hdl;
|
|
|
|
+ struct sio_par spar, gpar;
|
|
|
|
+#else
|
|
|
|
int dspfd;
|
|
|
|
+#endif
|
|
|
|
int dspsamplesize;
|
|
|
|
int dspstereo;
|
|
|
|
int dspspeed;
|
|
|
|
@@ -206,7 +216,9 @@ static tvi_handle_t *tvi_init_bsdbt848(tv_param_t* tv_
|
|
|
|
|
|
|
|
/* set audio device name */
|
|
|
|
if (!tv_param->adevice)
|
|
|
|
-#ifdef CONFIG_SUN_AUDIO
|
|
|
|
+#if defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
+ priv->dspdev = NULL;
|
|
|
|
+#elif defined(CONFIG_SUN_AUDIO)
|
|
|
|
priv->dspdev = strdup("/dev/sound");
|
|
|
|
#else
|
|
|
|
priv->dspdev = strdup("/dev/dsp");
|
|
|
|
@@ -315,12 +327,19 @@ static int control(priv_t *priv, int cmd, void *arg)
|
2008-02-08 12:32:41 -05:00
|
|
|
{
|
|
|
|
int dspspeed = *(int *)arg;
|
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
+#if defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
+ sio_initpar(&priv->spar);
|
|
|
|
+ priv->spar.rate = dspspeed;
|
|
|
|
+ if(!sio_setpar(priv->hdl, &priv->spar)) { printf("sio_setpar failed at %d\n", __LINE__); }
|
|
|
|
+ if(!sio_getpar(priv->hdl, &priv->gpar)) { printf("sio_getpar failed at %d\n", __LINE__); }
|
|
|
|
+ dspspeed = priv->gpar.rate;
|
2008-02-08 12:32:41 -05:00
|
|
|
+#else
|
2009-10-11 09:36:23 -04:00
|
|
|
if(ioctl(priv->dspfd, SNDCTL_DSP_SPEED, &dspspeed) == -1)
|
2008-02-08 12:32:41 -05:00
|
|
|
{
|
|
|
|
mp_msg(MSGT_TV, MSGL_ERR, MSGTR_TV_Bt848InvalidAudioRate, strerror(errno));
|
2009-10-11 09:36:23 -04:00
|
|
|
return TVI_CONTROL_FALSE;
|
|
|
|
}
|
|
|
|
-
|
2008-02-08 12:32:41 -05:00
|
|
|
+#endif
|
2009-10-11 09:36:23 -04:00
|
|
|
priv->dspspeed = dspspeed;
|
2008-02-08 12:32:41 -05:00
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
priv->dspframesize = priv->dspspeed*priv->dspsamplesize/8/
|
|
|
|
@@ -629,12 +648,46 @@ priv->dspready = TRUE;
|
2008-02-08 12:32:41 -05:00
|
|
|
priv->dspsamplesize = 16;
|
|
|
|
priv->dspstereo = 1;
|
|
|
|
priv->dspspeed = 44100;
|
2009-10-11 09:36:23 -04:00
|
|
|
+#if !defined(CONFIG_SNDIO_AUDIO)
|
2008-02-08 12:32:41 -05:00
|
|
|
priv->dspfmt = AFMT_S16_LE;
|
|
|
|
+#endif
|
|
|
|
priv->dspbytesread = 0;
|
|
|
|
priv->dsprate = priv->dspspeed * priv->dspsamplesize/8*(priv->dspstereo+1);
|
2009-10-11 09:36:23 -04:00
|
|
|
priv->dspframesize = priv->dspspeed*priv->dspsamplesize/8/priv->fps *
|
|
|
|
(priv->dspstereo+1);
|
2008-02-08 12:32:41 -05:00
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
+#if defined(CONFIG_SNDIO_AUDIO)
|
2008-02-08 12:32:41 -05:00
|
|
|
+
|
2009-10-11 09:36:23 -04:00
|
|
|
+if((priv->hdl = sio_open(priv->dspdev, SIO_REC, 0) == NULL))
|
|
|
|
+ {
|
|
|
|
+ mp_msg(MSGT_TV, MSGL_ERR, MSGTR_TV_Bt848ErrorOpeningDspDev, strerror(errno));
|
|
|
|
+ priv->dspready = FALSE;
|
|
|
|
+ }
|
2008-02-08 12:32:41 -05:00
|
|
|
+
|
2009-10-11 09:36:23 -04:00
|
|
|
+sio_initpar(&priv->spar);
|
|
|
|
+priv->spar.rchan = priv->dspstereo + 1;
|
|
|
|
+priv->spar.rate = priv->dspspeed;
|
|
|
|
+priv->spar.bits = priv->dspsamplesize;
|
|
|
|
+priv->spar.le = 1;
|
|
|
|
+priv->spar.sig = 1;
|
2008-02-08 12:32:41 -05:00
|
|
|
+
|
2009-10-11 09:36:23 -04:00
|
|
|
+if((priv->dspready == TRUE) &&
|
|
|
|
+ (!sio_setpar(priv->hdl, &priv->spar)))
|
|
|
|
+ {
|
|
|
|
+ mp_msg(MSGT_TV, MSGL_ERR, MSGTR_TV_Bt848ErrorConfiguringDsp, strerror(errno));
|
|
|
|
+ sio_close(priv->hdl);
|
|
|
|
+ priv->dspready = FALSE;
|
|
|
|
+ }
|
2008-02-08 12:32:41 -05:00
|
|
|
+
|
2009-10-11 09:36:23 -04:00
|
|
|
+if(!sio_start(priv->hdl))
|
|
|
|
+ {
|
|
|
|
+ mp_msg(MSGT_TV, MSGL_ERR, MSGTR_TV_Bt848ErrorConfiguringDsp, strerror(errno));
|
|
|
|
+ sio_close(priv->hdl);
|
|
|
|
+ priv->dspready = FALSE;
|
|
|
|
+ }
|
2008-02-08 12:32:41 -05:00
|
|
|
+
|
|
|
|
+#else
|
|
|
|
+
|
2009-10-11 09:36:23 -04:00
|
|
|
if((priv->dspfd = open (priv->dspdev, O_RDONLY, 0)) < 0)
|
2008-02-08 12:32:41 -05:00
|
|
|
{
|
2009-10-11 09:36:23 -04:00
|
|
|
mp_msg(MSGT_TV, MSGL_ERR, MSGTR_TV_Bt848ErrorOpeningDspDev, strerror(errno));
|
|
|
|
@@ -660,6 +713,8 @@ if((priv->dspready == TRUE) &&
|
2008-02-08 12:32:41 -05:00
|
|
|
priv->dspready = FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
+#endif
|
|
|
|
+
|
2009-10-11 09:36:23 -04:00
|
|
|
return 1;
|
2008-02-08 12:32:41 -05:00
|
|
|
}
|
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
@@ -684,7 +739,9 @@ if(ioctl(priv->btfd, METEORSSIGNAL, &marg) < 0)
|
|
|
|
return 0;
|
|
|
|
}
|
2008-02-08 12:32:41 -05:00
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
+#if !defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
read(priv->dspfd, &tmp, 2);
|
|
|
|
+#endif
|
2008-02-08 12:32:41 -05:00
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
gettimeofday(&curtime, NULL);
|
2008-02-08 12:32:41 -05:00
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
@@ -723,10 +780,15 @@ if(ioctl(priv->btfd, METEORCAPTUR, &marg) < 0 )
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
-close(priv->btfd);
|
|
|
|
+#if defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
+sio_close(priv->hdl);
|
|
|
|
+priv->hdl = NULL;
|
|
|
|
+#else
|
|
|
|
close(priv->dspfd);
|
|
|
|
-
|
2008-02-08 12:32:41 -05:00
|
|
|
priv->dspfd = -1;
|
2009-10-11 09:36:23 -04:00
|
|
|
+#endif
|
|
|
|
+
|
|
|
|
+close(priv->btfd);
|
2008-02-08 12:32:41 -05:00
|
|
|
priv->btfd = -1;
|
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
priv->dspready = priv->videoready = FALSE;
|
|
|
|
@@ -806,11 +868,19 @@ gettimeofday(&curtime, NULL);
|
2008-02-08 12:32:41 -05:00
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
/* Get exactly one frame of audio, which forces video sync to audio.. */
|
2008-02-08 12:32:41 -05:00
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
+#if defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
+bytesread=sio_read(priv->hdl, buffer, len);
|
|
|
|
+#else
|
|
|
|
bytesread=read(priv->dspfd, buffer, len);
|
|
|
|
+#endif
|
|
|
|
|
|
|
|
while(bytesread < len)
|
|
|
|
{
|
|
|
|
+#if defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
+ ret=sio_read(priv->hdl, &buffer[bytesread], len-bytesread);
|
|
|
|
+#else
|
|
|
|
ret=read(priv->dspfd, &buffer[bytesread], len-bytesread);
|
|
|
|
+#endif
|
2008-02-08 12:32:41 -05:00
|
|
|
|
2009-10-11 09:36:23 -04:00
|
|
|
if(ret == -1)
|
|
|
|
{
|
|
|
|
@@ -845,13 +915,16 @@ return priv->dspbytesread * 1.0 / priv->dsprate;
|
|
|
|
static int get_audio_framesize(priv_t *priv)
|
2008-02-08 12:32:41 -05:00
|
|
|
{
|
2009-10-11 09:36:23 -04:00
|
|
|
int bytesavail;
|
|
|
|
-#ifdef CONFIG_SUN_AUDIO
|
|
|
|
+#if defined(CONFIG_SUN_AUDIO) && !defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
struct audio_info auinf;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if(priv->dspready == FALSE) return 0;
|
|
|
|
|
|
|
|
-#ifdef CONFIG_SUN_AUDIO
|
|
|
|
+#if defined(CONFIG_SNDIO_AUDIO)
|
|
|
|
+sio_getpar(priv->hdl, &priv->gpar);
|
|
|
|
+bytesavail = priv->gpar.round * priv->gpar.bps;
|
|
|
|
+#elif defined(CONFIG_SUN_AUDIO)
|
|
|
|
if(ioctl(priv->dspfd, AUDIO_GETINFO, &auinf) < 0)
|
|
|
|
{
|
|
|
|
mp_msg(MSGT_TV, MSGL_ERR, MSGTR_TV_Bt848IoctlFailed, "AUDIO_GETINFO", strerror(errno));
|