NAME

POSIX::RT::Signal - POSIX Real-time signal handling functions

VERSION

version 0.005

SYNOPSIS

use POSIX::RT::Signal qw/sigqueue sigwait/;
use Signal::Mask;

$Signal::Mask{USR1}++;
sigqueue($$, 'USR1');
sigwait('USR1');

FUNCTIONS

sigqueue($pid, $sig, $value = 0)

Queue a signal $sig to process $pid, optionally with the additional argument $value. On error an exception is thrown. $sig must be either a signal number(14) or a signal name ('ALRM').

sigwait($signals, $timeout = undef)

Wait for a signal in $signals to arrive and return it. The signal handler (if any) will not be called. Unlike signal handlers it is not affected by signal masks, in fact you are expected to mask signals you're waiting for. $signals must either be a POSIX::SigSet object, a signal number or a signal name. If $timeout is specified, it indicates the maximal time the thread is suspended in fractional seconds; if no signal is received it returns an empty list, or in void context an exception. If $timeout is not defined it may wait indefinitely until a signal arrives. On success it returns a hash with the following entries:

  • signo

    The signal number

  • code

    The signal code, a signal-specific code that gives the reason why the signal was generated

  • errno

    If non-zero, an errno value associated with this signal

  • pid

    Sending process ID

  • uid

    Real user ID of sending process

  • addr

    The address of faulting instruction

  • status

    Exit value or signal

  • band

    Band event for SIGPOLL

  • value

    Signal value as passed to sigqueue

Note that not all of these will have meaningful values for all or even most signals

SEE ALSO

AUTHOR

Leon Timmermans <fawaka@gmail.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2011 by Leon Timmermans.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.