aboutsummaryrefslogtreecommitdiffstats
path: root/package/lqtapi/src/mps/vmmc-alm.h
diff options
context:
space:
mode:
authorJohn Crispin <blogic@openwrt.org>2010-11-03 19:12:34 +0000
committerJohn Crispin <blogic@openwrt.org>2010-11-03 19:12:34 +0000
commitb27571141a7270c79f4e8bde7212797cd2fa8f22 (patch)
tree1b900bd32ce90c62703905c460db950c7c2ba9ec /package/lqtapi/src/mps/vmmc-alm.h
parent5f37a84ad559c0c8101cea2c2d86e4aab0a35404 (diff)
downloadupstream-b27571141a7270c79f4e8bde7212797cd2fa8f22.tar.gz
upstream-b27571141a7270c79f4e8bde7212797cd2fa8f22.tar.bz2
upstream-b27571141a7270c79f4e8bde7212797cd2fa8f22.zip
[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-alm.h')
-rw-r--r--package/lqtapi/src/mps/vmmc-alm.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/package/lqtapi/src/mps/vmmc-alm.h b/package/lqtapi/src/mps/vmmc-alm.h
new file mode 100644
index 0000000000..4e59b6627e
--- /dev/null
+++ b/package/lqtapi/src/mps/vmmc-alm.h
@@ -0,0 +1,42 @@
+#ifndef __VMMC_ALM_H__
+#define __VMMC_ALM_H__
+
+#include "vmmc-module.h"
+
+struct vmmc;
+enum vmmc_alm_state {
+ VMMC_ALM_STATE_OFF = 0 << 16,
+ VMMC_ALM_STATE_ONHOOK = 1 << 16,
+ VMMC_ALM_STATE_RING = 3 << 16,
+ VMMC_ALM_STATE_ACTIVE = 2 << 16,
+};
+
+struct vmmc_alm {
+ struct vmmc *vmmc;
+ unsigned int id;
+
+ enum vmmc_alm_state state;
+
+ struct vmmc_module module;
+
+ uint32_t cmd_cache[3];
+};
+
+struct vmmc_alm_coef {
+ struct list_head list;
+ unsigned int offset;
+ size_t len;
+ uint32_t data[0];
+};
+
+int vmmc_alm_init(struct vmmc_alm *alm, struct vmmc *vmmc, unsigned int id);
+
+int vmmc_alm_set_state(struct vmmc_alm *alm, enum vmmc_alm_state state);
+enum vmmc_alm_state vmmc_alm_get_state(struct vmmc_alm *alm);
+
+int vmcc_alm_set_coefficents(struct vmmc_alm *alm,
+ const struct vmmc_alm_coef *coef_list);
+
+void vmmc_alm_hook_event_handler(struct vmmc *vmmc, uint32_t event, uint32_t data);
+
+#endif