Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-1.1
Commits
7c8b9f86
Commit
7c8b9f86
authored
Jan 04, 2010
by
Jean-Baptiste Kempf
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Remove qnx modules.
Unmaintained and no maintainer showed up
parent
f5aed5af
Changes
9
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
3 additions
and
1491 deletions
+3
-1491
NEWS
NEWS
+1
-1
configure.ac
configure.ac
+1
-15
modules/LIST
modules/LIST
+0
-1
modules/gui/Modules.am
modules/gui/Modules.am
+1
-2
modules/gui/qnx/Modules.am
modules/gui/qnx/Modules.am
+0
-4
modules/gui/qnx/aout.c
modules/gui/qnx/aout.c
+0
-321
modules/gui/qnx/qnx.c
modules/gui/qnx/qnx.c
+0
-56
modules/gui/qnx/vout.c
modules/gui/qnx/vout.c
+0
-1088
po/POTFILES.in
po/POTFILES.in
+0
-3
No files found.
NEWS
View file @
7c8b9f86
...
@@ -99,7 +99,7 @@ Removed modules:
...
@@ -99,7 +99,7 @@ Removed modules:
* gtk_main, gtk_main2, gnome_main, gnome_main2 and pda interfaces
* gtk_main, gtk_main2, gnome_main, gnome_main2 and pda interfaces
* linear_resampler and trivial_resampler are removed. Use the ugly one.
* linear_resampler and trivial_resampler are removed. Use the ugly one.
* XvMC accelerated modules
* XvMC accelerated modules
* WinCE
interface
* WinCE
and qnx interfaces
* opie, qte and qte_main
* opie, qte and qte_main
* opengllayer
* opengllayer
* cddax. Use cdda instead
* cddax. Use cdda instead
...
...
configure.ac
View file @
7c8b9f86
...
@@ -2639,7 +2639,7 @@ if test "${enable_screen}" != "no"; then
...
@@ -2639,7 +2639,7 @@ if test "${enable_screen}" != "no"; then
fi
fi
dnl
dnl
dnl ipv6 plugin
- not for QNX yet
dnl ipv6 plugin
dnl
dnl
have_ipv6=no
have_ipv6=no
AC_CHECK_FUNCS(inet_pton,[have_ipv6=yes],[
AC_CHECK_FUNCS(inet_pton,[have_ipv6=yes],[
...
@@ -4396,19 +4396,6 @@ AM_CONDITIONAL(BUILD_MACOSX_VLC_APP, [test "${enable_macosx_vlc_app}" != "no" &&
...
@@ -4396,19 +4396,6 @@ AM_CONDITIONAL(BUILD_MACOSX_VLC_APP, [test "${enable_macosx_vlc_app}" != "no" &&
(test "${SYS}" = "darwin" || test "${enable_macosx_vlc_app}" = "yes") ])
(test "${SYS}" = "darwin" || test "${enable_macosx_vlc_app}" = "yes") ])
dnl
dnl QNX RTOS module
dnl
AC_ARG_ENABLE(qnx,
[ --enable-qnx QNX RTOS support (default enabled on QNX RTOS)])
if test "${enable_qnx}" != "no"
then
AC_CHECK_HEADERS(Ph.h, [
VLC_ADD_PLUGIN([qnx])
VLC_ADD_LIBS([qnx],[-lasound -lph])
])
fi
dnl
dnl
dnl ncurses module
dnl ncurses module
dnl
dnl
...
@@ -5168,7 +5155,6 @@ AC_CONFIG_FILES([
...
@@ -5168,7 +5155,6 @@ AC_CONFIG_FILES([
modules/gui/hildon/Makefile
modules/gui/hildon/Makefile
modules/gui/minimal_macosx/Makefile
modules/gui/minimal_macosx/Makefile
modules/gui/macosx_dialog_provider/Makefile
modules/gui/macosx_dialog_provider/Makefile
modules/gui/qnx/Makefile
modules/gui/qt4/Makefile
modules/gui/qt4/Makefile
modules/gui/skins2/Makefile
modules/gui/skins2/Makefile
modules/meta_engine/Makefile
modules/meta_engine/Makefile
...
...
modules/LIST
View file @
7c8b9f86
...
@@ -258,7 +258,6 @@ $Id$
...
@@ -258,7 +258,6 @@ $Id$
* puzzle: puzzle video filter
* puzzle: puzzle video filter
* pva: PVA demuxer
* pva: PVA demuxer
* pvr: input module to read from a PVR card
* pvr: input module to read from a PVR card
* qnx: QNX RTOS plugin
* qt4: interface module using the cross-platform Qt4 library
* qt4: interface module using the cross-platform Qt4 library
* qtcapture: Quicktime Capture
* qtcapture: Quicktime Capture
* quartztext: Text renderer using native Mac OS X API
* quartztext: Text renderer using native Mac OS X API
...
...
modules/gui/Modules.am
View file @
7c8b9f86
DIST_SUBDIRS = beos macosx hildon minimal_macosx q
nx q
t4 skins2 macosx_dialog_provider
DIST_SUBDIRS = beos macosx hildon minimal_macosx qt4 skins2 macosx_dialog_provider
SUBDIRS =
SUBDIRS =
if HAVE_BEOS
if HAVE_BEOS
...
@@ -10,7 +10,6 @@ endif
...
@@ -10,7 +10,6 @@ endif
if BUILD_HILDON
if BUILD_HILDON
SUBDIRS += hildon
SUBDIRS += hildon
endif
endif
SUBDIRS += qnx
if ENABLE_QT4
if ENABLE_QT4
SUBDIRS += qt4
SUBDIRS += qt4
endif
endif
...
...
modules/gui/qnx/Modules.am
deleted
100644 → 0
View file @
f5aed5af
SOURCES_qnx = \
qnx.c \
aout.c \
vout.c
modules/gui/qnx/aout.c
deleted
100644 → 0
View file @
f5aed5af
/*****************************************************************************
* aout.c : QNX audio output
*****************************************************************************
* Copyright (C) 2000, 2001 the VideoLAN team
*
* Authors: Henri Fallon <henri@videolan.org>
* Jon Lech Johansen <jon-vl@nanocrew.net>
* Pascal Levesque <pascal.levesque@mindready.com>
*
* This program 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.
*
* This program 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 this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
/*****************************************************************************
* Preamble
*****************************************************************************/
#include <errno.h>
/* ENOMEM */
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
#include <vlc_common.h>
#include <vlc_aout.h>
#include <sys/asoundlib.h>
struct
aout_sys_t
{
snd_pcm_t
*
p_pcm_handle
;
int
i_card
;
int
i_device
;
uint8_t
*
p_silent_buffer
;
};
#define DEFAULT_FRAME_SIZE 2048
/*****************************************************************************
* Local prototypes
*****************************************************************************/
int
OpenAudio
(
vlc_object_t
*
p_this
);
void
CloseAudio
(
vlc_object_t
*
p_this
);
static
int
GetBufInfo
(
aout_instance_t
*
);
static
void
Play
(
aout_instance_t
*
);
static
void
*
QNXaoutThread
(
vlc_object_t
*
);
/*****************************************************************************
* Open : creates a handle and opens an alsa device
*****************************************************************************
* This function opens an alsa device, through the alsa API
*****************************************************************************/
int
OpenAudio
(
vlc_object_t
*
p_this
)
{
aout_instance_t
*
p_aout
=
(
aout_instance_t
*
)
p_this
;
int
i_ret
;
int
i_bytes_per_sample
;
int
i_nb_channels
;
snd_pcm_channel_info_t
pi
;
snd_pcm_channel_params_t
pp
;
aout_instance_t
*
p_aout
=
(
aout_instance_t
*
)
p_this
;
/* allocate structure */
p_aout
->
output
.
p_sys
=
malloc
(
sizeof
(
aout_sys_t
)
);
if
(
p_aout
->
output
.
p_sys
==
NULL
)
return
-
1
;
/* open audio device */
if
(
(
i_ret
=
snd_pcm_open_preferred
(
&
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
&
p_aout
->
output
.
p_sys
->
i_card
,
&
p_aout
->
output
.
p_sys
->
i_device
,
SND_PCM_OPEN_PLAYBACK
)
)
<
0
)
{
msg_Err
(
p_aout
,
"unable to open audio device (%s)"
,
snd_strerror
(
i_ret
)
);
free
(
p_aout
->
output
.
p_sys
);
return
-
1
;
}
/* disable mmap */
if
(
(
i_ret
=
snd_pcm_plugin_set_disable
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
PLUGIN_DISABLE_MMAP
)
)
<
0
)
{
msg_Err
(
p_aout
,
"unable to disable mmap (%s)"
,
snd_strerror
(
i_ret
)
);
CloseAudio
(
p_this
);
free
(
p_aout
->
output
.
p_sys
);
return
-
1
;
}
p_aout
->
output
.
p_sys
->
p_silent_buffer
=
malloc
(
DEFAULT_FRAME_SIZE
*
4
);
p_aout
->
output
.
pf_play
=
Play
;
aout_VolumeSoftInit
(
p_aout
);
memset
(
&
pi
,
0
,
sizeof
(
pi
)
);
memset
(
&
pp
,
0
,
sizeof
(
pp
)
);
pi
.
channel
=
SND_PCM_CHANNEL_PLAYBACK
;
if
(
(
i_ret
=
snd_pcm_plugin_info
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
&
pi
)
)
<
0
)
{
msg_Err
(
p_aout
,
"unable to get plugin info (%s)"
,
snd_strerror
(
i_ret
)
);
CloseAudio
(
p_this
);
free
(
p_aout
->
output
.
p_sys
);
return
-
1
;
}
pp
.
mode
=
SND_PCM_MODE_BLOCK
;
pp
.
channel
=
SND_PCM_CHANNEL_PLAYBACK
;
pp
.
start_mode
=
SND_PCM_START_FULL
;
pp
.
stop_mode
=
SND_PCM_STOP_STOP
;
pp
.
buf
.
block
.
frags_max
=
3
;
pp
.
buf
.
block
.
frags_min
=
1
;
pp
.
format
.
interleave
=
1
;
pp
.
format
.
rate
=
p_aout
->
output
.
output
.
i_rate
;
i_nb_channels
=
aout_FormatNbChannels
(
&
p_aout
->
output
.
output
);
if
(
i_nb_channels
>
2
)
{
/* I don't know if QNX supports more than two channels. */
i_nb_channels
=
2
;
p_aout
->
output
.
output
.
i_channels
=
AOUT_CHAN_STEREO
;
}
pp
.
format
.
voices
=
i_nb_channels
;
p_aout
->
output
.
output
.
i_format
=
VLC_CODEC_S16N
;
p_aout
->
output
.
i_nb_samples
=
DEFAULT_FRAME_SIZE
;
pp
.
format
.
format
=
SND_PCM_SFMT_S16
;
i_bytes_per_sample
=
2
;
pp
.
buf
.
block
.
frag_size
=
p_aout
->
output
.
i_nb_samples
*
p_aout
->
output
.
output
.
i_channels
*
i_bytes_per_sample
;
/* set parameters */
if
(
(
i_ret
=
snd_pcm_plugin_params
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
&
pp
)
)
<
0
)
{
msg_Err
(
p_aout
,
"unable to set parameters (%s)"
,
snd_strerror
(
i_ret
)
);
CloseAudio
(
p_this
);
free
(
p_aout
->
output
.
p_sys
);
return
-
1
;
}
/* prepare channel */
if
(
(
i_ret
=
snd_pcm_plugin_prepare
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
SND_PCM_CHANNEL_PLAYBACK
)
)
<
0
)
{
msg_Err
(
p_aout
,
"unable to prepare channel (%s)"
,
snd_strerror
(
i_ret
)
);
CloseAudio
(
p_this
);
free
(
p_aout
->
output
.
p_sys
);
return
-
1
;
}
/* Create audio thread and wait for its readiness. */
if
(
vlc_thread_create
(
p_aout
,
"aout"
,
QNXaoutThread
,
VLC_THREAD_PRIORITY_OUTPUT
)
)
{
msg_Err
(
p_aout
,
"cannot create QNX audio thread (%m)"
);
CloseAudio
(
p_this
);
free
(
p_aout
->
output
.
p_sys
);
return
-
1
;
}
return
(
0
);
}
/*****************************************************************************
* GetBufInfo: buffer status query
*****************************************************************************
* This function returns the number of used byte in the queue.
* It also deals with errors : indeed if the device comes to run out
* of data to play, it switches to the "underrun" status. It has to
* be flushed and re-prepared
*****************************************************************************/
static
int
GetBufInfo
(
aout_instance_t
*
p_aout
)
{
int
i_ret
;
snd_pcm_channel_status_t
status
;
/* get current pcm status */
memset
(
&
status
,
0
,
sizeof
(
status
)
);
if
(
(
i_ret
=
snd_pcm_plugin_status
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
&
status
)
)
<
0
)
{
msg_Err
(
p_aout
,
"unable to get device status (%s)"
,
snd_strerror
(
i_ret
)
);
return
(
-
1
);
}
/* check for underrun */
switch
(
status
.
status
)
{
case
SND_PCM_STATUS_READY
:
case
SND_PCM_STATUS_UNDERRUN
:
if
(
(
i_ret
=
snd_pcm_plugin_prepare
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
SND_PCM_CHANNEL_PLAYBACK
)
)
<
0
)
{
msg_Err
(
p_aout
,
"unable to prepare channel (%s)"
,
snd_strerror
(
i_ret
)
);
}
break
;
}
return
(
status
.
count
);
}
/*****************************************************************************
* Play : plays a sample
*****************************************************************************
* Plays a sample using the snd_pcm_write function from the alsa API
*****************************************************************************/
static
void
Play
(
aout_instance_t
*
p_aout
)
{
}
/*****************************************************************************
* CloseAudio: close the audio device
*****************************************************************************/
void
CloseAudio
(
vlc_object_t
*
p_this
)
{
aout_instance_t
*
p_aout
=
(
aout_instance_t
*
)
p_this
;
int
i_ret
;
vlc_object_kill
(
p_aout
);
vlc_thread_join
(
p_aout
);
if
(
(
i_ret
=
snd_pcm_close
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
)
)
<
0
)
{
msg_Err
(
p_aout
,
"unable to close audio device (%s)"
,
snd_strerror
(
i_ret
)
);
}
free
(
p_aout
->
output
.
p_sys
->
p_silent_buffer
);
free
(
p_aout
->
output
.
p_sys
);
}
/*****************************************************************************
* QNXaoutThread: asynchronous thread used to DMA the data to the device
*****************************************************************************/
static
void
*
QNXaoutThread
(
vlc_object_t
*
p_this
)
{
aout_instance_t
*
p_aout
=
(
aout_instance_t
*
)
p_this
;
struct
aout_sys_t
*
p_sys
=
p_aout
->
output
.
p_sys
;
int
canc
=
vlc_savecancel
();
while
(
vlc_object_alive
(
p_aout
)
)
{
aout_buffer_t
*
p_buffer
;
int
i_tmp
,
i_size
;
uint8_t
*
p_bytes
;
if
(
p_aout
->
output
.
output
.
i_format
!=
VLC_CODEC_SPDIFL
)
{
mtime_t
next_date
=
0
;
/* Get the presentation date of the next write() operation. It
* is equal to the current date + duration of buffered samples.
* Order is important here, since GetBufInfo is believed to take
* more time than mdate(). */
next_date
=
(
mtime_t
)
GetBufInfo
(
p_aout
)
*
1000000
/
p_aout
->
output
.
output
.
i_bytes_per_frame
/
p_aout
->
output
.
output
.
i_rate
*
p_aout
->
output
.
output
.
i_frame_length
;
next_date
+=
mdate
();
p_buffer
=
aout_OutputNextBuffer
(
p_aout
,
next_date
,
false
);
}
else
{
p_buffer
=
aout_OutputNextBuffer
(
p_aout
,
0
,
true
);
}
if
(
p_buffer
!=
NULL
)
{
p_bytes
=
p_buffer
->
p_buffer
;
i_size
=
p_buffer
->
i_buffer
;
}
else
{
i_size
=
DEFAULT_FRAME_SIZE
/
p_aout
->
output
.
output
.
i_frame_length
*
p_aout
->
output
.
output
.
i_bytes_per_frame
;
p_bytes
=
p_aout
->
output
.
p_sys
->
p_silent_buffer
;
memset
(
p_bytes
,
0
,
i_size
);
}
i_tmp
=
snd_pcm_plugin_write
(
p_aout
->
output
.
p_sys
->
p_pcm_handle
,
(
void
*
)
p_bytes
,
(
size_t
)
i_size
);
if
(
i_tmp
<
0
)
{
msg_Err
(
p_aout
,
"write failed (%m)"
);
}
if
(
p_buffer
!=
NULL
)
{
aout_BufferFree
(
p_buffer
);
}
}
vlc_restorecancel
(
canc
);
return
NULL
;
}
modules/gui/qnx/qnx.c
deleted
100644 → 0
View file @
f5aed5af
/*****************************************************************************
* qnx.c : QNX RTOS plugin for vlc
*****************************************************************************
* Copyright (C) 2000, 2001 the VideoLAN team
*
* Authors: Jon Lech Johansen <jon-vl@nanocrew.net>
*
* This program 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.
*
* This program 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 this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
/*****************************************************************************
* Preamble
*****************************************************************************/
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
#include <vlc_common.h>
#include <vlc_plugin.h>
/*****************************************************************************
* External prototypes
******************************************************************************/
int
OpenAudio
(
vlc_object_t
*
);
void
CloseAudio
(
vlc_object_t
*
);
int
OpenVideo
(
vlc_object_t
*
);
void
CloseVideo
(
vlc_object_t
*
);
/*****************************************************************************
* Module descriptor
*****************************************************************************/
vlc_module_begin
()
set_description
(
N_
(
"QNX RTOS video and audio output"
)
)
set_capability
(
"video output"
,
100
)
set_callbacks
(
OpenVideo
,
CloseVideo
)
set_category
(
CAT_INTERFACE
)
set_subcategory
(
SUBCAT_INTERFACE_MAIN
)
add_submodule
()
set_capability
(
"audio output"
,
100
)
set_callbacks
(
OpenAudio
,
CloseAudio
)
vlc_module_end
()
modules/gui/qnx/vout.c
deleted
100644 → 0
View file @
f5aed5af
/*****************************************************************************
* vout.c: QNX RTOS video output display method
*****************************************************************************
* Copyright (C) 2001, 2002 the VideoLAN team
*
* Authors: Jon Lech Johansen <jon-vl@nanocrew.net>
* Pascal Levesque <Pascal.Levesque@mindready.com>
*
* This program 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.
*
* This program 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 this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
/*****************************************************************************
* Preamble
*****************************************************************************/
#include <errno.h>
/* ENOMEM */
#include <photon/PtWidget.h>
#include <photon/PtWindow.h>
#include <photon/PtLabel.h>
#include <photon/PdDirect.h>
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
#include <vlc_common.h>
#include <vlc_interface.h>
#include <vlc_vout.h>
#include <vlc_memory.h>
/*****************************************************************************
* vout_sys_t: video output QNX method descriptor
*****************************************************************************
* This structure is part of the video output thread descriptor.
* It describes the QNX specific properties of an output thread. QNX video
* output is performed through regular resizable windows. Windows can be
* dynamically resized to adapt to the size of the streams.
*****************************************************************************/
#define MAX_DIRECTBUFFERS 2
#define MODE_NORMAL_MEM 0
#define MODE_SHARED_MEM 1
#define MODE_VIDEO_MEM 2
#define MODE_VIDEO_OVERLAY 3
struct
vout_sys_t
{
/* video mode */
int
i_mode
;
/* internal stuff */
PtWidget_t
*
p_window
;
/* Color palette for 8bpp */
PgColor_t
p_colors
[
255
];
/* [shared] memory blit */
int
i_img_type
;
/* video memory blit */
/* video overlay */
PgVideoChannel_t
*
p_channel
;
int
i_vc_flags
;
int
i_vc_format
;
int
i_screen_depth
;
int
i_bytes_per_pixel
;
int
i_bytes_per_line
;
/* position & dimensions */
PhPoint_t
pos
;
PhDim_t
dim
;
PhPoint_t
old_pos
;
PhDim_t
old_dim
;
PhDim_t
screen_dim
;
PhRect_t
frame
;
};
/*****************************************************************************
* picture_sys_t: direct buffer method descriptor
*****************************************************************************
* This structure is part of the picture descriptor, it describes the
* XVideo specific properties of a direct buffer.
*****************************************************************************/
struct
picture_sys_t
{
/* [shared] memory blit */
PhImage_t
*
p_image
;
/* video memory blit and video overlay */
PdOffscreenContext_t
*
p_ctx
[
3
];
/* 0: y, 1: u, 2: v */
char
*
p_buf
[
3
];
};
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
int
QNXInit
(
vout_thread_t
*
);
static
void
QNXEnd
(
vout_thread_t
*
);
static
int
QNXManage
(
vout_thread_t
*
);
static
void
QNXDisplay
(
vout_thread_t
*
,
picture_t
*
);
static
int
QNXInitDisplay
(
vout_thread_t
*
);
static
int
QNXCreateWnd
(
vout_thread_t
*
);
static
int
QNXDestroyWnd
(
vout_thread_t
*
);
static
int
NewPicture
(
vout_thread_t
*
,
picture_t
*
,
int
);
static
void
FreePicture
(
vout_thread_t
*
,
picture_t
*
);
static
int
ResizeOverlayOutput
(
vout_thread_t
*
);
static
void
SetPalette
(
vout_thread_t
*
,
uint16_t
*
,
uint16_t
*
,
uint16_t
*
);
/*****************************************************************************
* OpenVideo: allocate QNX video thread output method
*****************************************************************************
* This function allocate and initialize a QNX vout method. It uses some of the
* vout properties to choose the window size, and change them according to the
* actual properties of the display.
*****************************************************************************/
int
OpenVideo
(
vlc_object_t
*
p_this
)
{
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
/* init connection to photon */
if
(
PtInit
(
"/dev/photon"
)
!=
0
)
{
msg_Err
(
p_vout
,
"unable to connect to photon"
);
return
(
1
);
}
/* allocate structure */
p_vout
->
p_sys
=
malloc
(
sizeof
(
vout_sys_t
)
);
if
(
p_vout
->
p_sys
==
NULL
)
return
(
1
);
memset
(
p_vout
->
p_sys
,
0
,
sizeof
(
vout_sys_t
)
);
p_vout
->
b_fullscreen
=
config_GetInt
(
p_vout
,
"fullscreen"
);
p_vout
->
p_sys
->
i_mode
=
config_GetInt
(
p_vout
,
"overlay"
)
?
MODE_VIDEO_OVERLAY
:
MODE_VIDEO_MEM
;
p_vout
->
p_sys
->
dim
.
w
=
p_vout
->
i_window_width
;
p_vout
->
p_sys
->
dim
.
h
=
p_vout
->
i_window_height
;
/* init display and create window */
if
(
QNXInitDisplay
(
p_vout
)
||
QNXCreateWnd
(
p_vout
)
)
{
free
(
p_vout
->
p_sys
);
return
(
1
);
}
p_vout
->
pf_init
=
QNXInit
;
p_vout
->
pf_end
=
QNXEnd
;
p_vout
->
pf_manage
=
QNXManage
;
p_vout
->
pf_render
=
NULL
;
p_vout
->
pf_display
=
QNXDisplay
;
return
(
0
);
}
/*****************************************************************************
* QNXInit: initialize QNX video thread output method
*****************************************************************************
* This function create the buffers needed by the output thread. It is called
* at the beginning of the thread, but also each time the window is resized.
*****************************************************************************/
static
int
QNXInit
(
vout_thread_t
*
p_vout
)
{
int
i_index
;
picture_t
*
p_pic
;
I_OUTPUTPICTURES
=
0
;
switch
(
p_vout
->
p_sys
->
i_mode
)
{
case
MODE_NORMAL_MEM
:
case
MODE_SHARED_MEM
:
p_vout
->
output
.
i_width
=
p_vout
->
p_sys
->
dim
.
w
;
p_vout
->
output
.
i_height
=
p_vout
->
p_sys
->
dim
.
h
;
/* Assume we have square pixels */
p_vout
->
output
.
i_aspect
=
p_vout
->
p_sys
->
dim
.
w
*
VOUT_ASPECT_FACTOR
/
p_vout
->
p_sys
->
dim
.
h
;
break
;
case
MODE_VIDEO_MEM
:
p_vout
->
output
.
i_width
=
p_vout
->
p_sys
->
dim
.
w
;
p_vout
->
output
.
i_height
=
p_vout
->
p_sys
->
dim
.
h
;
/* Assume we have square pixels */
p_vout
->
output
.
i_aspect
=
p_vout
->
p_sys
->
dim
.
w
*
VOUT_ASPECT_FACTOR
/
p_vout
->
p_sys
->
dim
.
h
;
break
;
case
MODE_VIDEO_OVERLAY
:
p_vout
->
output
.
i_width
=
p_vout
->
render
.
i_width
;
p_vout
->
output
.
i_height
=
p_vout
->
render
.
i_height
;
p_vout
->
output
.
i_aspect
=
p_vout
->
render
.
i_aspect
;
if
(
ResizeOverlayOutput
(
p_vout
))
{
return
(
1
);
}
break
;
default:
/* This shouldn't happen ! */
break
;
}
/* Try to initialize up to MAX_DIRECTBUFFERS direct buffers */
while
(
I_OUTPUTPICTURES
<
MAX_DIRECTBUFFERS
)
{
p_pic
=
NULL
;
/* Find an empty picture slot */
for
(
i_index
=
0
;
i_index
<
VOUT_MAX_PICTURES
;
i_index
++
)
{
if
(
p_vout
->
p_picture
[
i_index
].
i_status
==
FREE_PICTURE
)
{
p_pic
=
p_vout
->
p_picture
+
i_index
;
break
;
}
}
/* Allocate the picture */
if
(
p_pic
==
NULL
||
NewPicture
(
p_vout
,
p_pic
,
I_OUTPUTPICTURES
)
)
{
break
;
}
p_pic
->
i_status
=
DESTROYED_PICTURE
;
p_pic
->
i_type
=
DIRECT_PICTURE
;
PP_OUTPUTPICTURE
[
I_OUTPUTPICTURES
]
=
p_pic
;
I_OUTPUTPICTURES
++
;
}
return
(
0
);
}
/*****************************************************************************
* QNXEnd: terminate QNX video thread output method
*****************************************************************************
* Destroy the buffers created by QNXInit. It is called at the end of
* the thread, but also each time the window is resized.
*****************************************************************************/
static
void
QNXEnd
(
vout_thread_t
*
p_vout
)
{
int
i_index
;
/* Free the direct buffers we allocated */
for
(
i_index
=
I_OUTPUTPICTURES
;
i_index
;
)
{
i_index
--
;
FreePicture
(
p_vout
,
PP_OUTPUTPICTURE
[
i_index
]
);
}
}
/*****************************************************************************
* CloseVideo: destroy QNX video thread output method
*****************************************************************************
* Terminate an output method created by QNXCreate
*****************************************************************************/
void
CloseVideo
(
vlc_object_t
*
p_this
)
{
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
/* destroy the window */
QNXDestroyWnd
(
p_vout
);
/* destroy structure */
free
(
p_vout
->
p_sys
);
}
/*****************************************************************************
* QNXManage: handle QNX events
*****************************************************************************
* This function should be called regularly by video output thread. It allows
* window resizing. It returns a non null value on error.
*****************************************************************************/
static
int
QNXManage
(
vout_thread_t
*
p_vout
)
{
int
i_ev
,
i_buflen
;
PhEvent_t
*
p_event
;
bool
b_repos
=
0
;
if
(
!
vlc_object_alive
(
p_vout
))
{
return
(
0
);
}
/* allocate buffer for event */
i_buflen
=
sizeof
(
PhEvent_t
)
*
4
;
if
(
(
p_event
=
malloc
(
i_buflen
)
)
==
NULL
)
return
(
1
);
/* event loop */
do
{
memset
(
p_event
,
0
,
i_buflen
);
i_ev
=
PhEventPeek
(
p_event
,
i_buflen
);
if
(
i_ev
==
Ph_RESIZE_MSG
)
{
i_buflen
=
PhGetMsgSize
(
p_event
);
p_event
=
realloc_or_free
(
p_event
,
i_buflen
);
if
(
p_event
==
NULL
)
return
(
1
);
}
else
if
(
i_ev
==
Ph_EVENT_MSG
)
{
PtEventHandler
(
p_event
);
if
(
p_event
->
type
==
Ph_EV_WM
)
{
PhWindowEvent_t
*
p_ev
=
PhGetData
(
p_event
);
switch
(
p_ev
->
event_f
)
{
case
Ph_WM_CLOSE
:
p_vout
->
p_libvlc
->
b_die
=
true
;
break
;
case
Ph_WM_MOVE
:
p_vout
->
p_sys
->
pos
.
x
=
p_ev
->
pos
.
x
;
p_vout
->
p_sys
->
pos
.
y
=
p_ev
->
pos
.
y
;
b_repos
=
1
;
break
;
case
Ph_WM_RESIZE
:
p_vout
->
p_sys
->
old_dim
.
w
=
p_vout
->
p_sys
->
dim
.
w
;
p_vout
->
p_sys
->
old_dim
.
h
=
p_vout
->
p_sys
->
dim
.
h
;
p_vout
->
p_sys
->
dim
.
w
=
p_ev
->
size
.
w
;
p_vout
->
p_sys
->
dim
.
h
=
p_ev
->
size
.
h
;
p_vout
->
i_changes
|=
VOUT_SIZE_CHANGE
;
break
;
}
}
else
if
(
p_event
->
type
==
Ph_EV_KEY
)
{
PhKeyEvent_t
*
p_ev
=
PhGetData
(
p_event
);
long
i_key
=
p_ev
->
key_sym
;
if
(
(
p_ev
->
key_flags
&
Pk_KF_Key_Down
)
&&
(
p_ev
->
key_flags
&
Pk_KF_Sym_Valid
)
)
{
switch
(
i_key
)
{
case
Pk_q
:
case
Pk_Q
:
p_vout
->
p_libvlc
->
b_die
=
true
;
break
;
case
Pk_f
:
case
Pk_F
:
p_vout
->
i_changes
|=
VOUT_FULLSCREEN_CHANGE
;
break
;
default:
break
;
}
}
}
}
}
while
(
i_ev
!=
-
1
&&
i_ev
!=
0
);
free
(
p_event
);
/*
* fullscreen
*/
if
(
p_vout
->
i_changes
&
VOUT_FULLSCREEN_CHANGE
)
{
PhDim_t
dim
;
p_vout
->
b_fullscreen
=
!
p_vout
->
b_fullscreen
;
p_vout
->
i_changes
&=
~
VOUT_FULLSCREEN_CHANGE
;
if
(
p_vout
->
b_fullscreen
)
{
p_vout
->
p_sys
->
old_pos
.
x
=
p_vout
->
p_sys
->
pos
.
x
;
p_vout
->
p_sys
->
old_pos
.
y
=
p_vout
->
p_sys
->
pos
.
y
;
p_vout
->
p_sys
->
pos
.
x
=
p_vout
->
p_sys
->
pos
.
y
=
0
;
dim
.
w
=
p_vout
->
p_sys
->
screen_dim
.
w
+
1
;
dim
.
h
=
p_vout
->
p_sys
->
screen_dim
.
h
+
1
;
}
else
{
p_vout
->
p_sys
->
pos
.
x
=
p_vout
->
p_sys
->
old_pos
.
x
;
p_vout
->
p_sys
->
pos
.
y
=
p_vout
->
p_sys
->
old_pos
.
y
;
dim
.
w
=
p_vout
->
p_sys
->
old_dim
.
w
+
1
;
dim
.
h
=
p_vout
->
p_sys
->
old_dim
.
h
+
1
;
}
/* modify render flags, border */
PtSetResource
(
p_vout
->
p_sys
->
p_window
,
Pt_ARG_WINDOW_RENDER_FLAGS
,
p_vout
->
b_fullscreen
?
Pt_FALSE
:
Pt_TRUE
,
Ph_WM_RENDER_BORDER
|
Ph_WM_RENDER_TITLE
);
/* set position and dimension */
PtSetResource
(
p_vout
->
p_sys
->
p_window
,
Pt_ARG_POS
,
&
p_vout
->
p_sys
->
pos
,
0
);
PtSetResource
(
p_vout
->
p_sys
->
p_window
,
Pt_ARG_DIM
,
&
dim
,
0
);
/* mark as damaged to force redraw */
PtDamageWidget
(
p_vout
->
p_sys
->
p_window
);
}
/*
* size change
*/
if
(
p_vout
->
i_changes
&
VOUT_SIZE_CHANGE
)
{
p_vout
->
i_changes
&=
~
VOUT_SIZE_CHANGE
;
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_OVERLAY
)
{
ResizeOverlayOutput
(
p_vout
);
}
#if 0
else
{
p_vout->output.i_width = p_vout->p_sys->dim.w;
p_vout->output.i_height = p_vout->p_sys->dim.h;
p_vout->i_changes |= VOUT_YUV_CHANGE;
QNXEnd( p_vout );
if( QNXInit( p_vout ) )
{
msg_Err( p_vout, "cannot resize display" );
return( 1 );
}
}
#endif
msg_Dbg
(
p_vout
,
"video display resized (%dx%d)"
,
p_vout
->
p_sys
->
dim
.
w
,
p_vout
->
p_sys
->
dim
.
h
);
}
/*
* position change, move video channel
*/
if
(
b_repos
&&
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_OVERLAY
)
{
ResizeOverlayOutput
(
p_vout
);
}
return
(
i_ev
==
-
1
);
}
/*****************************************************************************
* QNXDisplay: displays previously rendered output
*****************************************************************************
* This function send the currently rendered image to QNX server, wait until
* it is displayed and switch the two rendering buffer, preparing next frame.
*****************************************************************************/
static
void
QNXDisplay
(
vout_thread_t
*
p_vout
,
picture_t
*
p_pic
)
{
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_NORMAL_MEM
||
p_vout
->
p_sys
->
i_mode
==
MODE_SHARED_MEM
)
{
PhPoint_t
pos
=
{
0
,
0
};
PgSetRegion
(
PtWidgetRid
(
p_vout
->
p_sys
->
p_window
)
);
if
(
p_vout
->
p_sys
->
i_screen_depth
==
8
)
{
PgSetPalette
(
p_vout
->
p_sys
->
p_colors
,
0
,
0
,
255
,
Pg_PALSET_SOFT
,
0
);
}
PgDrawPhImagemx
(
&
pos
,
p_pic
->
p_sys
->
p_image
,
0
);
PgFlush
();
}
else
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_MEM
)
{
PhRect_t
rc
=
{
{
0
,
0
},
{
p_vout
->
output
.
i_width
,
p_vout
->
output
.
i_height
}
};
// PgSetRegion( PtWidgetRid ( p_vout->p_sys->p_window ) );
PgContextBlit
(
p_pic
->
p_sys
->
p_ctx
[
0
],
&
rc
,
NULL
,
&
rc
);
PgFlush
();
}
}
/*****************************************************************************
* QNXInitDisplay: check screen resolution, depth, amount of video ram, etc
*****************************************************************************/
static
int
QNXInitDisplay
(
vout_thread_t
*
p_vout
)
{
PgHWCaps_t
hwcaps
;
PgDisplaySettings_t
cfg
;
PgVideoModeInfo_t
minfo
;
/* get graphics card hw capabilities */
if
(
PgGetGraphicsHWCaps
(
&
hwcaps
)
!=
0
)
{
msg_Err
(
p_vout
,
"unable to get gfx card capabilities"
);
return
(
1
);
}
/* get current video mode */
if
(
PgGetVideoMode
(
&
cfg
)
!=
0
)
{
msg_Err
(
p_vout
,
"unable to get current video mode"
);
return
(
1
);
}
/* get video mode info */
if
(
PgGetVideoModeInfo
(
cfg
.
mode
,
&
minfo
)
!=
0
)
{
msg_Err
(
p_vout
,
"unable to get info for video mode"
);
return
(
1
);
}
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_OVERLAY
)
{
int
i
=
0
;
PgScalerCaps_t
vcaps
;
if
(
(
p_vout
->
p_sys
->
p_channel
=
PgCreateVideoChannel
(
Pg_VIDEO_CHANNEL_SCALER
,
0
)
)
==
NULL
)
{
msg_Err
(
p_vout
,
"unable to create video channel"
);
printf
(
"errno = %d
\n
"
,
errno
);
p_vout
->
p_sys
->
i_mode
=
MODE_NORMAL_MEM
;
}
else
{
vcaps
.
size
=
sizeof
(
vcaps
);
while
(
PgGetScalerCapabilities
(
p_vout
->
p_sys
->
p_channel
,
i
++
,
&
vcaps
)
==
0
)
{
printf
(
"vcaps.format = 0x%x
\n
"
,
vcaps
.
format
);
if
(
vcaps
.
format
==
Pg_VIDEO_FORMAT_YV12
||
vcaps
.
format
==
Pg_VIDEO_FORMAT_YUV420
||
vcaps
.
format
==
Pg_VIDEO_FORMAT_YUY2
||
vcaps
.
format
==
Pg_VIDEO_FORMAT_UYVY
||
vcaps
.
format
==
Pg_VIDEO_FORMAT_RGB555
||
vcaps
.
format
==
Pg_VIDEO_FORMAT_RGB565
||
vcaps
.
format
==
Pg_VIDEO_FORMAT_RGB8888
)
{
p_vout
->
p_sys
->
i_vc_flags
=
vcaps
.
flags
;
p_vout
->
p_sys
->
i_vc_format
=
vcaps
.
format
;
}
vcaps
.
size
=
sizeof
(
vcaps
);
}
if
(
p_vout
->
p_sys
->
i_vc_format
==
0
)
{
msg_Warn
(
p_vout
,
"need YV12, YUY2 or RGB8888 overlay"
);
p_vout
->
p_sys
->
i_mode
=
MODE_NORMAL_MEM
;
}
}
}
/* use video ram if we have enough available */
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_NORMAL_MEM
&&
(
minfo
.
bits_per_pixel
!=
8
)
&&
hwcaps
.
currently_available_video_ram
>=
(
(
minfo
.
width
*
minfo
.
height
*
minfo
.
bits_per_pixel
*
MAX_DIRECTBUFFERS
)
/
8
)
)
{
p_vout
->
p_sys
->
i_mode
=
MODE_VIDEO_MEM
;
printf
(
"Using video memory...
\n
"
);
}
p_vout
->
p_sys
->
i_img_type
=
minfo
.
type
;
p_vout
->
p_sys
->
screen_dim
.
w
=
minfo
.
width
;
p_vout
->
p_sys
->
screen_dim
.
h
=
minfo
.
height
;
p_vout
->
p_sys
->
i_screen_depth
=
minfo
.
bits_per_pixel
;
switch
(
p_vout
->
p_sys
->
i_screen_depth
)
{
case
8
:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_RGB8
;
p_vout
->
p_sys
->
i_bytes_per_pixel
=
1
;
p_vout
->
output
.
pf_setpalette
=
SetPalette
;
break
;
case
15
:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_RGB15
;
p_vout
->
p_sys
->
i_bytes_per_pixel
=
2
;
p_vout
->
output
.
i_rmask
=
0x7c00
;
p_vout
->
output
.
i_gmask
=
0x03e0
;
p_vout
->
output
.
i_bmask
=
0x001f
;
break
;
case
16
:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_RGB16
;
p_vout
->
p_sys
->
i_bytes_per_pixel
=
2
;
p_vout
->
output
.
i_rmask
=
0xf800
;
p_vout
->
output
.
i_gmask
=
0x07e0
;
p_vout
->
output
.
i_bmask
=
0x001f
;
break
;
case
24
:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_RGB24
;
p_vout
->
p_sys
->
i_bytes_per_pixel
=
3
;
p_vout
->
output
.
i_rmask
=
0xff0000
;
p_vout
->
output
.
i_gmask
=
0x00ff00
;
p_vout
->
output
.
i_bmask
=
0x0000ff
;
break
;
case
32
:
default:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_RGB32
;
p_vout
->
p_sys
->
i_bytes_per_pixel
=
4
;
p_vout
->
output
.
i_rmask
=
0xff0000
;
p_vout
->
output
.
i_gmask
=
0x00ff00
;
p_vout
->
output
.
i_bmask
=
0x0000ff
;
break
;
}
return
(
0
);
}
/*****************************************************************************
* QNXCreateWnd: create and realize the main window
*****************************************************************************/
static
int
QNXCreateWnd
(
vout_thread_t
*
p_vout
)
{
PtArg_t
args
[
8
];
PhPoint_t
pos
=
{
0
,
0
};
PgColor_t
color
=
Pg_BLACK
;
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_OVERLAY
)
{
if
(
p_vout
->
p_sys
->
i_vc_flags
&
Pg_SCALER_CAP_DST_CHROMA_KEY
)
{
color
=
PgGetOverlayChromaColor
();
}
}
/* fullscreen, set dimension */
if
(
p_vout
->
b_fullscreen
)
{
p_vout
->
p_sys
->
old_dim
.
w
=
p_vout
->
p_sys
->
dim
.
w
;
p_vout
->
p_sys
->
old_dim
.
h
=
p_vout
->
p_sys
->
dim
.
h
;
p_vout
->
output
.
i_width
=
p_vout
->
p_sys
->
dim
.
w
=
p_vout
->
p_sys
->
screen_dim
.
w
;
p_vout
->
output
.
i_height
=
p_vout
->
p_sys
->
dim
.
h
=
p_vout
->
p_sys
->
screen_dim
.
h
;
}
/* set window parameters */
PtSetArg
(
&
args
[
0
],
Pt_ARG_POS
,
&
pos
,
0
);
PtSetArg
(
&
args
[
1
],
Pt_ARG_DIM
,
&
p_vout
->
p_sys
->
dim
,
0
);
PtSetArg
(
&
args
[
2
],
Pt_ARG_FILL_COLOR
,
color
,
0
);
PtSetArg
(
&
args
[
3
],
Pt_ARG_WINDOW_TITLE
,
"VLC media player"
,
0
);
PtSetArg
(
&
args
[
4
],
Pt_ARG_WINDOW_MANAGED_FLAGS
,
Pt_FALSE
,
Ph_WM_CLOSE
);
PtSetArg
(
&
args
[
5
],
Pt_ARG_WINDOW_NOTIFY_FLAGS
,
Pt_TRUE
,
Ph_WM_MOVE
|
Ph_WM_RESIZE
|
Ph_WM_CLOSE
);
PtSetArg
(
&
args
[
6
],
Pt_ARG_WINDOW_RENDER_FLAGS
,
p_vout
->
b_fullscreen
?
Pt_FALSE
:
Pt_TRUE
,
Ph_WM_RENDER_BORDER
|
Ph_WM_RENDER_TITLE
);
/* create window */
p_vout
->
p_sys
->
p_window
=
PtCreateWidget
(
PtWindow
,
Pt_NO_PARENT
,
7
,
args
);
if
(
p_vout
->
p_sys
->
p_window
==
NULL
)
{
msg_Err
(
p_vout
,
"unable to create window"
);
return
(
1
);
}
/* realize the window widget */
if
(
PtRealizeWidget
(
p_vout
->
p_sys
->
p_window
)
!=
0
)
{
msg_Err
(
p_vout
,
"unable to realize window widget"
);
PtDestroyWidget
(
p_vout
->
p_sys
->
p_window
);
return
(
1
);
}
/* get window frame size */
if
(
PtWindowFrameSize
(
NULL
,
p_vout
->
p_sys
->
p_window
,
&
p_vout
->
p_sys
->
frame
)
!=
0
)
{
msg_Err
(
p_vout
,
"unable to get window frame size"
);
PtDestroyWidget
(
p_vout
->
p_sys
->
p_window
);
return
(
1
);
}
return
(
0
);
}
/*****************************************************************************
* QNXDestroyWnd: unrealize and destroy the main window
*****************************************************************************/
static
int
QNXDestroyWnd
(
vout_thread_t
*
p_vout
)
{
/* destroy the window widget */
PtUnrealizeWidget
(
p_vout
->
p_sys
->
p_window
);
// PtDestroyWidget( p_vout->p_sys->p_window );
/* destroy video channel */
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_OVERLAY
)
{
PgDestroyVideoChannel
(
p_vout
->
p_sys
->
p_channel
);
}
return
(
0
);
}
/*****************************************************************************
* NewPicture: allocate a picture
*****************************************************************************
* Returns 0 on success, -1 otherwise
*****************************************************************************/
static
int
NewPicture
(
vout_thread_t
*
p_vout
,
picture_t
*
p_pic
,
int
index
)
{
/* We know the chroma, allocate a buffer which will be used
* directly by the decoder */
p_pic
->
p_sys
=
malloc
(
sizeof
(
picture_sys_t
)
);
if
(
p_pic
->
p_sys
==
NULL
)
{
return
-
1
;
}
switch
(
p_vout
->
p_sys
->
i_mode
)
{
case
MODE_NORMAL_MEM
:
case
MODE_SHARED_MEM
:
/* create images for [shared] memory blit */
if
(
!
(
p_pic
->
p_sys
->
p_image
=
PhCreateImage
(
NULL
,
p_vout
->
p_sys
->
dim
.
w
,
p_vout
->
p_sys
->
dim
.
h
,
p_vout
->
p_sys
->
i_img_type
,
NULL
,
0
,
p_vout
->
p_sys
->
i_mode
==
MODE_SHARED_MEM
)
)
)
{
msg_Err
(
p_vout
,
"cannot create image"
);
free
(
p_pic
->
p_sys
);
return
(
-
1
);
}
p_pic
->
p
->
p_pixels
=
p_pic
->
p_sys
->
p_image
->
image
;
p_pic
->
p
->
i_lines
=
p_pic
->
p_sys
->
p_image
->
size
.
h
;
p_pic
->
p
->
i_visible_lines
=
p_pic
->
p_sys
->
p_image
->
size
.
h
;
p_pic
->
p
->
i_pitch
=
p_pic
->
p_sys
->
p_image
->
bpl
;
p_pic
->
p
->
i_pixel_pitch
=
p_vout
->
p_sys
->
i_bytes_per_pixel
;
p_pic
->
p
->
i_visible_pitch
=
p_vout
->
p_sys
->
i_bytes_per_pixel
*
p_pic
->
p_sys
->
p_image
->
size
.
w
;
p_pic
->
i_planes
=
1
;
break
;
case
MODE_VIDEO_MEM
:
/* create offscreen contexts for video memory blit */
if
(
(
p_pic
->
p_sys
->
p_ctx
[
0
]
=
PdCreateOffscreenContext
(
0
,
p_vout
->
p_sys
->
dim
.
w
,
p_vout
->
p_sys
->
dim
.
h
,
Pg_OSC_MEM_PAGE_ALIGN
)
)
==
NULL
)
{
msg_Err
(
p_vout
,
"unable to create offscreen context"
);
free
(
p_pic
->
p_sys
);
return
(
-
1
);
}
/* get context pointers */
if
(
(
p_pic
->
p_sys
->
p_buf
[
0
]
=
PdGetOffscreenContextPtr
(
p_pic
->
p_sys
->
p_ctx
[
0
]
)
)
==
NULL
)
{
msg_Err
(
p_vout
,
"unable to get offscreen context ptr"
);
PhDCRelease
(
p_pic
->
p_sys
->
p_ctx
[
0
]
);
p_pic
->
p_sys
->
p_ctx
[
0
]
=
NULL
;
free
(
p_pic
->
p_sys
);
return
(
-
1
);
}
p_vout
->
p_sys
->
i_bytes_per_line
=
p_pic
->
p_sys
->
p_ctx
[
0
]
->
pitch
;
memset
(
p_pic
->
p_sys
->
p_buf
[
0
],
0
,
p_vout
->
p_sys
->
i_bytes_per_line
*
p_vout
->
p_sys
->
dim
.
h
);
p_pic
->
p
->
p_pixels
=
p_pic
->
p_sys
->
p_buf
[
0
];
p_pic
->
p
->
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
0
]
->
dim
.
h
;
p_pic
->
p
->
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
0
]
->
dim
.
h
;
p_pic
->
p
->
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
0
]
->
pitch
;
p_pic
->
p
->
i_pixel_pitch
=
p_vout
->
p_sys
->
i_bytes_per_pixel
;
p_pic
->
p
->
i_visible_pitch
=
p_vout
->
p_sys
->
i_bytes_per_pixel
*
p_pic
->
p_sys
->
p_ctx
[
0
]
->
dim
.
w
;
p_pic
->
i_planes
=
1
;
break
;
case
MODE_VIDEO_OVERLAY
:
if
(
index
==
0
)
{
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
=
p_vout
->
p_sys
->
p_channel
->
yplane1
;
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
=
p_vout
->
p_sys
->
p_channel
->
uplane1
;
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
=
p_vout
->
p_sys
->
p_channel
->
vplane1
;
}
else
{
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
=
p_vout
->
p_sys
->
p_channel
->
yplane2
;
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
=
p_vout
->
p_sys
->
p_channel
->
uplane2
;
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
=
p_vout
->
p_sys
->
p_channel
->
vplane2
;
}
p_pic
->
p_sys
->
p_buf
[
Y_PLANE
]
=
PdGetOffscreenContextPtr
(
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
);
if
(
p_pic
->
p_sys
->
p_buf
[
Y_PLANE
]
==
NULL
)
{
msg_Err
(
p_vout
,
"unable to get video channel ctx ptr"
);
return
(
1
);
}
switch
(
p_vout
->
p_sys
->
i_vc_format
)
{
case
Pg_VIDEO_FORMAT_YUV420
:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_I420
;
p_pic
->
p_sys
->
p_buf
[
U_PLANE
]
=
PdGetOffscreenContextPtr
(
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
);
p_pic
->
p_sys
->
p_buf
[
V_PLANE
]
=
PdGetOffscreenContextPtr
(
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
);
if
(
p_pic
->
p_sys
->
p_buf
[
U_PLANE
]
==
NULL
||
p_pic
->
p_sys
->
p_buf
[
V_PLANE
]
==
NULL
)
{
msg_Err
(
p_vout
,
"unable to get video channel ctx ptr"
);
return
(
1
);
}
p_pic
->
Y_PIXELS
=
p_pic
->
p_sys
->
p_buf
[
Y_PLANE
];
p_pic
->
p
[
Y_PLANE
].
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
Y_PLANE
].
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
Y_PLANE
].
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
pitch
;
p_pic
->
p
[
Y_PLANE
].
i_pixel_pitch
=
1
;
p_pic
->
p
[
Y_PLANE
].
i_visible_pitch
=
p_pic
->
p
[
Y_PLANE
].
i_pitch
;
p_pic
->
U_PIXELS
=
p_pic
->
p_sys
->
p_buf
[
U_PLANE
];
p_pic
->
p
[
U_PLANE
].
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
U_PLANE
].
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
U_PLANE
].
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
->
pitch
;
p_pic
->
p
[
U_PLANE
].
i_pixel_pitch
=
1
;
p_pic
->
p
[
U_PLANE
].
i_visible_pitch
=
p_pic
->
p
[
U_PLANE
].
i_pitch
;
p_pic
->
V_PIXELS
=
p_pic
->
p_sys
->
p_buf
[
V_PLANE
];
p_pic
->
p
[
V_PLANE
].
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
V_PLANE
].
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
V_PLANE
].
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
->
pitch
;
p_pic
->
p
[
V_PLANE
].
i_pixel_pitch
=
1
;
p_pic
->
p
[
V_PLANE
].
i_visible_pitch
=
p_pic
->
p
[
V_PLANE
].
i_pitch
;
p_pic
->
i_planes
=
3
;
break
;
case
Pg_VIDEO_FORMAT_YV12
:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_YV12
;
p_pic
->
p_sys
->
p_buf
[
U_PLANE
]
=
PdGetOffscreenContextPtr
(
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
);
p_pic
->
p_sys
->
p_buf
[
V_PLANE
]
=
PdGetOffscreenContextPtr
(
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
);
if
(
p_pic
->
p_sys
->
p_buf
[
U_PLANE
]
==
NULL
||
p_pic
->
p_sys
->
p_buf
[
V_PLANE
]
==
NULL
)
{
msg_Err
(
p_vout
,
"unable to get video channel ctx ptr"
);
return
(
1
);
}
p_pic
->
Y_PIXELS
=
p_pic
->
p_sys
->
p_buf
[
Y_PLANE
];
p_pic
->
p
[
Y_PLANE
].
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
Y_PLANE
].
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
Y_PLANE
].
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
pitch
;
p_pic
->
p
[
Y_PLANE
].
i_pixel_pitch
=
1
;
p_pic
->
p
[
Y_PLANE
].
i_visible_pitch
=
p_pic
->
p
[
Y_PLANE
].
i_pitch
;
p_pic
->
U_PIXELS
=
p_pic
->
p_sys
->
p_buf
[
U_PLANE
];
p_pic
->
p
[
U_PLANE
].
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
U_PLANE
].
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
U_PLANE
].
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
U_PLANE
]
->
pitch
;
p_pic
->
p
[
U_PLANE
].
i_pixel_pitch
=
1
;
p_pic
->
p
[
U_PLANE
].
i_visible_pitch
=
p_pic
->
p
[
U_PLANE
].
i_pitch
;
p_pic
->
V_PIXELS
=
p_pic
->
p_sys
->
p_buf
[
V_PLANE
];
p_pic
->
p
[
V_PLANE
].
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
V_PLANE
].
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
->
dim
.
h
;
p_pic
->
p
[
V_PLANE
].
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
V_PLANE
]
->
pitch
;
p_pic
->
p
[
V_PLANE
].
i_pixel_pitch
=
1
;
p_pic
->
p
[
V_PLANE
].
i_visible_pitch
=
p_pic
->
p
[
V_PLANE
].
i_pitch
;
p_pic
->
i_planes
=
3
;
break
;
case
Pg_VIDEO_FORMAT_UYVY
:
case
Pg_VIDEO_FORMAT_YUY2
:
if
(
p_vout
->
p_sys
->
i_vc_format
==
Pg_VIDEO_FORMAT_UYVY
)
{
p_vout
->
output
.
i_chroma
=
VLC_CODEC_UYVY
;
}
else
{
p_vout
->
output
.
i_chroma
=
VLC_CODEC_YUYV
;
}
p_pic
->
p
->
p_pixels
=
p_pic
->
p_sys
->
p_buf
[
Y_PLANE
];
p_pic
->
p
->
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
->
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
->
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
pitch
;
p_pic
->
p
->
i_pixel_pitch
=
4
;
p_pic
->
p
->
i_visible_pitch
=
p_pic
->
p
->
i_pitch
;
p_pic
->
i_planes
=
1
;
break
;
case
Pg_VIDEO_FORMAT_RGB555
:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_RGB15
;
p_vout
->
output
.
i_rmask
=
0x001f
;
p_vout
->
output
.
i_gmask
=
0x03e0
;
p_vout
->
output
.
i_bmask
=
0x7c00
;
p_pic
->
p
->
p_pixels
=
p_pic
->
p_sys
->
p_buf
[
Y_PLANE
];
p_pic
->
p
->
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
->
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
->
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
pitch
;
p_pic
->
p
->
i_pixel_pitch
=
2
;
p_pic
->
p
->
i_visible_pitch
=
2
*
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
w
;
p_pic
->
i_planes
=
1
;
break
;
case
Pg_VIDEO_FORMAT_RGB565
:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_RGB16
;
p_vout
->
output
.
i_rmask
=
0x001f
;
p_vout
->
output
.
i_gmask
=
0x07e0
;
p_vout
->
output
.
i_bmask
=
0xf800
;
p_pic
->
p
->
p_pixels
=
p_pic
->
p_sys
->
p_buf
[
Y_PLANE
];
p_pic
->
p
->
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
->
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
->
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
pitch
;
p_pic
->
p
->
i_pixel_pitch
=
4
;
p_pic
->
p
->
i_visible_pitch
=
4
*
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
w
;
p_pic
->
i_planes
=
1
;
break
;
case
Pg_VIDEO_FORMAT_RGB8888
:
p_vout
->
output
.
i_chroma
=
VLC_CODEC_RGB32
;
p_vout
->
output
.
i_rmask
=
0x000000ff
;
p_vout
->
output
.
i_gmask
=
0x0000ff00
;
p_vout
->
output
.
i_bmask
=
0x00ff0000
;
p_pic
->
p
->
p_pixels
=
p_pic
->
p_sys
->
p_buf
[
Y_PLANE
];
p_pic
->
p
->
i_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
->
i_visible_lines
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
h
;
p_pic
->
p
->
i_pitch
=
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
pitch
;
p_pic
->
p
->
i_pixel_pitch
=
4
;
p_pic
->
p
->
i_visible_pitch
=
4
*
p_pic
->
p_sys
->
p_ctx
[
Y_PLANE
]
->
dim
.
w
;
p_pic
->
i_planes
=
1
;
break
;
}
#if 0
switch( p_vout->output.i_chroma )
{
#ifdef MODULE_NAME_IS_xvideo
case VLC_CODEC_Y211:
p_pic->p->p_pixels = p_pic->p_sys->p_image->data
+ p_pic->p_sys->p_image->offsets[0];
p_pic->p->i_lines = p_vout->output.i_height;
p_pic->p->i_visible_lines = p_vout->output.i_height;
/* XXX: this just looks so plain wrong... check it out ! */
p_pic->p->i_pitch = p_pic->p_sys->p_image->pitches[0] / 4;
p_pic->p->i_pixel_pitch = 4;
p_pic->p->i_visible_pitch = p_pic->p->i_pitch;
p_pic->i_planes = 1;
break;
#endif
#endif
default:
/* This shouldn't happen ! */
break
;
}
return
0
;
}
/*****************************************************************************
* FreePicture: destroy a picture allocated with NewPicture
*****************************************************************************
* Destroy XImage AND associated data. If using Shm, detach shared memory
* segment from server and process, then free it. The XDestroyImage manpage
* says that both the image structure _and_ the data pointed to by the
* image structure are freed, so no need to free p_image->data.
*****************************************************************************/
static
void
FreePicture
(
vout_thread_t
*
p_vout
,
picture_t
*
p_pic
)
{
if
(
(
p_vout
->
p_sys
->
i_mode
==
MODE_NORMAL_MEM
||
p_vout
->
p_sys
->
i_mode
==
MODE_SHARED_MEM
)
&&
p_pic
->
p_sys
->
p_image
)
{
PhReleaseImage
(
p_pic
->
p_sys
->
p_image
);
free
(
p_pic
->
p_sys
->
p_image
);
}
else
if
(
p_vout
->
p_sys
->
i_mode
==
MODE_VIDEO_MEM
&&
p_pic
->
p_sys
->
p_ctx
[
0
]
)
{
PhDCRelease
(
p_pic
->
p_sys
->
p_ctx
[
0
]
);
}
free
(
p_pic
->
p_sys
);
}
static
int
ResizeOverlayOutput
(
vout_thread_t
*
p_vout
)
{
int
i_width
,
i_height
,
i_x
,
i_y
;
int
i_ret
;
PgScalerProps_t
props
;
props
.
size
=
sizeof
(
props
);
props
.
format
=
p_vout
->
p_sys
->
i_vc_format
;
props
.
flags
=
Pg_SCALER_PROP_SCALER_ENABLE
|
Pg_SCALER_PROP_DOUBLE_BUFFER
;
/* enable chroma keying if available */
if
(
p_vout
->
p_sys
->
i_vc_flags
&
Pg_SCALER_CAP_DST_CHROMA_KEY
)
{
props
.
flags
|=
Pg_SCALER_PROP_CHROMA_ENABLE
;
}
/* set viewport position */
props
.
viewport
.
ul
.
x
=
p_vout
->
p_sys
->
pos
.
x
;
props
.
viewport
.
ul
.
y
=
p_vout
->
p_sys
->
pos
.
y
;
if
(
!
p_vout
->
b_fullscreen
)
{
props
.
viewport
.
ul
.
x
+=
p_vout
->
p_sys
->
frame
.
ul
.
x
;
props
.
viewport
.
ul
.
y
+=
p_vout
->
p_sys
->
frame
.
ul
.
y
;
}
/* set viewport dimension */
vout_PlacePicture
(
p_vout
,
p_vout
->
p_sys
->
dim
.
w
,
p_vout
->
p_sys
->
dim
.
h
,
&
i_x
,
&
i_y
,
&
i_width
,
&
i_height
);
props
.
viewport
.
ul
.
x
+=
i_x
;
props
.
viewport
.
ul
.
y
+=
i_y
;
props
.
viewport
.
lr
.
x
=
i_width
+
props
.
viewport
.
ul
.
x
;
props
.
viewport
.
lr
.
y
=
i_height
+
props
.
viewport
.
ul
.
y
;
/* set source dimension */
props
.
src_dim
.
w
=
p_vout
->
output
.
i_width
;
props
.
src_dim
.
h
=
p_vout
->
output
.
i_height
;
/* configure scaler channel */
i_ret
=
PgConfigScalerChannel
(
p_vout
->
p_sys
->
p_channel
,
&
props
);
if
(
i_ret
==
-
1
)
{
msg_Err
(
p_vout
,
"unable to configure video channel"
);
return
(
1
);
}
return
(
0
);
}
/*****************************************************************************
* SetPalette: sets an 8 bpp palette
*****************************************************************************
* This function sets the palette given as an argument. It does not return
* anything, but could later send information on which colors it was unable
* to set.
*****************************************************************************/
static
void
SetPalette
(
vout_thread_t
*
p_vout
,
uint16_t
*
red
,
uint16_t
*
green
,
uint16_t
*
blue
)
{
int
i
;
/* allocate palette */
for
(
i
=
0
;
i
<
255
;
i
++
)
{
/* kludge: colors are indexed reversely because color 255 seems
* to be reserved for black even if we try to set it to white */
p_vout
->
p_sys
->
p_colors
[
i
]
=
PgRGB
(
red
[
i
]
>>
8
,
green
[
i
]
>>
8
,
blue
[
i
]
>>
8
);
}
}
po/POTFILES.in
View file @
7c8b9f86
...
@@ -631,9 +631,6 @@ modules/gui/minimal_macosx/voutagl.m
...
@@ -631,9 +631,6 @@ modules/gui/minimal_macosx/voutagl.m
modules/gui/minimal_macosx/voutgl.h
modules/gui/minimal_macosx/voutgl.h
modules/gui/minimal_macosx/voutgl.m
modules/gui/minimal_macosx/voutgl.m
modules/gui/ncurses.c
modules/gui/ncurses.c
modules/gui/qnx/aout.c
modules/gui/qnx/qnx.c
modules/gui/qnx/vout.c
modules/gui/qt4/components/complete_preferences.cpp
modules/gui/qt4/components/complete_preferences.cpp
modules/gui/qt4/components/complete_preferences.hpp
modules/gui/qt4/components/complete_preferences.hpp
modules/gui/qt4/components/controller.cpp
modules/gui/qt4/components/controller.cpp
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment