Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
75412805
Commit
75412805
authored
Sep 08, 2008
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix crash when thread creation fails, fix msleep usage.
parent
c3ae935f
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
42 deletions
+28
-42
modules/demux/live555.cpp
modules/demux/live555.cpp
+28
-42
No files found.
modules/demux/live555.cpp
View file @
75412805
...
@@ -48,6 +48,7 @@
...
@@ -48,6 +48,7 @@
#include <iostream>
#include <iostream>
#include <limits.h>
#include <limits.h>
#include <assert.h>
#if defined( WIN32 )
#if defined( WIN32 )
...
@@ -160,10 +161,9 @@ typedef struct
...
@@ -160,10 +161,9 @@ typedef struct
struct
timeout_thread_t
struct
timeout_thread_t
{
{
VLC_COMMON_MEMBERS
bool
b_handle_keep_alive
;
demux_sys_t
*
p_sys
;
demux_sys_t
*
p_sys
;
vlc_thread_t
handle
;
bool
b_handle_keep_alive
;
};
};
struct
demux_sys_t
struct
demux_sys_t
...
@@ -222,7 +222,7 @@ static void StreamRead ( void *, unsigned int, unsigned int,
...
@@ -222,7 +222,7 @@ static void StreamRead ( void *, unsigned int, unsigned int,
static
void
StreamClose
(
void
*
);
static
void
StreamClose
(
void
*
);
static
void
TaskInterrupt
(
void
*
);
static
void
TaskInterrupt
(
void
*
);
static
void
*
TimeoutPrevention
(
v
lc_object_t
*
);
static
void
*
TimeoutPrevention
(
v
oid
*
);
static
unsigned
char
*
parseH264ConfigStr
(
char
const
*
configStr
,
static
unsigned
char
*
parseH264ConfigStr
(
char
const
*
configStr
,
unsigned
int
&
configSize
);
unsigned
int
&
configSize
);
...
@@ -412,10 +412,9 @@ error:
...
@@ -412,10 +412,9 @@ error:
if
(
p_sys
->
env
)
p_sys
->
env
->
reclaim
();
if
(
p_sys
->
env
)
p_sys
->
env
->
reclaim
();
if
(
p_sys
->
p_timeout
)
if
(
p_sys
->
p_timeout
)
{
{
vlc_object_kill
(
p_sys
->
p_timeout
);
vlc_cancel
(
p_sys
->
p_timeout
->
handle
);
vlc_thread_join
(
p_sys
->
p_timeout
);
vlc_join
(
p_sys
->
p_timeout
->
handle
,
NULL
);
vlc_object_detach
(
p_sys
->
p_timeout
);
free
(
p_sys
->
p_timeout
);
vlc_object_release
(
p_sys
->
p_timeout
);
}
}
delete
p_sys
->
scheduler
;
delete
p_sys
->
scheduler
;
free
(
p_sys
->
p_sdp
);
free
(
p_sys
->
p_sdp
);
...
@@ -454,10 +453,9 @@ static void Close( vlc_object_t *p_this )
...
@@ -454,10 +453,9 @@ static void Close( vlc_object_t *p_this )
if
(
p_sys
->
env
)
p_sys
->
env
->
reclaim
();
if
(
p_sys
->
env
)
p_sys
->
env
->
reclaim
();
if
(
p_sys
->
p_timeout
)
if
(
p_sys
->
p_timeout
)
{
{
vlc_object_kill
(
p_sys
->
p_timeout
);
vlc_cancel
(
p_sys
->
p_timeout
->
handle
);
vlc_thread_join
(
p_sys
->
p_timeout
);
vlc_join
(
p_sys
->
p_timeout
->
handle
,
NULL
);
vlc_object_detach
(
p_sys
->
p_timeout
);
free
(
p_sys
->
p_timeout
);
vlc_object_release
(
p_sys
->
p_timeout
);
}
}
delete
p_sys
->
scheduler
;
delete
p_sys
->
scheduler
;
free
(
p_sys
->
p_sdp
);
free
(
p_sys
->
p_sdp
);
...
@@ -1042,17 +1040,16 @@ static int Play( demux_t *p_demux )
...
@@ -1042,17 +1040,16 @@ static int Play( demux_t *p_demux )
if
(
!
p_sys
->
p_timeout
&&
p_sys
->
b_get_param
)
if
(
!
p_sys
->
p_timeout
&&
p_sys
->
b_get_param
)
{
{
msg_Dbg
(
p_demux
,
"We have a timeout of %d seconds"
,
p_sys
->
i_timeout
);
msg_Dbg
(
p_demux
,
"We have a timeout of %d seconds"
,
p_sys
->
i_timeout
);
p_sys
->
p_timeout
=
(
timeout_thread_t
*
)
vlc_object_create
(
p_demux
,
sizeof
(
timeout_thread_t
)
);
p_sys
->
p_timeout
=
(
timeout_thread_t
*
)
malloc
(
sizeof
(
timeout_thread_t
)
);
p_sys
->
p_timeout
->
p_sys
=
p_demux
->
p_sys
;
/* lol, object recursion :D */
p_sys
->
p_timeout
->
p_sys
=
p_demux
->
p_sys
;
/* lol, object recursion :D */
if
(
vlc_thread_create
(
p_sys
->
p_timeout
,
"liveMedia-timeout"
,
if
(
vlc_clone
(
&
p_sys
->
p_timeout
->
handle
,
TimeoutPrevention
,
TimeoutPrevention
,
p_sys
->
p_timeout
,
VLC_THREAD_PRIORITY_LOW
)
)
VLC_THREAD_PRIORITY_LOW
,
false
)
)
{
{
msg_Err
(
p_demux
,
"cannot spawn liveMedia timeout thread"
);
msg_Err
(
p_demux
,
"cannot spawn liveMedia timeout thread"
);
vlc_object_release
(
p_sys
->
p_timeout
);
free
(
p_sys
->
p_timeout
);
p_sys
->
p_timeout
=
NULL
;
}
}
msg_Dbg
(
p_demux
,
"spawned timeout thread"
);
msg_Dbg
(
p_demux
,
"spawned timeout thread"
);
vlc_object_attach
(
p_sys
->
p_timeout
,
p_demux
);
}
}
}
}
p_sys
->
i_pcr
=
0
;
p_sys
->
i_pcr
=
0
;
...
@@ -1711,37 +1708,26 @@ static void TaskInterrupt( void *p_private )
...
@@ -1711,37 +1708,26 @@ static void TaskInterrupt( void *p_private )
/*****************************************************************************
/*****************************************************************************
*
*
*****************************************************************************/
*****************************************************************************/
static
void
*
TimeoutPrevention
(
v
lc_object_t
*
p_this
)
static
void
*
TimeoutPrevention
(
v
oid
*
p_data
)
{
{
timeout_thread_t
*
p_timeout
=
(
timeout_thread_t
*
)
p_this
;
timeout_thread_t
*
p_timeout
=
(
timeout_thread_t
*
)
p_data
;
int64_t
i_remain
=
(
int64_t
)
p_timeout
->
p_sys
->
i_timeout
-
2
;
i_remain
*=
1000000
;
int
canc
=
vlc_savecancel
();
for
(
;;
)
/* Avoid lock */
while
(
vlc_object_alive
(
p_timeout
)
)
{
{
if
(
i_remain
<=
0
)
/* Voodoo (= no) thread safety here! *Ahem* */
if
(
p_timeout
->
b_handle_keep_alive
)
{
{
char
*
psz_bye
=
NULL
;
char
*
psz_bye
=
NULL
;
i_remain
=
(
int64_t
)
p_timeout
->
p_sys
->
i_timeout
-
2
;
int
canc
=
vlc_savecancel
();
i_remain
*=
1000000
;
msg_Dbg
(
p_timeout
,
"reset the timeout timer"
);
if
(
p_timeout
->
b_handle_keep_alive
==
true
)
{
p_timeout
->
p_sys
->
rtsp
->
getMediaSessionParameter
(
*
p_timeout
->
p_sys
->
ms
,
NULL
,
psz_bye
);
p_timeout
->
p_sys
->
rtsp
->
getMediaSessionParameter
(
*
p_timeout
->
p_sys
->
ms
,
NULL
,
psz_bye
);
p_timeout
->
p_sys
->
b_timeout_call
=
false
;
vlc_restorecancel
(
canc
);
}
else
{
p_timeout
->
p_sys
->
b_timeout_call
=
true
;
}
}
}
i_remain
-=
200000
;
p_timeout
->
p_sys
->
b_timeout_call
=
!
p_timeout
->
b_handle_keep_alive
;
msleep
(
200000
);
/* 200 ms */
msleep
(((
int64_t
)
p_timeout
->
p_sys
->
i_timeout
-
2
)
*
CLOCK_FREQ
);
}
}
vlc_restorecancel
(
canc
);
assert
(
0
);
/* dead code */
}
}
/*****************************************************************************
/*****************************************************************************
...
...
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