summaryrefslogtreecommitdiffstats
path: root/package/libtapi/src/tapidemo.c
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/libtapi/src/tapidemo.c
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/libtapi/src/tapidemo.c')
-rw-r--r--package/libtapi/src/tapidemo.c56
1 files changed, 56 insertions, 0 deletions
diff --git a/package/libtapi/src/tapidemo.c b/package/libtapi/src/tapidemo.c
new file mode 100644
index 000000000..63098b89c
--- /dev/null
+++ b/package/libtapi/src/tapidemo.c
@@ -0,0 +1,56 @@
+
+#include <stdbool.h>
+#include <stdlib.h>
+#include <stdio.h>
+#include <sys/ioctl.h>
+#include <fcntl.h>
+#include <errno.h>
+#include <poll.h>
+
+#include <linux/input.h>
+/*#include <sys/timerfd.h>*/
+#include "timerfd.h"
+#include "dialdetector.h"
+
+#include "tapi-ioctl.h"
+
+#include "tapi-device.h"
+#include "tapi-port.h"
+
+static struct tapi_device dev;
+static struct tapi_port ports[2];
+
+void dial_callback(struct tapi_port *port, size_t num_digits, const unsigned char *digits)
+{
+ unsigned int link;
+
+ if (num_digits != 1)
+ return;
+ if (port->id == digits[0] || digits[0] > 1)
+ return;
+
+ tapi_port_set_ring(&ports[digits[0]], true);
+
+ tapi_session_alloc(&dev, port, &ports[digits[0]]);
+}
+
+int main(int argc, char *argv[])
+{
+ struct dialdetector *dd, *dd2;
+ unsigned int link;
+ unsigned char buf[1024];
+ int ret;
+
+ tapi_device_open(0, &dev);
+ tapi_port_open(0, 0, &ports[0]);
+ tapi_port_open(0, 1, &ports[1]);
+
+ dd = dialdetector_alloc(&ports[0]);
+ dd->dial_callback = dial_callback;
+ dd2 = dialdetector_alloc(&ports[1]);
+ dd2->dial_callback = dial_callback;
+
+ tapi_mainloop();
+
+ return 0;
+}