summaryrefslogtreecommitdiff
path: root/package/tapi_sip/src/dialdetector.h
diff options
context:
space:
mode:
authorblogic <blogic@3c298f89-4303-0410-b956-a3cf2f4a3e73>2010-11-03 19:12:34 +0000
committerblogic <blogic@3c298f89-4303-0410-b956-a3cf2f4a3e73>2010-11-03 19:12:34 +0000
commit6ea7ec75d2fe0dd52bc3e86135412bfc92c3158c (patch)
tree1b900bd32ce90c62703905c460db950c7c2ba9ec /package/tapi_sip/src/dialdetector.h
parent74f6f2f5a244b9ba7aec5d7114fe763f8c20e96c (diff)
[ifxmips]
* adds a rewrite of the tapi drivers + sip app. this is the result of lars' gsoc 2010 project, Thanks ! git-svn-id: svn://svn.openwrt.org/openwrt/trunk@23840 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/tapi_sip/src/dialdetector.h')
-rw-r--r--package/tapi_sip/src/dialdetector.h49
1 files changed, 49 insertions, 0 deletions
diff --git a/package/tapi_sip/src/dialdetector.h b/package/tapi_sip/src/dialdetector.h
new file mode 100644
index 0000000000..c3737c36e9
--- /dev/null
+++ b/package/tapi_sip/src/dialdetector.h
@@ -0,0 +1,49 @@
+#include <linux/input.h>
+#include <sys/epoll.h>
+#include <stdint.h>
+#include <stdbool.h>
+
+
+#include <stdlib.h>
+#include <stdio.h>
+
+#include "events.h"
+#include "timerfd.h"
+
+#include "tapi-port.h"
+
+enum dialdetector_dial_state {
+ DIALDETECTOR_DIAL_WAIT = 1,
+ DIALDETECTOR_DIAL_WAIT_TIMEOUT = 2,
+};
+
+enum dialdetector_port_state {
+ DIALDETECTOR_PORT_INACTIVE = 0,
+ DIALDETECTOR_PORT_ACTIVE = 1,
+ DIALDETECTOR_PORT_ACTIVE_DOWN = 2,
+};
+
+struct dialdetector {
+ enum dialdetector_dial_state dial_state;
+ enum dialdetector_port_state port_state;
+
+ struct tapi_port *port;
+ int timer_fd;
+ int impulse_timer_fd;
+
+ struct event_callback timeout_cb;
+ struct event_callback impulse_cb;
+ struct tapi_port_event_listener port_listener;
+
+ size_t num_digits;
+ unsigned char digits[20];
+
+ unsigned int impulses;
+
+ void (*dial_callback)(struct tapi_port *port, size_t num_digits, const unsigned char *digits);
+};
+
+
+struct tapi_port;
+
+struct dialdetector *dialdetector_alloc(struct tapi_port *port);