Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
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-2-2
Commits
eb6d8c3c
Commit
eb6d8c3c
authored
Dec 20, 2009
by
Rémi Duraffort
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
x264: use static mutex for win.
parent
2d4bad07
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
15 additions
and
24 deletions
+15
-24
modules/codec/x264.c
modules/codec/x264.c
+15
-24
No files found.
modules/codec/x264.c
View file @
eb6d8c3c
...
...
@@ -675,6 +675,11 @@ struct encoder_sys_t
char
*
psz_stat_name
;
};
#ifdef PTW32_STATIC_LIB
static
vlc_mutex_t
pthread_win32_mutex
=
VLC_STATIC_MUTEX
;
static
int
pthread_win32_count
=
0
;
#endif
/*****************************************************************************
* Open: probe the encoder
*****************************************************************************/
...
...
@@ -1114,30 +1119,21 @@ static int Open ( vlc_object_t *p_this )
but only once for the whole application. Since pthreadw32
doesn't keep a refcount, do it ourselves. */
#ifdef PTW32_STATIC_LIB
vlc_value_t
lock
,
count
;
var_Create
(
p_enc
->
p_libvlc
,
"pthread_win32_mutex"
,
VLC_VAR_MUTEX
);
var_Get
(
p_enc
->
p_libvlc
,
"pthread_win32_mutex"
,
&
lock
);
vlc_mutex_lock
(
lock
.
p_address
);
var_Create
(
p_enc
->
p_libvlc
,
"pthread_win32_count"
,
VLC_VAR_INTEGER
);
var_Get
(
p_enc
->
p_libvlc
,
"pthread_win32_count"
,
&
count
);
vlc_mutex_lock
(
&
pthread_win32_mutex
);
if
(
count
.
i_i
nt
==
0
)
if
(
pthread_win32_cou
nt
==
0
)
{
msg_Dbg
(
p_enc
,
"initializing pthread-win32"
);
if
(
!
pthread_win32_process_attach_np
()
||
!
pthread_win32_thread_attach_np
()
)
{
msg_Warn
(
p_enc
,
"pthread Win32 Initialization failed"
);
vlc_mutex_unlock
(
lock
.
p_address
);
vlc_mutex_unlock
(
&
pthread_win32_mutex
);
return
VLC_EGENERIC
;
}
}
count
.
i_int
++
;
var_Set
(
p_enc
->
p_libvlc
,
"pthread_win32_count"
,
count
);
vlc_mutex_unlock
(
lock
.
p_address
);
pthread_win32_count
++
;
vlc_mutex_unlock
(
&
pthread_win32_mutex
);
#endif
/* Set lookahead value to lower than default,
...
...
@@ -1279,22 +1275,17 @@ static void Close( vlc_object_t *p_this )
x264_encoder_close
(
p_sys
->
h
);
#ifdef PTW32_STATIC_LIB
vlc_value_t
lock
,
count
;
var_Get
(
p_enc
->
p_libvlc
,
"pthread_win32_mutex"
,
&
lock
);
vlc_mutex_lock
(
lock
.
p_address
);
vlc_mutex_lock
(
&
pthread_win32_mutex
);
pthread_win32_count
--
;
var_Get
(
p_enc
->
p_libvlc
,
"pthread_win32_count"
,
&
count
);
count
.
i_int
--
;
var_Set
(
p_enc
->
p_libvlc
,
"pthread_win32_count"
,
count
);
if
(
count
.
i_int
==
0
)
if
(
pthread_win32_count
==
0
)
{
pthread_win32_thread_detach_np
();
pthread_win32_process_detach_np
();
msg_Dbg
(
p_enc
,
"pthread-win32 deinitialized"
);
}
vlc_mutex_unlock
(
lock
.
p_address
);
vlc_mutex_unlock
(
&
pthread_win32_mutex
);
#endif
free
(
p_sys
);
...
...
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