iax2.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. /*
  2. * Asterisk -- A telephony toolkit for Linux.
  3. *
  4. * Implementation of Inter-Asterisk eXchange
  5. *
  6. * Copyright (C) 2003, Digium
  7. *
  8. * Mark Spencer <markster@linux-support.net>
  9. *
  10. * This program is free software, distributed under the terms of
  11. * the GNU General Public License
  12. */
  13. /*! \file
  14. * \brief
  15. *
  16. * Implementation of Inter-Asterisk eXchange, version 2
  17. * \ref iax2-parser.c
  18. * \ref iax2-parser.h
  19. * \ref chan_iax2.c
  20. */
  21. #ifndef _IAX2_H
  22. #define _IAX2_H
  23. /* Max version of IAX protocol we support */
  24. #define IAX_PROTO_VERSION 2
  25. /* NOTE: IT IS CRITICAL THAT IAX_MAX_CALLS BE A POWER OF 2. */
  26. #if defined(LOW_MEMORY)
  27. #define IAX_MAX_CALLS 2048
  28. #else
  29. #define IAX_MAX_CALLS 32768
  30. #endif
  31. #define IAX_FLAG_FULL 0x8000
  32. #define IAX_FLAG_RETRANS 0x8000
  33. #define IAX_FLAG_SC_LOG 0x80
  34. #define IAX_MAX_SHIFT 0x3F
  35. #define IAX_WINDOW 64
  36. /*! Subclass for AST_FRAME_IAX */
  37. enum iax_frame_subclass {
  38. IAX_COMMAND_NEW = 1,
  39. IAX_COMMAND_PING = 2,
  40. IAX_COMMAND_PONG = 3,
  41. IAX_COMMAND_ACK = 4,
  42. IAX_COMMAND_HANGUP = 5,
  43. IAX_COMMAND_REJECT = 6,
  44. IAX_COMMAND_ACCEPT = 7,
  45. IAX_COMMAND_AUTHREQ = 8,
  46. IAX_COMMAND_AUTHREP = 9,
  47. IAX_COMMAND_INVAL = 10,
  48. IAX_COMMAND_LAGRQ = 11,
  49. IAX_COMMAND_LAGRP = 12,
  50. /*! Registration request */
  51. IAX_COMMAND_REGREQ = 13,
  52. /*! Registration authentication required */
  53. IAX_COMMAND_REGAUTH = 14,
  54. /*! Registration accepted */
  55. IAX_COMMAND_REGACK = 15,
  56. /*! Registration rejected */
  57. IAX_COMMAND_REGREJ = 16,
  58. /*! Force release of registration */
  59. IAX_COMMAND_REGREL = 17,
  60. /*! If we receive voice before valid first voice frame, send this */
  61. IAX_COMMAND_VNAK = 18,
  62. /*! Request status of a dialplan entry */
  63. IAX_COMMAND_DPREQ = 19,
  64. /*! Request status of a dialplan entry */
  65. IAX_COMMAND_DPREP = 20,
  66. /*! Request a dial on channel brought up TBD */
  67. IAX_COMMAND_DIAL = 21,
  68. /*! Transfer Request */
  69. IAX_COMMAND_TXREQ = 22,
  70. /*! Transfer Connect */
  71. IAX_COMMAND_TXCNT = 23,
  72. /*! Transfer Accepted */
  73. IAX_COMMAND_TXACC = 24,
  74. /*! Transfer ready */
  75. IAX_COMMAND_TXREADY = 25,
  76. /*! Transfer release */
  77. IAX_COMMAND_TXREL = 26,
  78. /*! Transfer reject */
  79. IAX_COMMAND_TXREJ = 27,
  80. /*! Stop audio/video transmission */
  81. IAX_COMMAND_QUELCH = 28,
  82. /*! Resume audio/video transmission */
  83. IAX_COMMAND_UNQUELCH = 29,
  84. /*! Like ping, but does not require an open connection */
  85. IAX_COMMAND_POKE = 30,
  86. /*! Paging description */
  87. IAX_COMMAND_PAGE = 31,
  88. /*! Stand-alone message waiting indicator */
  89. IAX_COMMAND_MWI = 32,
  90. /*! Unsupported message received */
  91. IAX_COMMAND_UNSUPPORT = 33,
  92. /*! Request remote transfer */
  93. IAX_COMMAND_TRANSFER = 34,
  94. /*! Provision device */
  95. IAX_COMMAND_PROVISION = 35,
  96. /*! Download firmware */
  97. IAX_COMMAND_FWDOWNL = 36,
  98. /*! Firmware Data */
  99. IAX_COMMAND_FWDATA = 37,
  100. /*! Transfer media only */
  101. IAX_COMMAND_TXMEDIA = 38,
  102. /*! Command to rotate key */
  103. IAX_COMMAND_RTKEY = 39,
  104. /*! Call number token */
  105. IAX_COMMAND_CALLTOKEN = 40,
  106. };
  107. /*! By default require re-registration once per minute */
  108. #define IAX_DEFAULT_REG_EXPIRE 60
  109. /*! How long to wait before closing bridged call */
  110. #define IAX_LINGER_TIMEOUT 10
  111. #define IAX_DEFAULT_PORTNO 4569
  112. /*! IAX Information elements */
  113. #define IAX_IE_CALLED_NUMBER 1 /*!< Number/extension being called - string */
  114. #define IAX_IE_CALLING_NUMBER 2 /*!< Calling number - string */
  115. #define IAX_IE_CALLING_ANI 3 /*!< Calling number ANI for billing - string */
  116. #define IAX_IE_CALLING_NAME 4 /*!< Name of caller - string */
  117. #define IAX_IE_CALLED_CONTEXT 5 /*!< Context for number - string */
  118. #define IAX_IE_USERNAME 6 /*!< Username (peer or user) for authentication - string */
  119. #define IAX_IE_PASSWORD 7 /*!< Password for authentication - string */
  120. #define IAX_IE_CAPABILITY 8 /*!< Actual codec capability - unsigned int */
  121. #define IAX_IE_FORMAT 9 /*!< Desired codec format - unsigned int */
  122. #define IAX_IE_LANGUAGE 10 /*!< Desired language - string */
  123. #define IAX_IE_VERSION 11 /*!< Protocol version - short */
  124. #define IAX_IE_ADSICPE 12 /*!< CPE ADSI capability - short */
  125. #define IAX_IE_DNID 13 /*!< Originally dialed DNID - string */
  126. #define IAX_IE_AUTHMETHODS 14 /*!< Authentication method(s) - short */
  127. #define IAX_IE_CHALLENGE 15 /*!< Challenge data for MD5/RSA - string */
  128. #define IAX_IE_MD5_RESULT 16 /*!< MD5 challenge result - string */
  129. #define IAX_IE_RSA_RESULT 17 /*!< RSA challenge result - string */
  130. #define IAX_IE_APPARENT_ADDR 18 /*!< Apparent address of peer - struct sockaddr_in */
  131. #define IAX_IE_REFRESH 19 /*!< When to refresh registration - short */
  132. #define IAX_IE_DPSTATUS 20 /*!< Dialplan status - short */
  133. #define IAX_IE_CALLNO 21 /*!< Call number of peer - short */
  134. #define IAX_IE_CAUSE 22 /*!< Cause - string */
  135. #define IAX_IE_IAX_UNKNOWN 23 /*!< Unknown IAX command - byte */
  136. #define IAX_IE_MSGCOUNT 24 /*!< How many messages waiting - short */
  137. #define IAX_IE_AUTOANSWER 25 /*!< Request auto-answering -- none */
  138. #define IAX_IE_MUSICONHOLD 26 /*!< Request musiconhold with QUELCH -- none or string */
  139. #define IAX_IE_TRANSFERID 27 /*!< Transfer Request Identifier -- int */
  140. #define IAX_IE_RDNIS 28 /*!< Referring DNIS -- string */
  141. #define IAX_IE_PROVISIONING 29 /*!< Provisioning info */
  142. #define IAX_IE_AESPROVISIONING 30 /*!< AES Provisioning info */
  143. #define IAX_IE_DATETIME 31 /*!< Date/Time */
  144. #define IAX_IE_DEVICETYPE 32 /*!< Device Type -- string */
  145. #define IAX_IE_SERVICEIDENT 33 /*!< Service Identifier -- string */
  146. #define IAX_IE_FIRMWAREVER 34 /*!< Firmware revision -- u16 */
  147. #define IAX_IE_FWBLOCKDESC 35 /*!< Firmware block description -- u32 */
  148. #define IAX_IE_FWBLOCKDATA 36 /*!< Firmware block of data -- raw */
  149. #define IAX_IE_PROVVER 37 /*!< Provisioning Version (u32) */
  150. #define IAX_IE_CALLINGPRES 38 /*!< Calling presentation (u8) */
  151. #define IAX_IE_CALLINGTON 39 /*!< Calling type of number (u8) */
  152. #define IAX_IE_CALLINGTNS 40 /*!< Calling transit network select (u16) */
  153. #define IAX_IE_SAMPLINGRATE 41 /*!< Supported sampling rates (u16) */
  154. #define IAX_IE_CAUSECODE 42 /*!< Hangup cause (u8) */
  155. #define IAX_IE_ENCRYPTION 43 /*!< Encryption format (u16) */
  156. #define IAX_IE_ENCKEY 44 /*!< Encryption key (raw) */
  157. #define IAX_IE_CODEC_PREFS 45 /*!< Codec Negotiation */
  158. #define IAX_IE_RR_JITTER 46 /*!< Received jitter (as in RFC1889) u32 */
  159. #define IAX_IE_RR_LOSS 47 /*!< Received loss (high byte loss pct, low 24 bits loss count, as in rfc1889 */
  160. #define IAX_IE_RR_PKTS 48 /*!< Received frames (total frames received) u32 */
  161. #define IAX_IE_RR_DELAY 49 /*!< Max playout delay for received frames (in ms) u16 */
  162. #define IAX_IE_RR_DROPPED 50 /*!< Dropped frames (presumably by jitterbuf) u32 */
  163. #define IAX_IE_RR_OOO 51 /*!< Frames received Out of Order u32 */
  164. #define IAX_IE_VARIABLE 52 /*!< Remote variables */
  165. #define IAX_IE_OSPTOKEN 53 /*!< OSP token */
  166. #define IAX_IE_CALLTOKEN 54 /*!< Call number security token */
  167. #define IAX_IE_CAPABILITY2 55 /*!< Actual codec capability - u8 version + integer array */
  168. #define IAX_IE_FORMAT2 56 /*!< Desired codec format - u8 version + integer array */
  169. #define IAX_MAX_OSPBLOCK_SIZE 254 /*!< Max OSP token block size, 255 bytes - 1 byte OSP token block index */
  170. #define IAX_MAX_OSPBLOCK_NUM 4
  171. #define IAX_MAX_OSPTOKEN_SIZE (IAX_MAX_OSPBLOCK_SIZE * IAX_MAX_OSPBLOCK_NUM)
  172. #define IAX_MAX_OSPBUFF_SIZE (IAX_MAX_OSPTOKEN_SIZE + 16)
  173. #define IAX_AUTH_PLAINTEXT (1 << 0)
  174. #define IAX_AUTH_MD5 (1 << 1)
  175. #define IAX_AUTH_RSA (1 << 2)
  176. #define IAX_ENCRYPT_AES128 (1 << 0)
  177. #define IAX_ENCRYPT_KEYROTATE (1 << 15) /*!< Keyrotation support */
  178. #define IAX_META_TRUNK 1 /*!< Trunk meta-message */
  179. #define IAX_META_VIDEO 2 /*!< Video frame */
  180. #define IAX_META_TRUNK_SUPERMINI 0 /*!< This trunk frame contains classic supermini frames */
  181. #define IAX_META_TRUNK_MINI 1 /*!< This trunk frame contains trunked mini frames */
  182. #define IAX_RATE_8KHZ (1 << 0) /*!< 8khz sampling (default if absent) */
  183. #define IAX_RATE_11KHZ (1 << 1) /*!< 11.025khz sampling */
  184. #define IAX_RATE_16KHZ (1 << 2) /*!< 16khz sampling */
  185. #define IAX_RATE_22KHZ (1 << 3) /*!< 22.05khz sampling */
  186. #define IAX_RATE_44KHZ (1 << 4) /*!< 44.1khz sampling */
  187. #define IAX_RATE_48KHZ (1 << 5) /*!< 48khz sampling */
  188. #define IAX_DPSTATUS_EXISTS (1 << 0)
  189. #define IAX_DPSTATUS_CANEXIST (1 << 1)
  190. #define IAX_DPSTATUS_NONEXISTENT (1 << 2)
  191. #define IAX_DPSTATUS_IGNOREPAT (1 << 14)
  192. #define IAX_DPSTATUS_MATCHMORE (1 << 15)
  193. /*! iax2 format bit field for handling codecs the old way */
  194. typedef int64_t iax2_format;
  195. /*!\brief iax2 wrapper function for ast_getformatname */
  196. const char *iax2_getformatname(iax2_format format);
  197. /*! Full frames are always delivered reliably */
  198. struct ast_iax2_full_hdr {
  199. unsigned short scallno; /*!< Source call number -- high bit must be 1 */
  200. unsigned short dcallno; /*!< Destination call number -- high bit is 1 if retransmission */
  201. unsigned int ts; /*!< 32-bit timestamp in milliseconds (from 1st transmission) */
  202. unsigned char oseqno; /*!< Packet number (outgoing) */
  203. unsigned char iseqno; /*!< Packet number (next incoming expected) */
  204. unsigned char type; /*!< Frame type */
  205. unsigned char csub; /*!< Compressed subclass */
  206. unsigned char iedata[0];
  207. } __attribute__ ((__packed__));
  208. /*! Full frames are always delivered reliably */
  209. struct ast_iax2_full_enc_hdr {
  210. unsigned short scallno; /*!< Source call number -- high bit must be 1 */
  211. unsigned short dcallno; /*!< Destination call number -- high bit is 1 if retransmission */
  212. unsigned char encdata[0];
  213. } __attribute__ ((__packed__));
  214. /*! Mini header is used only for voice frames -- delivered unreliably */
  215. struct ast_iax2_mini_hdr {
  216. unsigned short callno; /*!< Source call number -- high bit must be 0, rest must be non-zero */
  217. unsigned short ts; /*!< 16-bit Timestamp (high 16 bits from last ast_iax2_full_hdr) */
  218. /* Frametype implicitly VOICE_FRAME */
  219. /* subclass implicit from last ast_iax2_full_hdr */
  220. unsigned char data[0];
  221. } __attribute__ ((__packed__));
  222. /*! Mini header is used only for voice frames -- delivered unreliably */
  223. struct ast_iax2_mini_enc_hdr {
  224. unsigned short callno; /*!< Source call number -- high bit must be 0, rest must be non-zero */
  225. unsigned char encdata[0];
  226. } __attribute__ ((__packed__));
  227. struct ast_iax2_meta_hdr {
  228. unsigned short zeros; /*!< Zeros field -- must be zero */
  229. unsigned char metacmd; /*!< Meta command */
  230. unsigned char cmddata; /*!< Command Data */
  231. unsigned char data[0];
  232. } __attribute__ ((__packed__));
  233. struct ast_iax2_video_hdr {
  234. unsigned short zeros; /*!< Zeros field -- must be zero */
  235. unsigned short callno; /*!< Video call number */
  236. unsigned short ts; /*!< Timestamp and mark if present */
  237. unsigned char data[0];
  238. } __attribute__ ((__packed__));
  239. struct ast_iax2_meta_trunk_hdr {
  240. unsigned int ts; /*!< 32-bit timestamp for all messages */
  241. unsigned char data[0];
  242. } __attribute__ ((__packed__));
  243. struct ast_iax2_meta_trunk_entry {
  244. unsigned short callno; /*!< Call number */
  245. unsigned short len; /*!< Length of data for this callno */
  246. } __attribute__ ((__packed__));
  247. /*! When trunktimestamps are used, we use this format instead */
  248. struct ast_iax2_meta_trunk_mini {
  249. unsigned short len;
  250. struct ast_iax2_mini_hdr mini; /*!< this is an actual miniframe */
  251. } __attribute__ ((__packed__));
  252. #define IAX_FIRMWARE_MAGIC 0x69617879
  253. struct ast_iax2_firmware_header {
  254. unsigned int magic; /*!< Magic number */
  255. unsigned short version; /*!< Software version */
  256. unsigned char devname[16]; /*!< Device */
  257. unsigned int datalen; /*!< Data length of file beyond header */
  258. unsigned char chksum[16]; /*!< Checksum of all data */
  259. unsigned char data[0];
  260. } __attribute__ ((__packed__));
  261. #endif