summaryrefslogtreecommitdiffstats
path: root/package/lqtapi/src/mps/vmmc-port.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/lqtapi/src/mps/vmmc-port.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/lqtapi/src/mps/vmmc-port.c')
-rw-r--r--package/lqtapi/src/mps/vmmc-port.c48
1 files changed, 48 insertions, 0 deletions
diff --git a/package/lqtapi/src/mps/vmmc-port.c b/package/lqtapi/src/mps/vmmc-port.c
new file mode 100644
index 000000000..aa620a1e0
--- /dev/null
+++ b/package/lqtapi/src/mps/vmmc-port.c
@@ -0,0 +1,48 @@
+#include <linux/kernel.h>
+#include <linux/slab.h>
+
+#include <linux/tapi/tapi.h>
+
+#include "vmmc.h"
+#include "vmmc-port.h"
+#include "vmmc-alm.h"
+#include "vmmc-sig.h"
+
+int vmmc_port_ring(struct tapi_device *tdev, struct tapi_port *port, bool ring)
+{
+ struct vmmc *vmmc = tdev_to_vmmc(tdev);
+
+ return vmmc_alm_set_state(&vmmc->ports[port->id].alm,
+ ring ? VMMC_ALM_STATE_RING : VMMC_ALM_STATE_ONHOOK);
+}
+
+int vmmc_port_send_dtmf_event(struct tapi_device *tdev,
+ struct tapi_port *port, struct tapi_dtmf_event *event)
+{
+ return 0;
+}
+
+struct vmmc_port *vmmc_port_init(struct vmmc *vmmc, struct vmmc_port *port,
+ struct tapi_port *tport, unsigned int id)
+{
+ vmmc_alm_init(&port->alm, vmmc, id);
+ vmmc_sig_init(&port->sig, vmmc, id);
+
+ port->sig_pin = vmmc_module_get_pin(&port->sig.module);
+ vmmc_module_set_pin_input(&port->sig.module, port->sig_pin,
+ &port->alm.module);
+
+ vmmc_module_sync(&port->sig.module);
+
+ vmmc_alm_set_state(&port->alm, VMMC_ALM_STATE_ONHOOK);
+
+ tport->id = id;
+ tapi_endpoint_set_data(&tport->ep, &port->alm.module);
+
+ return port;
+}
+
+void vmmc_port_put(struct vmmc *vmmc, struct vmmc_port *port)
+{
+ vmmc_module_put_pin(&port->sig.module, port->sig_pin);
+}