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
54668b79
Commit
54668b79
authored
Aug 31, 2007
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Document signal handling
parent
64099a68
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
22 additions
and
3 deletions
+22
-3
src/vlc.c
src/vlc.c
+22
-3
No files found.
src/vlc.c
View file @
54668b79
...
@@ -98,11 +98,30 @@ int main( int i_argc, char *ppsz_argv[] )
...
@@ -98,11 +98,30 @@ int main( int i_argc, char *ppsz_argv[] )
}
}
#if !defined(WIN32) && !defined(UNDER_CE)
#if !defined(WIN32) && !defined(UNDER_CE)
/* Synchronously intercepted signals. They request a clean shutdown,
/* Synchronously intercepted POSIX signals.
* and force an unclean shutdown if they are triggered again 2+ seconds
*
* later. We have to handle SIGTERM cleanly because of daemon mode.
* In a threaded program such as VLC, the only sane way to handle signals
* is to block them in all thread but one - this is the only way to
* predict which thread will receive them. If any piece of code depends
* on delivery of one of this signal it is intrinsically not thread-safe
* and MUST NOT be used in VLC, whether we like it or not.
* There is only one exception: if the signal is raised with
* pthread_kill() - we do not use this in LibVLC but some pthread
* implementations use them internally. You should really use conditions
* for thread synchronization anyway.
*
* Signal that request a clean shutdown, and force an unclean shutdown
* if they are triggered again 2+ seconds later.
* We have to handle SIGTERM cleanly because of daemon mode.
* Note that we set the signals after the vlc_create call. */
* Note that we set the signals after the vlc_create call. */
static
const
int
exitsigs
[]
=
{
SIGINT
,
SIGHUP
,
SIGQUIT
,
SIGTERM
};
static
const
int
exitsigs
[]
=
{
SIGINT
,
SIGHUP
,
SIGQUIT
,
SIGTERM
};
/* Signals that cause a no-op:
* - SIGALRM should not happen, but lets stay on the safe side.
* - SIGPIPE might happen with sockets and would crash VLC. It MUST be
* blocked by any LibVLC-dependant application, in addition to VLC.
* - SIGCHLD is comes after exec*() (such as httpd CGI support) and must
* be dequeued to cleanup zombie processes.
*/
static
const
int
dummysigs
[]
=
{
SIGALRM
,
SIGPIPE
,
SIGCHLD
};
static
const
int
dummysigs
[]
=
{
SIGALRM
,
SIGPIPE
,
SIGCHLD
};
sigset_t
set
;
sigset_t
set
;
...
...
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