summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Changelog35
-rw-r--r--DOCS/man/en/mplayer.120
-rw-r--r--Makefile1
-rwxr-xr-xconfigure26
-rw-r--r--libao2/ao_kai.c331
-rw-r--r--libao2/audio_out.c4
-rw-r--r--libmpcodecs/vf_tfields.c21
7 files changed, 412 insertions, 26 deletions
diff --git a/Changelog b/Changelog
index 3b856cc4f6..1695720b65 100644
--- a/Changelog
+++ b/Changelog
@@ -5,42 +5,43 @@ MPlayer (1.0)
* YUY2 Lossless Codec (YLC0) via binary DLL
* Truemotion RT codec (TR20) via binary DLL
* Nogantech Codec (NTN1 and NTN2) via binary DLL
- * add new FourCCs (m1v1,yuvs,VYUY,Y42B,V422,YUNV,UYNV,UYNY,uyv1,2Vu1,P422,HDYC,
- IJLV,MVJP)
- TwoCCs (0xA106,0x6c75,0xAAC0,0x55005354)
+ * add new FourCCs (m1v1, yuvs, VYUY, Y42B, V422, YUNV, UYNV, UYNY, uyv1,
+ 2Vu1, P422, HDYC, IJLV, MVJP)
+ TwoCCs (0xA106, 0x6c75, 0xAAC0, 0x55005354)
to existing decoders.
- * AMR now handled via opencore decoder
- * updated Windoes Media Screen Codec (MSS1,MSS2) via binary DLL
- * h264 decoder (CoreAVC) on Windows only via binary DLL
+ * AMR now handled via OpenCORE decoder
+ * updated Windows Media Screen Codec (MSS1, MSS2) via binary DLL
+ * CoreAVC H.264 decoder via binary DLL (Windows only)
* Kega Game video codec (KGV1) via binary DLL
- * SoftLab-NSK Forward MPEG2 I-frames (SLIF) via binary DLL
- * JPEG2000 support via OpenJPEG
+ * SoftLab-NSK Forward MPEG-2 I-frames (SLIF) via binary DLL
+ * JPEG 2000 support via OpenJPEG
Demuxers:
- * support for TrueHD in BluRay streams in libmpdemux
- * more BluRay codec support with lavf
- * fix length in asf/wmv files
- * support ISDB-Tb dvb streams
+ * support for TrueHD in Blu-ray streams in libmpdemux
+ * more Blu-ray codec support with lavf
+ * fix length in ASF/WMV files
+ * support ISDB-Tb DVB streams
Drivers:
- * Support for more formats in OpenGL vos (different YUV
+ * Support for more formats in OpenGL video output drivers (different YUV
subsampling, 16 bit per component)
* Selectable YUV to RGB conversion standard for -vo gl
(-vo gl:colorspace=...:levelconv=...)
* -vo matrixview finally added
+ * add OS/2 KAI audio driver (-ao kai)
Other:
* -nosub option for disabling auto-selected subtitles
- * support for displaying subs in the term (FIXME)
- * support for subtitles with audio only files
+ * support for displaying subs in the terminal (FIXME)
+ * support for subtitles with audio-only files
* support for right-to-left languages with embedded subtitles
* support for 8 channel audio
* sync dvd:// and dvdnav:// features
- * support for mpeg4 asp in VDPAU video output (non B-frame only)
+ * support for MPEG-4 ASP in VDPAU video output (non B-frame only)
* support for live and non-live DVB teletext with demuxer lavf
* -name, -title and -use-filename-title options for MPlayer
* support for stream handling via FFmpeg
- Use e.g. ffmpeg://http://example.com/test
+ (use e.g. ffmpeg://http://example.com/test)
* better support for 16-bit-per-component formats and formats
with alpha channel.
* better out-of-the-box support for compiling for ARM, IA64,
diff --git a/DOCS/man/en/mplayer.1 b/DOCS/man/en/mplayer.1
index 6e9282ae25..5e11048552 100644
--- a/DOCS/man/en/mplayer.1
+++ b/DOCS/man/en/mplayer.1
@@ -2822,6 +2822,22 @@ Playing a file with \-v will show a list of available devices.
.PD 1
.
.TP
+.B kai (OS/2 only)
+OS/2 KAI audio output driver
+.PD 0
+.RSs
+.IPs uniaud
+Force UNIAUD mode
+.IPs dart
+Force DART mode
+.IPs (no)share
+Open audio in shareable or exclusive mode.
+.IPs bufsize=<size>
+Set buffer size to <size> in samples (default: 2048).
+.RE
+.PD 1
+.
+.TP
.B dart (OS/2 only)
OS/2 DART audio output driver
.PD 0
@@ -7057,8 +7073,8 @@ Height unchanged at half framerate.
.B tfields[=mode[:field_dominance]]
Temporal field separation \- split fields into frames, doubling the
output framerate.
-Like the telecine filter, tfields will only work properly with
-MEncoder, and only if both \-fps and \-ofps are set to the
+Like the telecine filter, tfields might not work completely right unless
+used with MEncoder and both \-fps and \-ofps set to the
desired (double) framerate!
.PD 0
.RSs
diff --git a/Makefile b/Makefile
index da5172ef7d..eef6f927d6 100644
--- a/Makefile
+++ b/Makefile
@@ -548,6 +548,7 @@ SRCS_MPLAYER-$(IVTV) += libao2/ao_ivtv.c libvo/vo_ivtv.c
SRCS_MPLAYER-$(JACK) += libao2/ao_jack.c
SRCS_MPLAYER-$(JOYSTICK) += input/joystick.c
SRCS_MPLAYER-$(JPEG) += libvo/vo_jpeg.c
+SRCS_MPLAYER-$(KAI) += libao2/ao_kai.c
SRCS_MPLAYER-$(KVA) += libvo/vo_kva.c
SRCS_MPLAYER-$(LIBAVCODEC) += libvo/vo_png.c
SRCS_MPLAYER-$(LIBMENU) += libmenu/menu.c \
diff --git a/configure b/configure
index 519edaad26..c4bc567f8c 100755
--- a/configure
+++ b/configure
@@ -393,6 +393,7 @@ Audio output:
--disable-nas disable NAS audio output [autodetect]
--disable-sgiaudio disable SGI audio output [autodetect]
--disable-sunaudio disable Sun audio output [autodetect]
+ --disable-kai disable KAI audio output [autodetect]
--disable-dart disable DART audio output [autodetect]
--disable-win32waveout disable Windows waveout audio output [autodetect]
--disable-coreaudio disable CoreAudio audio output [autodetect]
@@ -563,6 +564,7 @@ _arts=auto
_esd=auto
_pulse=auto
_jack=auto
+_kai=auto
_dart=auto
_openal=no
_libcdio=auto
@@ -949,6 +951,8 @@ for ac_option do
--disable-jack) _jack=no ;;
--enable-openal) _openal=yes ;;
--disable-openal) _openal=no ;;
+ --enable-kai) _kai=yes ;;
+ --disable-kai) _kai=no ;;
--enable-dart) _dart=yes ;;
--disable-dart) _dart=no ;;
--enable-mad) _mad=yes ;;
@@ -5803,6 +5807,26 @@ fi #if irix
if os2 ; then
+echocheck "KAI (UNIAUD/DART)"
+if test "$_kai" = auto; then
+ cat > $TMPC << EOF
+#include <os2.h>
+#include <kai.h>
+int main(void) { return 0; }
+EOF
+ _kai=no;
+ cc_check -lkai && _kai=yes
+fi
+if test "$_kai" = yes ; then
+ def_kai='#define CONFIG_KAI 1'
+ libs_mplayer="$libs_mplayer -lkai"
+ _aomodules="kai $_aomodules"
+else
+ def_kai='#undef CONFIG_KAI'
+ _noaomodules="kai $_noaomodules"
+fi
+echores "$_kai"
+
echocheck "DART"
if test "$_dart" = auto; then
cat > $TMPC << EOF
@@ -7963,6 +7987,7 @@ IVTV = $_ivtv
JACK = $_jack
JOYSTICK = $_joystick
JPEG = $_jpeg
+KAI = $_kai
KVA = $_kva
LADSPA = $_ladspa
LIBA52 = $_liba52
@@ -8348,6 +8373,7 @@ $def_dart
$def_esd
$def_esd_latency
$def_jack
+$def_kai
$def_nas
$def_openal
$def_openal_h
diff --git a/libao2/ao_kai.c b/libao2/ao_kai.c
new file mode 100644
index 0000000000..a52b60e0b5
--- /dev/null
+++ b/libao2/ao_kai.c
@@ -0,0 +1,331 @@
+/*
+ * OS/2 KAI audio output driver
+ *
+ * Copyright (c) 2010 by KO Myung-Hun (komh@chollian.net)
+ *
+ * This file is part of MPlayer.
+ *
+ * MPlayer is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * MPlayer is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with MPlayer; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#define INCL_DOS
+#define INCL_DOSERRORS
+#include <os2.h>
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <sys/time.h>
+#include <float.h>
+
+#include <kai.h>
+
+#include "config.h"
+#include "libaf/af_format.h"
+#include "audio_out.h"
+#include "audio_out_internal.h"
+#include "mp_msg.h"
+#include "libvo/fastmemcpy.h"
+#include "subopt-helper.h"
+#include "libavutil/fifo.h"
+
+static const ao_info_t info = {
+ "KAI audio output",
+ "kai",
+ "KO Myung-Hun <komh@chollian.net>",
+ ""
+};
+
+LIBAO_EXTERN(kai)
+
+#define OUTBURST_SAMPLES 512
+#define DEFAULT_SAMPLES (OUTBURST_SAMPLES << 2)
+
+#define CHUNK_SIZE ao_data.outburst
+
+static AVFifoBuffer *m_audioBuf;
+
+static int m_nBufSize = 0;
+
+static volatile int m_fQuit = FALSE;
+
+static KAISPEC m_kaiSpec;
+
+static HKAI m_hkai;
+
+static int write_buffer(unsigned char *data, int len)
+{
+ int nFree = av_fifo_space(m_audioBuf);
+
+ len = FFMIN(len, nFree);
+
+ return av_fifo_generic_write(m_audioBuf, data, len, NULL);
+}
+
+static int read_buffer(unsigned char *data, int len)
+{
+ int nBuffered = av_fifo_size(m_audioBuf);
+
+ len = FFMIN(len, nBuffered);
+
+ av_fifo_generic_read(m_audioBuf, data, len, NULL);
+ return len;
+}
+
+// end ring buffer stuff
+
+static ULONG APIENTRY kai_audio_callback(PVOID pCBData, PVOID pBuffer,
+ ULONG ulSize)
+{
+ int nReadLen;
+
+ nReadLen = read_buffer(pBuffer, ulSize);
+ if (nReadLen < ulSize && !m_fQuit) {
+ memset((uint8_t *)pBuffer + nReadLen, m_kaiSpec.bSilence, ulSize - nReadLen);
+ nReadLen = ulSize;
+ }
+
+ return nReadLen;
+}
+
+// to set/get/query special features/parameters
+static int control(int cmd, void *arg)
+{
+ switch (cmd) {
+ case AOCONTROL_GET_VOLUME:
+ {
+ ao_control_vol_t *vol = arg;
+
+ vol->left = vol->right = kaiGetVolume(m_hkai, MCI_STATUS_AUDIO_ALL);
+
+ return CONTROL_OK;
+ }
+
+ case AOCONTROL_SET_VOLUME:
+ {
+ int mid;
+ ao_control_vol_t *vol = arg;
+
+ mid = (vol->left + vol->right) / 2;
+ kaiSetVolume(m_hkai, MCI_SET_AUDIO_ALL, mid);
+
+ return CONTROL_OK;
+ }
+ }
+
+ return CONTROL_UNKNOWN;
+}
+
+static void print_help(void)
+{
+ mp_msg(MSGT_AO, MSGL_FATAL,
+ "\n-ao kai commandline help:\n"
+ "Example: mplayer -ao kai:noshare\n"
+ " open audio in exclusive mode\n"
+ "\nOptions:\n"
+ " uniaud\n"
+ " Use UNIAUD audio driver\n"
+ " dart\n"
+ " Use DART audio driver\n"
+ " (no)share\n"
+ " Open audio in shareable or exclusive mode\n"
+ " bufsize=<size>\n"
+ " Set buffer size to <size> in samples(default: 2048)\n");
+}
+
+// open & set up audio device
+// return: 1=success 0=fail
+static int init(int rate, int channels, int format, int flags)
+{
+ int fUseUniaud = 0;
+ int fUseDart = 0;
+ int fShare = 1;
+ ULONG kaiMode;
+ KAICAPS kc;
+ int nSamples = DEFAULT_SAMPLES;
+ int nBytesPerSample;
+ KAISPEC ksWanted;
+
+ const opt_t subopts[] = {
+ {"uniaud", OPT_ARG_BOOL, &fUseUniaud, NULL},
+ {"dart", OPT_ARG_BOOL, &fUseDart, NULL},
+ {"share", OPT_ARG_BOOL, &fShare, NULL},
+ {"bufsize", OPT_ARG_INT, &nSamples, int_non_neg},
+ {NULL}
+ };
+
+ const char *audioDriver[] = {"DART", "UNIAUD",};
+
+ if (subopt_parse(ao_subdevice, subopts) != 0) {
+ print_help();
+ return 0;
+ }
+
+ if (fUseUniaud && fUseDart)
+ mp_msg(MSGT_VO, MSGL_WARN,"KAI: Multiple mode specified!!!\n");
+
+ if (fUseUniaud)
+ kaiMode = KAIM_UNIAUD;
+ else if (fUseDart)
+ kaiMode = KAIM_DART;
+ else
+ kaiMode = KAIM_AUTO;
+
+ if (kaiInit(kaiMode)) {
+ mp_msg(MSGT_VO, MSGL_ERR, "KAI: Init failed!!!\n");
+ return 0;
+ }
+
+ kaiCaps(&kc);
+ mp_msg(MSGT_AO, MSGL_V, "KAI: selected audio driver = %s\n",
+ audioDriver[kc.ulMode - 1]);
+ mp_msg(MSGT_AO, MSGL_V, "KAI: PDD name = %s, maximum channels = %lu\n",
+ kc.szPDDName, kc.ulMaxChannels);
+
+ if (!nSamples)
+ nSamples = DEFAULT_SAMPLES;
+
+ mp_msg(MSGT_AO, MSGL_V, "KAI: open in %s mode, buffer size = %d sample(s)\n",
+ fShare ? "shareable" : "exclusive", nSamples);
+
+ switch (format) {
+ case AF_FORMAT_S16_LE:
+ case AF_FORMAT_S8:
+ break;
+
+ default:
+ format = AF_FORMAT_S16_LE;
+ mp_msg(MSGT_AO, MSGL_V, "KAI: format %s not supported defaulting to Signed 16-bit Little-Endian\n",
+ af_fmt2str_short(format));
+ break;
+ }
+
+ nBytesPerSample = (af_fmt2bits(format) >> 3) * channels;
+
+ ksWanted.usDeviceIndex = 0;
+ ksWanted.ulType = KAIT_PLAY;
+ ksWanted.ulBitsPerSample = af_fmt2bits(format);
+ ksWanted.ulSamplingRate = rate;
+ ksWanted.ulDataFormat = MCI_WAVE_FORMAT_PCM;
+ ksWanted.ulChannels = channels;
+ ksWanted.ulNumBuffers = 2;
+ ksWanted.ulBufferSize = nBytesPerSample * nSamples;
+ ksWanted.fShareable = fShare;
+ ksWanted.pfnCallBack = kai_audio_callback;
+ ksWanted.pCallBackData = NULL;
+
+ if (kaiOpen(&ksWanted, &m_kaiSpec, &m_hkai)) {
+ mp_msg(MSGT_VO, MSGL_ERR, "KAI: Open failed!!!\n");
+ return 0;
+ }
+
+ mp_msg(MSGT_AO, MSGL_V, "KAI: obtained buffer count = %lu, size = %lu bytes\n",
+ m_kaiSpec.ulNumBuffers, m_kaiSpec.ulBufferSize);
+
+ m_fQuit = FALSE;
+
+ ao_data.channels = channels;
+ ao_data.samplerate = rate;
+ ao_data.format = format;
+ ao_data.bps = nBytesPerSample * rate;
+ ao_data.outburst = nBytesPerSample * OUTBURST_SAMPLES;
+ ao_data.buffersize = m_kaiSpec.ulBufferSize;
+
+ m_nBufSize = (m_kaiSpec.ulBufferSize * m_kaiSpec.ulNumBuffers) << 3;
+
+ // multiple of CHUNK_SIZE
+ m_nBufSize = (m_nBufSize / CHUNK_SIZE) * CHUNK_SIZE;
+
+ // and one more chunk plus round up
+ m_nBufSize += 2 * CHUNK_SIZE;
+
+ mp_msg(MSGT_AO, MSGL_V, "KAI: internal audio buffer size = %d bytes\n",
+ m_nBufSize);
+
+ m_audioBuf = av_fifo_alloc(m_nBufSize);
+
+ kaiPlay(m_hkai);
+
+ // might cause PM DLLs to be loaded which incorrectly enable SIG_FPE,
+ // which AAC decoding might trigger.
+ // so, mask off all floating-point exceptions.
+ _control87(MCW_EM, MCW_EM);
+
+ return 1;
+}
+
+// close audio device
+static void uninit(int immed)
+{
+ m_fQuit = TRUE;
+
+ if (!immed)
+ while (kaiStatus(m_hkai) & KAIS_PLAYING)
+ DosSleep(1);
+
+ kaiClose(m_hkai);
+
+ kaiDone();
+
+ av_fifo_free(m_audioBuf);
+}
+
+// stop playing and empty buffers (for seeking/pause)
+static void reset(void)
+{
+ kaiPause(m_hkai);
+
+ // Reset ring-buffer state
+ av_fifo_reset(m_audioBuf);
+
+ kaiResume(m_hkai);
+}
+
+// stop playing, keep buffers (for pause)
+static void audio_pause(void)
+{
+ kaiPause(m_hkai);
+}
+
+// resume playing, after audio_pause()
+static void audio_resume(void)
+{
+ kaiResume(m_hkai);
+}
+
+// return: how many bytes can be played without blocking
+static int get_space(void)
+{
+ return av_fifo_space(m_audioBuf);
+}
+
+// plays 'len' bytes of 'data'
+// it should round it down to outburst*n
+// return: number of bytes played
+static int play(void *data, int len, int flags)
+{
+
+ if (!(flags & AOPLAY_FINAL_CHUNK))
+ len = (len / ao_data.outburst) * ao_data.outburst;
+
+ return write_buffer(data, len);
+}
+
+// return: delay in seconds between first and last sample in buffer
+static float get_delay(void)
+{
+ int nBuffered = av_fifo_size(m_audioBuf); // could be less
+
+ return (float)nBuffered / (float)ao_data.bps;
+}
diff --git a/libao2/audio_out.c b/libao2/audio_out.c
index 5ceafff73f..aaba6a90e5 100644
--- a/libao2/audio_out.c
+++ b/libao2/audio_out.c
@@ -46,6 +46,7 @@ extern const ao_functions_t audio_out_sun;
extern const ao_functions_t audio_out_sgi;
extern const ao_functions_t audio_out_win32;
extern const ao_functions_t audio_out_dsound;
+extern const ao_functions_t audio_out_kai;
extern const ao_functions_t audio_out_dart;
extern const ao_functions_t audio_out_dxr2;
extern const ao_functions_t audio_out_ivtv;
@@ -63,6 +64,9 @@ const ao_functions_t* const audio_out_drivers[] =
#ifdef CONFIG_WIN32WAVEOUT
&audio_out_win32,
#endif
+#ifdef CONFIG_KAI
+ &audio_out_kai,
+#endif
#ifdef CONFIG_DART
&audio_out_dart,
#endif
diff --git a/libmpcodecs/vf_tfields.c b/libmpcodecs/vf_tfields.c
index 1261936293..e687fdaff3 100644
--- a/libmpcodecs/vf_tfields.c
+++ b/libmpcodecs/vf_tfields.c
@@ -44,13 +44,16 @@ static void deint(unsigned char *dest, int ds, unsigned char *src, int ss, int w
int x, y;
src += ss;
dest += ds;
+ h--;
if (field) {
+ fast_memcpy(dest - ds, src - ss, w);
src += ss;
dest += ds;
- h -= 2;
+ h--;
}
- for (y=h/2; y; y--) {
- for (x=0; x<w; x++) {
+ for (y=h/2; y > 0; y--) {
+ dest[0] = src[0];
+ for (x=1; x<w-1; x++) {
if (((src[x-ss] < src[x]) && (src[x+ss] < src[x])) ||
((src[x-ss] > src[x]) && (src[x+ss] > src[x]))) {
//dest[x] = (src[x+ss] + src[x-ss])>>1;
@@ -60,9 +63,12 @@ static void deint(unsigned char *dest, int ds, unsigned char *src, int ss, int w
}
else dest[x] = src[x];
}
+ dest[w-1] = src[w-1];
dest += ds<<1;
src += ss<<1;
}
+ if (h & 1)
+ fast_memcpy(dest, src, w);
}
#if HAVE_AMD3DNOW
@@ -445,11 +451,13 @@ static int continue_buffered_image(struct vf_instance *vf)
return ret;
}
-#if 0
static int query_format(struct vf_instance* vf, unsigned int fmt)
{
- /* FIXME - figure out which other formats work */
+ /* FIXME - figure out which formats exactly work */
switch (fmt) {
+ default:
+ if (vf->priv->mode == 1)
+ return 0;
case IMGFMT_YV12:
case IMGFMT_IYUV:
case IMGFMT_I420:
@@ -457,7 +465,6 @@ static int query_format(struct vf_instance* vf, unsigned int fmt)
}
return 0;
}
-#endif
static int config(struct vf_instance* vf,
int width, int height, int d_width, int d_height,
@@ -485,7 +492,7 @@ static int open(vf_instance_t *vf, char* args)
struct vf_priv_s *p;
vf->config = config;
vf->put_image = put_image;
- //vf->query_format = query_format;
+ vf->query_format = query_format;
vf->uninit = uninit;
vf->default_reqs = VFCAP_ACCEPT_STRIDE;
vf->priv = p = calloc(1, sizeof(struct vf_priv_s));