merged signal.c in timer.c

This commit is contained in:
2021-01-27 15:26:19 +01:00
parent 691bc6304a
commit 3da1891778
3 changed files with 2 additions and 59 deletions

View File

@@ -33,7 +33,7 @@ TIME := \time -f "\ttime: %E real, %U user, %S sys\n\tcontext-switch:\t%c+%w, pa
export PATH := .:$(PATH)
TARGETS=lceb tree oper timer
OBJS=lceb.o tree.o oper.o stack.o eval.o best.o timer.o stack.o signal.o
OBJS=lceb.o tree.o oper.o stack.o eval.o best.o timer.o stack.o
INCLUDES=lceb.h
DEPS=$(INCLUDES) Makefile

View File

@@ -1,58 +0,0 @@
#include <stdio.h>
#include <signal.h>
#include <sys/time.h>
#include <string.h>
#include "lceb.h"
int sigint_received=0;
static void stopall(signum)
int signum;
{
printf("SIGNAL %d RECEIVED: aborting eval\n", signum);
sigint_received=1;
}
int stopped()
{
return sigint_received;
}
void set_intr()
{
struct sigaction sig;
sig.sa_handler = stopall;
sigemptyset(&sig.sa_mask);
sig.sa_flags = 0;
sigaction(SIGINT, &sig, NULL);
sigaction(SIGALRM, &sig, NULL);
# ifdef DEBUG
printf("SIGINT armed.\n");
# endif
}
void set_alarm(ms)
int ms;
{
struct sigaction sa;
struct itimerval timer;
/* Install timer_handler as the signal handler for SIGVTALRM. */
memset (&sa, 0, sizeof (sa));
sa.sa_handler = stopall;
sigaction (SIGUSR1, &sa, NULL);
timer.it_value.tv_sec = ms/1000;
timer.it_value.tv_usec = (ms%1000)*1000;
# ifdef DEBUG
printf("alarm clock set to %.2f secs.\n",
timer.it_value.tv_sec + timer.it_value.tv_usec / 1000000.);
# endif
/* ... and every 250 msec after that. */
timer.it_interval.tv_sec = 0;
timer.it_interval.tv_usec = 0;
/* Start a virtual timer. It counts down whenever this process is executing. */
setitimer (ITIMER_REAL, &timer, NULL);
}

View File

@@ -29,6 +29,7 @@ double get_timer(timer)
struct timespec timer;
{
double diff;
diff=(timer.tv_sec - start.tv_sec) + (timer.tv_nsec - start.tv_nsec) / NANOSEC;
# ifdef DEBUG_TIMER
printf("timer sec: %.5f\n", diff);