iax2.h 10 KB

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