Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
ef785d7a
Commit
ef785d7a
authored
May 18, 2010
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Cosmetics (vout).
parent
acbdb684
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
58 additions
and
61 deletions
+58
-61
src/video_output/video_output.c
src/video_output/video_output.c
+58
-61
No files found.
src/video_output/video_output.c
View file @
ef785d7a
...
@@ -98,8 +98,8 @@ static int VoutValidateFormat(video_format_t *dst,
...
@@ -98,8 +98,8 @@ static int VoutValidateFormat(video_format_t *dst,
* This function looks for a video output thread matching the current
* This function looks for a video output thread matching the current
* properties. If not found, it spawns a new one.
* properties. If not found, it spawns a new one.
*****************************************************************************/
*****************************************************************************/
vout_thread_t
*
(
vout_Request
)(
vlc_object_t
*
object
,
vout_thread_t
*
vout
,
vout_thread_t
*
(
vout_Request
)(
vlc_object_t
*
object
,
vout_thread_t
*
vout
,
const
video_format_t
*
fmt
)
const
video_format_t
*
fmt
)
{
{
if
(
!
fmt
)
{
if
(
!
fmt
)
{
if
(
vout
)
if
(
vout
)
...
@@ -138,86 +138,84 @@ vout_thread_t *(vout_Request)( vlc_object_t *object, vout_thread_t *vout,
...
@@ -138,86 +138,84 @@ vout_thread_t *(vout_Request)( vlc_object_t *object, vout_thread_t *vout,
* This function creates a new video output thread, and returns a pointer
* This function creates a new video output thread, and returns a pointer
* to its description. On error, it returns NULL.
* to its description. On error, it returns NULL.
*****************************************************************************/
*****************************************************************************/
vout_thread_t
*
(
vout_Create
)(
vlc_object_t
*
p_parent
,
const
video_format_t
*
p_fmt
)
vout_thread_t
*
(
vout_Create
)(
vlc_object_t
*
object
,
const
video_format_t
*
fmt
)
{
{
video_format_t
original
;
video_format_t
original
;
if
(
VoutValidateFormat
(
&
original
,
p_
fmt
))
if
(
VoutValidateFormat
(
&
original
,
fmt
))
return
NULL
;
return
NULL
;
/* Allocate descriptor */
/* Allocate descriptor */
vout_thread_t
*
p_vout
=
vlc_custom_create
(
p_paren
t
,
vout_thread_t
*
vout
=
vlc_custom_create
(
objec
t
,
sizeof
(
*
p_vout
)
+
sizeof
(
*
p_
vout
->
p
),
sizeof
(
*
vout
)
+
sizeof
(
*
vout
->
p
),
VLC_OBJECT_VOUT
,
"video output"
);
VLC_OBJECT_VOUT
,
"video output"
);
if
(
!
p_
vout
)
{
if
(
!
vout
)
{
video_format_Clean
(
&
original
);
video_format_Clean
(
&
original
);
return
NULL
;
return
NULL
;
}
}
/* */
/* */
p_vout
->
p
=
(
vout_thread_sys_t
*
)
&
p_
vout
[
1
];
vout
->
p
=
(
vout_thread_sys_t
*
)
&
vout
[
1
];
p_
vout
->
p
->
original
=
original
;
vout
->
p
->
original
=
original
;
vout_control_Init
(
&
p_vout
->
p
->
control
);
vout_control_Init
(
&
vout
->
p
->
control
);
vout_control_PushVoid
(
&
p_vout
->
p
->
control
,
VOUT_CONTROL_INIT
);
vout_control_PushVoid
(
&
vout
->
p
->
control
,
VOUT_CONTROL_INIT
);
vout_statistic_Init
(
&
p_vout
->
p
->
statistic
);
vout_statistic_Init
(
&
vout
->
p
->
statistic
);
p_
vout
->
p
->
i_par_num
=
vout
->
p
->
i_par_num
=
p_
vout
->
p
->
i_par_den
=
1
;
vout
->
p
->
i_par_den
=
1
;
vout_snapshot_Init
(
&
p_vout
->
p
->
snapshot
);
vout_snapshot_Init
(
&
vout
->
p
->
snapshot
);
/* Initialize locks */
/* Initialize locks */
vlc_mutex_init
(
&
p_vout
->
p
->
picture_lock
);
vlc_mutex_init
(
&
vout
->
p
->
picture_lock
);
vlc_mutex_init
(
&
p_vout
->
p
->
vfilter_lock
);
vlc_mutex_init
(
&
vout
->
p
->
vfilter_lock
);
/* Attach the new object now so we can use var inheritance below */
/* Attach the new object now so we can use var inheritance below */
vlc_object_attach
(
p_vout
,
p_parent
);
vlc_object_attach
(
vout
,
object
);
/* Initialize subpicture unit */
/* Initialize subpicture unit */
p_vout
->
p
->
p_spu
=
spu_Create
(
p_vout
);
vout
->
p
->
p_spu
=
spu_Create
(
vout
);
/* */
/* */
spu_Init
(
p_vout
->
p
->
p_spu
);
spu_Init
(
vout
->
p
->
p_spu
);
/* Take care of some "interface/control" related initialisations */
/* Take care of some "interface/control" related initialisations */
vout_IntfInit
(
p_vout
);
vout_IntfInit
(
vout
);
/* Get splitter name if present */
/* Get splitter name if present */
char
*
splitter_name
=
var_GetNonEmptyString
(
p_
vout
,
"vout-filter"
);
char
*
splitter_name
=
var_GetNonEmptyString
(
vout
,
"vout-filter"
);
if
(
splitter_name
)
{
if
(
splitter_name
)
{
if
(
asprintf
(
&
p_
vout
->
p
->
splitter_name
,
"%s,none"
,
splitter_name
)
<
0
)
if
(
asprintf
(
&
vout
->
p
->
splitter_name
,
"%s,none"
,
splitter_name
)
<
0
)
p_
vout
->
p
->
splitter_name
=
NULL
;
vout
->
p
->
splitter_name
=
NULL
;
free
(
splitter_name
);
free
(
splitter_name
);
}
else
{
}
else
{
p_
vout
->
p
->
splitter_name
=
NULL
;
vout
->
p
->
splitter_name
=
NULL
;
}
}
/* */
/* */
vout_InitInterlacingSupport
(
p_vout
,
p_vout
->
p
->
displayed
.
is_interlaced
);
vout_InitInterlacingSupport
(
vout
,
vout
->
p
->
displayed
.
is_interlaced
);
/* */
/* */
vlc_object_set_destructor
(
p_vout
,
VoutDestructor
);
vlc_object_set_destructor
(
vout
,
VoutDestructor
);
/* */
/* */
if
(
vlc_clone
(
&
p_vout
->
p
->
thread
,
Thread
,
p_vout
,
if
(
vlc_clone
(
&
vout
->
p
->
thread
,
Thread
,
vout
,
VLC_THREAD_PRIORITY_OUTPUT
)
)
VLC_THREAD_PRIORITY_OUTPUT
))
{
{
vlc_object_release
(
vout
);
vlc_object_release
(
p_vout
);
return
NULL
;
return
NULL
;
}
}
spu_Attach
(
p_vout
->
p
->
p_spu
,
VLC_OBJECT
(
p_vout
),
true
);
spu_Attach
(
vout
->
p
->
p_spu
,
VLC_OBJECT
(
vout
),
true
);
vout_control_WaitEmpty
(
&
p_vout
->
p
->
control
);
vout_control_WaitEmpty
(
&
vout
->
p
->
control
);
if
(
p_vout
->
p
->
dead
)
if
(
vout
->
p
->
dead
)
{
{
msg_Err
(
vout
,
"video output creation failed"
);
msg_Err
(
p_vout
,
"video output creation failed"
);
vout_CloseAndRelease
(
vout
);
vout_CloseAndRelease
(
p_vout
);
return
NULL
;
return
NULL
;
}
}
return
p_
vout
;
return
vout
;
}
}
/*****************************************************************************
/*****************************************************************************
...
@@ -228,43 +226,43 @@ vout_thread_t * (vout_Create)( vlc_object_t *p_parent, const video_format_t *p_f
...
@@ -228,43 +226,43 @@ vout_thread_t * (vout_Create)( vlc_object_t *p_parent, const video_format_t *p_f
* (like with vout_Request or vlc_object_find.)
* (like with vout_Request or vlc_object_find.)
* You can use vout_CloseAndRelease() as a convenience method.
* You can use vout_CloseAndRelease() as a convenience method.
*****************************************************************************/
*****************************************************************************/
void
vout_Close
(
vout_thread_t
*
p_vout
)
void
vout_Close
(
vout_thread_t
*
vout
)
{
{
assert
(
p_vout
);
assert
(
vout
);
spu_Attach
(
p_vout
->
p
->
p_spu
,
VLC_OBJECT
(
p_vout
),
false
);
spu_Attach
(
vout
->
p
->
p_spu
,
VLC_OBJECT
(
vout
),
false
);
vout_snapshot_End
(
&
p_vout
->
p
->
snapshot
);
vout_snapshot_End
(
&
vout
->
p
->
snapshot
);
vout_control_PushVoid
(
&
p_vout
->
p
->
control
,
VOUT_CONTROL_CLEAN
);
vout_control_PushVoid
(
&
vout
->
p
->
control
,
VOUT_CONTROL_CLEAN
);
vlc_join
(
p_vout
->
p
->
thread
,
NULL
);
vlc_join
(
vout
->
p
->
thread
,
NULL
);
}
}
/* */
/* */
static
void
VoutDestructor
(
vlc_object_t
*
p_this
)
static
void
VoutDestructor
(
vlc_object_t
*
object
)
{
{
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
vout_thread_t
*
vout
=
(
vout_thread_t
*
)
object
;
/* Make sure the vout was stopped first */
/* Make sure the vout was stopped first */
//assert(
!p_vout->p_module
);
//assert(
!vout->p_module
);
free
(
p_vout
->
p
->
splitter_name
);
free
(
vout
->
p
->
splitter_name
);
/* */
/* */
spu_Destroy
(
p_vout
->
p
->
p_spu
);
spu_Destroy
(
vout
->
p
->
p_spu
);
/* Destroy the locks */
/* Destroy the locks */
vlc_mutex_destroy
(
&
p_vout
->
p
->
picture_lock
);
vlc_mutex_destroy
(
&
vout
->
p
->
picture_lock
);
vlc_mutex_destroy
(
&
p_vout
->
p
->
vfilter_lock
);
vlc_mutex_destroy
(
&
vout
->
p
->
vfilter_lock
);
vout_control_Clean
(
&
p_vout
->
p
->
control
);
vout_control_Clean
(
&
vout
->
p
->
control
);
/* */
/* */
vout_statistic_Clean
(
&
p_vout
->
p
->
statistic
);
vout_statistic_Clean
(
&
vout
->
p
->
statistic
);
/* */
/* */
vout_snapshot_Clean
(
&
p_vout
->
p
->
snapshot
);
vout_snapshot_Clean
(
&
vout
->
p
->
snapshot
);
video_format_Clean
(
&
p_vout
->
p
->
original
);
video_format_Clean
(
&
vout
->
p
->
original
);
}
}
/* */
/* */
...
@@ -279,10 +277,9 @@ void vout_ChangePause(vout_thread_t *vout, bool is_paused, mtime_t date)
...
@@ -279,10 +277,9 @@ void vout_ChangePause(vout_thread_t *vout, bool is_paused, mtime_t date)
vout_control_WaitEmpty
(
&
vout
->
p
->
control
);
vout_control_WaitEmpty
(
&
vout
->
p
->
control
);
}
}
void
vout_GetResetStatistic
(
vout_thread_t
*
p_vout
,
int
*
pi_displayed
,
int
*
pi_lost
)
void
vout_GetResetStatistic
(
vout_thread_t
*
vout
,
int
*
displayed
,
int
*
lost
)
{
{
vout_statistic_GetReset
(
&
p_vout
->
p
->
statistic
,
vout_statistic_GetReset
(
&
vout
->
p
->
statistic
,
displayed
,
lost
);
pi_displayed
,
pi_lost
);
}
}
void
vout_Flush
(
vout_thread_t
*
vout
,
mtime_t
date
)
void
vout_Flush
(
vout_thread_t
*
vout
,
mtime_t
date
)
...
@@ -365,9 +362,9 @@ void vout_FlushSubpictureChannel( vout_thread_t *vout, int channel )
...
@@ -365,9 +362,9 @@ void vout_FlushSubpictureChannel( vout_thread_t *vout, int channel )
spu_ClearChannel
(
vout
->
p
->
p_spu
,
channel
);
spu_ClearChannel
(
vout
->
p
->
p_spu
,
channel
);
}
}
spu_t
*
vout_GetSpu
(
vout_thread_t
*
p_vout
)
spu_t
*
vout_GetSpu
(
vout_thread_t
*
vout
)
{
{
return
p_
vout
->
p
->
p_spu
;
return
vout
->
p
->
p_spu
;
}
}
/* vout_Control* are usable by anyone at anytime */
/* vout_Control* are usable by anyone at anytime */
...
...
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