Your company here ā€” click to reach over 10,000 unique daily visitors

alarm - Man Page

set an alarm clock for delivery of a signal


Standard C library (libc, -lc)


#include <unistd.h>

unsigned int alarm(unsigned int seconds);


alarm() arranges for a SIGALRM signal to be delivered to the calling process in seconds seconds.

If seconds is zero, any pending alarm is canceled.

In any event any previously set alarm() is canceled.

Return Value

alarm() returns the number of seconds remaining until any previously scheduled alarm was due to be delivered, or zero if there was no previously scheduled alarm.




POSIX.1-2001, SVr4, 4.3BSD.


alarm() and setitimer(2) share the same timer; calls to one will interfere with use of the other.

Alarms created by alarm() are preserved across execve(2) and are not inherited by children created via fork(2).

sleep(3) may be implemented using SIGALRM; mixing calls to alarm() and sleep(3) is a bad idea.

Scheduling delays can, as ever, cause the execution of the process to be delayed by an arbitrary amount of time.

See Also

gettimeofday(2), pause(2), select(2), setitimer(2), sigaction(2), signal(2), timer_create(2), timerfd_create(2), sleep(3), time(7)

Referenced By

fork(2), getitimer(2), ObjCmdWrite(3), seccomp(2), signal(2), signal(7), signal-safety(7), sleep(3), snmp_alarm(3), stress-ng(1), syscalls(2), systemd.exec(5), time(7), tload(1), ualarm(3), usleep(3).

2024-05-02 Linux man-pages 6.9.1