ath9k: merge a few bugfixes
[openwrt/svn-archive/archive.git] / package / lqtapi / src / mps / vmmc-cmds.h
1 #ifndef __VMMC_CMDS_H__
2 #define __VMMC_CMDS_H__
3
4 #define _VMMC_CMD(_x) ((_x) << 24)
5 #define _VMMC_MOD(_x) ((_x) << 13)
6 #define _VMMC_ECMD(_x) ((_x) << 8)
7
8 #define _VMMC_MSG(_cmd, _mod, _ecmd) \
9 (_VMMC_CMD(_cmd) | _VMMC_ECMD(_ecmd) | _VMMC_MOD(_mod))
10
11 #define _VMMC_CHAN(_chan) ((_chan) << 16)
12 #define _VMMC_LENGTH(_length) ((_length) << 2)
13
14 #define VMMC_CMD_OPMODE(_chan) (_VMMC_MSG(1, 0, 0) | _VMMC_CHAN(_chan) | _VMMC_LENGTH(1))
15
16 #define VMMC_CMD_SIG(_chan) (_VMMC_MSG(6, 2, 1) | _VMMC_CHAN(_chan) | _VMMC_LENGTH(1))
17 #define VMMC_CMD_SIG_DATA(_enable, _event, _rate, _i1, _i2, _mute1, _mute2) \
18 (((_enable) << 31) | ((_event) << 30) | ((_i1) << 24) | ((_i2) << 16) | \
19 ((_rate) << 23) | ((_mute1) << 15) | ((_mute2) << 14))
20
21 #define VMMC_CMD_SIG_SET_ENABLE(_data, _enable) (((_data) & ~BIT(31)) | ((_enable) << 31))
22 #define VMMC_CMD_SIG_SET_INPUTS(_data, _i1, _i2) (((_data) & ~0x3f3f0000) | \
23 ((_i1) << 24) | ((_i2) << 16))
24
25 #define VMMC_CMD_DTMFR(_chan) (_VMMC_MSG(6, 2, 4) | _VMMC_CHAN(_chan) | _VMMC_LENGTH(1))
26 #define VMMC_CMD_DTMFR_DATA(_enable, _event, _nr) \
27 (((_enable) << 31) | ((_event) << 30) | (6 << 27) | ((_nr) << 16))
28
29 #define VMMC_CMD_CODER(_chan) (_VMMC_MSG(6, 3, 1) | _VMMC_CHAN(_chan) | _VMMC_LENGTH(4))
30
31 #define VMMC_CMD_CODER_DATA1(_enable, _rate, _ns, _pte, _nr, _i1, _hp, _pf, \
32 _cng, _bfi, _dec, _im, _pst, _sic, _em, _enc) \
33 (((_enable) << 31) | ((_rate) << 30) | ((_ns) << 29) | ((_pte) << 26) | \
34 ((_nr) << 22) | ((_i1) << 16) | ((_hp) << 15) | ((_pf) << 14) | \
35 ((_cng) << 13) | ((_bfi) << 12) | ((_dec) << 11) | ((_im) << 10) | \
36 ((_pst) << 9) | ((_sic) << 8) | ((_em) << 7) | (_enc))
37
38 #define VMMC_CMD_CODER_DATA2(_gain1, _gain2) (((_gain1) << 16) | (_gain2))
39
40 #define VMMC_CMD_CODER_DATA3(_de, _ee, _i2, _red, _i3, _plc, _i4, _i5) \
41 (((_de) << 31) | ((_ee) << 30) | ((_i2) << 24) | ((_red) << 22) | \
42 ((_i3) << 16) | ((_plc) << 15) | ((_i4) << 8) | (_i5))
43
44 #define VMMC_CMD_SERR_ACK(_chan) _VMMC_MSG(6, 7, 1) | _VMMC_CHAN(_chan) | _VMMC_LENGTH(1)
45
46 #define VMMC_CMD_SERR_ACK_DATA1(_foo) ((_foo) << 22)
47
48 #define VMMC_CMD_CODER_DATA4(_tsf) ((_tsf) << 31)
49
50 #define VMMC_EVENT_ID_MASK (_VMMC_MSG(0x1f, 0x7, 0x1f) | 0xff)
51
52 #define VMMC_MSG_GET_CHAN(_msg) (((_msg) >> 16) & 0x1f)
53
54 #define VMMC_EVENT_HOOK_STATE(_data) ((_data) & 1)
55
56 #define VMMC_EVENT_HOOK_ID (_VMMC_MSG(9, 1, 1) | _VMMC_LENGTH(1))
57 #define VMMC_EVENT_DTMF_ID (_VMMC_MSG(9, 2, 0) | _VMMC_LENGTH(1))
58
59 #define VMMC_VOICE_DATA(_type, _chan, _len) (((_type) << 24) | ((_chan) << 16) \
60 | (_len))
61
62
63 #define VMMC_CMD_ALI(_chan) (_VMMC_MSG(6, 1, 1) | _VMMC_CHAN(_chan) | _VMMC_LENGTH(3))
64
65 #define VMMC_CMD_ALI_DATA1(_enable, _rate, _ud, _eh, _eo, _i1, _dg1) \
66 (((_enable) << 31) | ((_rate) << 30) | ((_ud) << 29) | ((_eh) << 27) | \
67 ((_eo) << 26) | ((_i1) << 16) | (_dg1))
68
69 #define VMMC_CMD_ALI_DATA2(_dg2, _i2, _i3) \
70 (((_dg2) << 16) | ((_i2) << 8) | (_i3))
71
72 #define VMMC_CMD_ALI_DATA3(_i4, _i5) \
73 (((_i4) << 24) | ((_i5) << 16))
74
75 #define VMMC_CMD_ALM_COEF(_chan, _offset, _len) \
76 (_VMMC_MSG(2, 0, _offset) | _VMMC_CHAN(_chan) | (_len))
77
78 #define CMD_VOICEREC_STATUS_PACKET 0x0
79 #define CMD_VOICEREC_DATA_PACKET 0x1
80 #define CMD_RTP_VOICE_DATA_PACKET 0x4
81 #define CMD_RTP_EVENT_PACKET 0x5
82 #define CMD_ADDRESS_PACKET 0x8
83 #define CMD_FAX_DATA_PACKET 0x10
84 #define CMD_FAX_STATUS_PACKET 0x11
85 #define CMD_P_PHONE_DATA_PACKET 0x12
86 #define CMD_P_PHONE_STATUS_PACKET 0x13
87
88 #define VMMC_CMD_RTP_CFG_US(_chan) \
89 (_VMMC_MSG(6, 3, 17) | _VMMC_CHAN(_chan) | (36))
90 #define VMMC_CMD_RTP_CFG_DS(_chan) \
91 (_VMMC_MSG(6, 3, 25) | _VMMC_CHAN(_chan) | (32))
92
93 #define VMMC_CMD_LEC(_chan) \
94 (_VMMC_MSG(6, 2, 1) | _VMMC_CHAN(_chan) | _VMMC_LENGTH(1))
95 // (_VMMC_MSG(CMD_EOP, ALI_LEC_ECMD, MOD_ALI) | _VMMC_CHAN(_chan) | (32))
96
97 #define VMMC_CMD_LEC_DATA()
98 #endif