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
13310047
Commit
13310047
authored
Jun 30, 2009
by
Rémi Duraffort
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Cosmetics.
parent
ce3964dd
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
51 additions
and
48 deletions
+51
-48
modules/video_filter/deinterlace.c
modules/video_filter/deinterlace.c
+51
-48
No files found.
modules/video_filter/deinterlace.c
View file @
13310047
/*****************************************************************************
/*****************************************************************************
* deinterlace.c : deinterlacer plugin for vlc
* deinterlace.c : deinterlacer plugin for vlc
*****************************************************************************
*****************************************************************************
* Copyright (C) 2000
, 2001, 2002, 2003
the VideoLAN team
* Copyright (C) 2000
-2009
the VideoLAN team
* $Id$
* $Id$
*
*
* Author: Sam Hocevar <sam@zoy.org>
* Author: Sam Hocevar <sam@zoy.org>
...
@@ -191,10 +191,11 @@ static int Control( vout_thread_t *p_vout, int i_query, va_list args )
...
@@ -191,10 +191,11 @@ static int Control( vout_thread_t *p_vout, int i_query, va_list args )
static
int
Create
(
vlc_object_t
*
p_this
)
static
int
Create
(
vlc_object_t
*
p_this
)
{
{
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
vout_sys_t
*
p_sys
;
vlc_value_t
val
;
vlc_value_t
val
;
/* Allocate structure */
/* Allocate structure */
p_vout
->
p_sys
=
malloc
(
sizeof
(
vout_sys_t
)
);
p_
sys
=
p_
vout
->
p_sys
=
malloc
(
sizeof
(
vout_sys_t
)
);
if
(
p_vout
->
p_sys
==
NULL
)
if
(
p_vout
->
p_sys
==
NULL
)
return
VLC_ENOMEM
;
return
VLC_ENOMEM
;
...
@@ -205,48 +206,48 @@ static int Create( vlc_object_t *p_this )
...
@@ -205,48 +206,48 @@ static int Create( vlc_object_t *p_this )
p_vout
->
pf_display
=
NULL
;
p_vout
->
pf_display
=
NULL
;
p_vout
->
pf_control
=
Control
;
p_vout
->
pf_control
=
Control
;
p_
vout
->
p_
sys
->
i_mode
=
DEINTERLACE_DISCARD
;
p_sys
->
i_mode
=
DEINTERLACE_DISCARD
;
p_
vout
->
p_
sys
->
b_double_rate
=
false
;
p_sys
->
b_double_rate
=
false
;
p_
vout
->
p_
sys
->
b_half_height
=
true
;
p_sys
->
b_half_height
=
true
;
p_
vout
->
p_
sys
->
last_date
=
0
;
p_sys
->
last_date
=
0
;
p_
vout
->
p_
sys
->
p_vout
=
0
;
p_sys
->
p_vout
=
0
;
vlc_mutex_init
(
&
p_
vout
->
p_
sys
->
filter_lock
);
vlc_mutex_init
(
&
p_sys
->
filter_lock
);
#if defined(CAN_COMPILE_C_ALTIVEC)
#if defined(CAN_COMPILE_C_ALTIVEC)
if
(
vlc_CPU
()
&
CPU_CAPABILITY_ALTIVEC
)
if
(
vlc_CPU
()
&
CPU_CAPABILITY_ALTIVEC
)
{
{
p_
vout
->
p_
sys
->
pf_merge
=
MergeAltivec
;
p_sys
->
pf_merge
=
MergeAltivec
;
p_
vout
->
p_
sys
->
pf_end_merge
=
NULL
;
p_sys
->
pf_end_merge
=
NULL
;
}
}
else
else
#endif
#endif
#if defined(CAN_COMPILE_SSE)
#if defined(CAN_COMPILE_SSE)
if
(
vlc_CPU
()
&
CPU_CAPABILITY_SSE2
)
if
(
vlc_CPU
()
&
CPU_CAPABILITY_SSE2
)
{
{
p_
vout
->
p_
sys
->
pf_merge
=
MergeSSE2
;
p_sys
->
pf_merge
=
MergeSSE2
;
p_
vout
->
p_
sys
->
pf_end_merge
=
EndMMX
;
p_sys
->
pf_end_merge
=
EndMMX
;
}
}
else
else
#endif
#endif
#if defined(CAN_COMPILE_MMXEXT)
#if defined(CAN_COMPILE_MMXEXT)
if
(
vlc_CPU
()
&
CPU_CAPABILITY_MMXEXT
)
if
(
vlc_CPU
()
&
CPU_CAPABILITY_MMXEXT
)
{
{
p_
vout
->
p_
sys
->
pf_merge
=
MergeMMXEXT
;
p_sys
->
pf_merge
=
MergeMMXEXT
;
p_
vout
->
p_
sys
->
pf_end_merge
=
EndMMX
;
p_sys
->
pf_end_merge
=
EndMMX
;
}
}
else
else
#endif
#endif
#if defined(CAN_COMPILE_3DNOW)
#if defined(CAN_COMPILE_3DNOW)
if
(
vlc_CPU
()
&
CPU_CAPABILITY_3DNOW
)
if
(
vlc_CPU
()
&
CPU_CAPABILITY_3DNOW
)
{
{
p_
vout
->
p_
sys
->
pf_merge
=
Merge3DNow
;
p_sys
->
pf_merge
=
Merge3DNow
;
p_
vout
->
p_
sys
->
pf_end_merge
=
End3DNow
;
p_sys
->
pf_end_merge
=
End3DNow
;
}
}
else
else
#endif
#endif
{
{
p_
vout
->
p_
sys
->
pf_merge
=
MergeGeneric
;
p_sys
->
pf_merge
=
MergeGeneric
;
p_
vout
->
p_
sys
->
pf_end_merge
=
NULL
;
p_sys
->
pf_end_merge
=
NULL
;
}
}
/* Look what method was requested */
/* Look what method was requested */
...
@@ -275,38 +276,39 @@ static int Create( vlc_object_t *p_this )
...
@@ -275,38 +276,39 @@ static int Create( vlc_object_t *p_this )
*****************************************************************************/
*****************************************************************************/
static
void
SetFilterMethod
(
vout_thread_t
*
p_vout
,
char
*
psz_method
)
static
void
SetFilterMethod
(
vout_thread_t
*
p_vout
,
char
*
psz_method
)
{
{
vout_sys_t
*
p_sys
=
p_vout
->
p_sys
;
if
(
!
strcmp
(
psz_method
,
"mean"
)
)
if
(
!
strcmp
(
psz_method
,
"mean"
)
)
{
{
p_
vout
->
p_
sys
->
i_mode
=
DEINTERLACE_MEAN
;
p_sys
->
i_mode
=
DEINTERLACE_MEAN
;
p_
vout
->
p_
sys
->
b_double_rate
=
false
;
p_sys
->
b_double_rate
=
false
;
p_
vout
->
p_
sys
->
b_half_height
=
true
;
p_sys
->
b_half_height
=
true
;
}
}
else
if
(
!
strcmp
(
psz_method
,
"blend"
)
else
if
(
!
strcmp
(
psz_method
,
"blend"
)
||
!
strcmp
(
psz_method
,
"average"
)
||
!
strcmp
(
psz_method
,
"average"
)
||
!
strcmp
(
psz_method
,
"combine-fields"
)
)
||
!
strcmp
(
psz_method
,
"combine-fields"
)
)
{
{
p_
vout
->
p_
sys
->
i_mode
=
DEINTERLACE_BLEND
;
p_sys
->
i_mode
=
DEINTERLACE_BLEND
;
p_
vout
->
p_
sys
->
b_double_rate
=
false
;
p_sys
->
b_double_rate
=
false
;
p_
vout
->
p_
sys
->
b_half_height
=
false
;
p_sys
->
b_half_height
=
false
;
}
}
else
if
(
!
strcmp
(
psz_method
,
"bob"
)
else
if
(
!
strcmp
(
psz_method
,
"bob"
)
||
!
strcmp
(
psz_method
,
"progressive-scan"
)
)
||
!
strcmp
(
psz_method
,
"progressive-scan"
)
)
{
{
p_
vout
->
p_
sys
->
i_mode
=
DEINTERLACE_BOB
;
p_sys
->
i_mode
=
DEINTERLACE_BOB
;
p_
vout
->
p_
sys
->
b_double_rate
=
true
;
p_sys
->
b_double_rate
=
true
;
p_
vout
->
p_
sys
->
b_half_height
=
false
;
p_sys
->
b_half_height
=
false
;
}
}
else
if
(
!
strcmp
(
psz_method
,
"linear"
)
)
else
if
(
!
strcmp
(
psz_method
,
"linear"
)
)
{
{
p_
vout
->
p_
sys
->
i_mode
=
DEINTERLACE_LINEAR
;
p_sys
->
i_mode
=
DEINTERLACE_LINEAR
;
p_
vout
->
p_
sys
->
b_double_rate
=
true
;
p_sys
->
b_double_rate
=
true
;
p_
vout
->
p_
sys
->
b_half_height
=
false
;
p_sys
->
b_half_height
=
false
;
}
}
else
if
(
!
strcmp
(
psz_method
,
"x"
)
)
else
if
(
!
strcmp
(
psz_method
,
"x"
)
)
{
{
p_
vout
->
p_
sys
->
i_mode
=
DEINTERLACE_X
;
p_sys
->
i_mode
=
DEINTERLACE_X
;
p_
vout
->
p_
sys
->
b_double_rate
=
false
;
p_sys
->
b_double_rate
=
false
;
p_
vout
->
p_
sys
->
b_half_height
=
false
;
p_sys
->
b_half_height
=
false
;
}
}
else
else
{
{
...
@@ -315,9 +317,9 @@ static void SetFilterMethod( vout_thread_t *p_vout, char *psz_method )
...
@@ -315,9 +317,9 @@ static void SetFilterMethod( vout_thread_t *p_vout, char *psz_method )
msg_Err
(
p_vout
,
"no valid deinterlace mode provided, "
msg_Err
(
p_vout
,
"no valid deinterlace mode provided, "
"using
\"
discard
\"
"
);
"using
\"
discard
\"
"
);
p_
vout
->
p_
sys
->
i_mode
=
DEINTERLACE_DISCARD
;
p_sys
->
i_mode
=
DEINTERLACE_DISCARD
;
p_
vout
->
p_
sys
->
b_double_rate
=
false
;
p_sys
->
b_double_rate
=
false
;
p_
vout
->
p_
sys
->
b_half_height
=
!
b_i422
;
p_sys
->
b_half_height
=
!
b_i422
;
}
}
msg_Dbg
(
p_vout
,
"using %s deinterlace method"
,
psz_method
);
msg_Dbg
(
p_vout
,
"using %s deinterlace method"
,
psz_method
);
...
@@ -1681,42 +1683,43 @@ static int FilterCallback( vlc_object_t *p_this, char const *psz_cmd,
...
@@ -1681,42 +1683,43 @@ static int FilterCallback( vlc_object_t *p_this, char const *psz_cmd,
{
{
VLC_UNUSED
(
psz_cmd
);
VLC_UNUSED
(
p_data
);
VLC_UNUSED
(
oldval
);
VLC_UNUSED
(
psz_cmd
);
VLC_UNUSED
(
p_data
);
VLC_UNUSED
(
oldval
);
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
vout_thread_t
*
p_vout
=
(
vout_thread_t
*
)
p_this
;
vout_sys_t
*
p_sys
=
p_vout
->
p_sys
;
msg_Dbg
(
p_vout
,
"using %s deinterlace mode"
,
newval
.
psz_string
);
msg_Dbg
(
p_vout
,
"using %s deinterlace mode"
,
newval
.
psz_string
);
vlc_mutex_lock
(
&
p_
vout
->
p_
sys
->
filter_lock
);
vlc_mutex_lock
(
&
p_sys
->
filter_lock
);
const
bool
b_old_half_height
=
p_
vout
->
p_
sys
->
b_half_height
;
const
bool
b_old_half_height
=
p_sys
->
b_half_height
;
SetFilterMethod
(
p_vout
,
newval
.
psz_string
);
SetFilterMethod
(
p_vout
,
newval
.
psz_string
);
if
(
!
b_old_half_height
==
!
p_
vout
->
p_
sys
->
b_half_height
)
if
(
!
b_old_half_height
==
!
p_sys
->
b_half_height
)
{
{
vlc_mutex_unlock
(
&
p_
vout
->
p_
sys
->
filter_lock
);
vlc_mutex_unlock
(
&
p_sys
->
filter_lock
);
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
/* We need to kill the old vout */
/* We need to kill the old vout */
if
(
p_
vout
->
p_
sys
->
p_vout
)
if
(
p_sys
->
p_vout
)
{
{
vout_filter_DelChild
(
p_vout
,
p_
vout
->
p_
sys
->
p_vout
,
MouseEvent
);
vout_filter_DelChild
(
p_vout
,
p_sys
->
p_vout
,
MouseEvent
);
vout_CloseAndRelease
(
p_
vout
->
p_
sys
->
p_vout
);
vout_CloseAndRelease
(
p_sys
->
p_vout
);
}
}
/* Try to open a new video output */
/* Try to open a new video output */
p_
vout
->
p_
sys
->
p_vout
=
SpawnRealVout
(
p_vout
);
p_sys
->
p_vout
=
SpawnRealVout
(
p_vout
);
if
(
p_
vout
->
p_
sys
->
p_vout
==
NULL
)
if
(
p_sys
->
p_vout
==
NULL
)
{
{
/* Everything failed */
/* Everything failed */
msg_Err
(
p_vout
,
"cannot open vout, aborting"
);
msg_Err
(
p_vout
,
"cannot open vout, aborting"
);
vlc_mutex_unlock
(
&
p_
vout
->
p_
sys
->
filter_lock
);
vlc_mutex_unlock
(
&
p_sys
->
filter_lock
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
vout_filter_AddChild
(
p_vout
,
p_
vout
->
p_
sys
->
p_vout
,
MouseEvent
);
vout_filter_AddChild
(
p_vout
,
p_sys
->
p_vout
,
MouseEvent
);
vlc_mutex_unlock
(
&
p_
vout
->
p_
sys
->
filter_lock
);
vlc_mutex_unlock
(
&
p_sys
->
filter_lock
);
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
}
}
...
...
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