diff options
Diffstat (limited to 'src/irbox.c')
-rw-r--r-- | src/irbox.c | 161 |
1 files changed, 161 insertions, 0 deletions
diff --git a/src/irbox.c b/src/irbox.c new file mode 100644 index 0000000..bd8b719 --- /dev/null +++ b/src/irbox.c @@ -0,0 +1,161 @@ +/* + * + * IRBOX, an Ivy driver for infra-red remote controls + * + * Copyright 1998-1999 + * Centre d'Etudes de la Navigation Aerienne + * + * Main file + * + * Authors: Francois-Regis Colin <fcolin@cenatoulouse.dgac.fr> + * Stephane Chatty <chatty@cenatoulouse.dgac.fr> + * + * $Id$ + * + * Please refer to file version.h for the + * copyright notice regarding this software + */ + +#include <stdio.h> +#include <stdlib.h> +#include <sys/types.h> +#include <sys/ioctl.h> +#include <sys/errno.h> +#include <sys/fcntl.h> +#include <unistd.h> +#include <string.h> +#include <signal.h> + +#include "timer.h" +#include "ivy.h" +#include "ivychannel.h" + +#include "irdev.h" +#include "irtable.h" + +#ifndef DEFAULT_DEVICE +#define DEFAULT_DEVICE "/dev/ttyS1" +#endif + +#ifndef DEFAULT_IRBOX_DIR +#define DEFAULT_IRBOX_DIR "." +#endif + +static const char* data_dir_name = 0; +static const char* app_name; +static IrState *ir; + + +static void +HandleChannel (Channel channel, int fd, void *data) +{ + IrState *ir = (IrState*) data; + IrIntr (ir); +} + +static void* +IrTimeout (IrTimerCallback cb, long value, void *data ) +{ + return TimerRepeatAfter (1, value, (TimerCb) cb, ir); +} + +static void +IrUntimeout (void *id) +{ + TimerRemove ((TimerId) id); +} + +static void +IrHandleHup (int sig) +{ + IrResetTables (); + IrReadTables (data_dir_name); +} + +static void +IrEventCb (IrState *ir, const unsigned char* code) +{ + IrTable* t; + const char* key; + if (IrTableTranslateCode (code, &t, &key)) { + IvySendMsg ("%s Down control=%s button=%s", app_name, t->name, key); + } else { + IvySendMsg ("%s unknown code %.3d %.3d %.3d %.3d %.3d %.3d", app_name, code[0], code[1],code[2],code[3],code[4],code[5]); + fprintf (stderr, "unknown code %.3d %.3d %.3d %.3d %.3d %.3d\n", code[0], code[1],code[2],code[3],code[4],code[5]); + } +} + +static void +IrFailCb (IrState* ir) +{ + fprintf(stderr,"IR box not responding.\n"); + IvySendMsg ("%s Failed", app_name); + IvyStop (); +} + +int +main (int argc, char *argv[]) +{ + unsigned short bport = DEFAULT_BUS; + int c; + const char* dev = DEFAULT_DEVICE; + const char* domains = 0; + static char app_name_buf [1024]; + struct sigaction act; + + while ((c = getopt(argc, argv, "s:b:n:p:d:")) != EOF) + switch (c) { + case 'b': + bport = atoi(optarg) ; + break; + case 's': + dev = optarg; + break; + case 'd': + domains = optarg; + break; + case 'n': + app_name = optarg; + break; + case 'p': + data_dir_name = optarg; + break; + } + + if (!app_name) { + gethostname (app_name_buf, 1024); + strcat (app_name_buf, ".IRBOX"); + app_name = app_name_buf; + } + + /* data directory */ + if (!data_dir_name) + data_dir_name = getenv ("IRBOX_DIR"); + if (!data_dir_name) + data_dir_name = DEFAULT_IRBOX_DIR; + + ir = IrOpen (dev); + if (!ir) { + fprintf (stderr, "Can't open %s\n", dev); + return -1; + } + + if (!IrInit (ir, IrEventCb, IrFailCb, IrTimeout, IrUntimeout)) + return -1; + + /* Let's read tables and provide for their re-reading on SIGHUP */ + IrReadTables (data_dir_name); + act.sa_handler = IrHandleHup; + sigemptyset (&act.sa_mask); + act.sa_flags = 0; + sigaction (1, &act, 0); + + + IvyInit (app_name, bport, 0, 0, 0, 0, 0); + IvyChannelSetUp (IrGetFd (ir), ir, 0, HandleChannel); + + IvyStart (domains); + IvyMainLoop (0); + + return 0 ; +} |