mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-11-03 20:38:59 +00:00 
			
		
		
		
	This patch just moves the IAX2 source and header files into a separate iax2 sub-directory in the channels directory, similar to how the sip source files are structured. The only thing that was added was an #ifndef to protect provision.h from multiple inclusion. git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@380433 65c4cc65-6c06-0410-ace0-fbb531ad65f3
		
			
				
	
	
		
			302 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			302 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * Asterisk -- An open source telephony toolkit.
 | 
						|
 *
 | 
						|
 * Implementation of Inter-Asterisk eXchange
 | 
						|
 * 
 | 
						|
 * Copyright (C) 2003, Digium
 | 
						|
 *
 | 
						|
 * Mark Spencer <markster@linux-support.net>
 | 
						|
 *
 | 
						|
 * This program is free software, distributed under the terms of
 | 
						|
 * the GNU General Public License
 | 
						|
 */
 | 
						|
 | 
						|
/*! \file
 | 
						|
 * \brief
 | 
						|
 *
 | 
						|
 * Implementation of Inter-Asterisk eXchange, version 2
 | 
						|
 * \ref iax2-parser.c
 | 
						|
 * \ref iax2-parser.h
 | 
						|
 * \ref chan_iax2.c
 | 
						|
 */
 | 
						|
 
 | 
						|
#ifndef _IAX2_H
 | 
						|
#define _IAX2_H
 | 
						|
 | 
						|
/* Max version of IAX protocol we support */
 | 
						|
#define IAX_PROTO_VERSION 2
 | 
						|
 | 
						|
/* NOTE: It is recommended that IAX_MAX_CALLS be a power of 2, but it is not
 | 
						|
 * required.  The maximum number of calls supported by the protocol is 32768.
 | 
						|
 *
 | 
						|
 * For LOW_MEMORY, we use 2049 for compatibility with earlier code because
 | 
						|
 * callno 2048 leaked out when the intended callno range was 2 - 2047. */
 | 
						|
#if defined(LOW_MEMORY)
 | 
						|
#define IAX_MAX_CALLS 2049
 | 
						|
#else
 | 
						|
#define IAX_MAX_CALLS 32768
 | 
						|
#endif
 | 
						|
 | 
						|
#define IAX_FLAG_FULL		0x8000
 | 
						|
 | 
						|
#define IAX_FLAG_RETRANS	0x8000
 | 
						|
 | 
						|
#define IAX_FLAG_SC_LOG		0x80
 | 
						|
 | 
						|
#define IAX_MAX_SHIFT		0x3F
 | 
						|
 | 
						|
#define IAX_WINDOW			64
 | 
						|
 | 
						|
/*! Subclass for AST_FRAME_IAX */
 | 
						|
enum iax_frame_subclass {
 | 
						|
	IAX_COMMAND_NEW =       1,
 | 
						|
	IAX_COMMAND_PING =      2,
 | 
						|
	IAX_COMMAND_PONG =      3,
 | 
						|
	IAX_COMMAND_ACK =       4,
 | 
						|
	IAX_COMMAND_HANGUP =    5,
 | 
						|
	IAX_COMMAND_REJECT =    6,
 | 
						|
	IAX_COMMAND_ACCEPT =    7,
 | 
						|
	IAX_COMMAND_AUTHREQ =   8,
 | 
						|
	IAX_COMMAND_AUTHREP =   9,
 | 
						|
	IAX_COMMAND_INVAL =     10,
 | 
						|
	IAX_COMMAND_LAGRQ =     11,
 | 
						|
	IAX_COMMAND_LAGRP =     12,
 | 
						|
	/*! Registration request */
 | 
						|
	IAX_COMMAND_REGREQ =    13,
 | 
						|
	/*! Registration authentication required */
 | 
						|
	IAX_COMMAND_REGAUTH =   14,
 | 
						|
	/*! Registration accepted */
 | 
						|
	IAX_COMMAND_REGACK =    15,
 | 
						|
	/*! Registration rejected */
 | 
						|
	IAX_COMMAND_REGREJ =    16,
 | 
						|
	/*! Force release of registration */
 | 
						|
	IAX_COMMAND_REGREL =    17,
 | 
						|
	/*! If we receive voice before valid first voice frame, send this */
 | 
						|
	IAX_COMMAND_VNAK =      18,
 | 
						|
	/*! Request status of a dialplan entry */
 | 
						|
	IAX_COMMAND_DPREQ =     19,
 | 
						|
	/*! Request status of a dialplan entry */
 | 
						|
	IAX_COMMAND_DPREP =     20,
 | 
						|
	/*! Request a dial on channel brought up TBD */
 | 
						|
	IAX_COMMAND_DIAL =      21,
 | 
						|
	/*! Transfer Request */
 | 
						|
	IAX_COMMAND_TXREQ =     22,
 | 
						|
	/*! Transfer Connect */
 | 
						|
	IAX_COMMAND_TXCNT =     23,
 | 
						|
	/*! Transfer Accepted */
 | 
						|
	IAX_COMMAND_TXACC =     24,
 | 
						|
	/*! Transfer ready */
 | 
						|
	IAX_COMMAND_TXREADY =   25,
 | 
						|
	/*! Transfer release */
 | 
						|
	IAX_COMMAND_TXREL =     26,
 | 
						|
	/*! Transfer reject */
 | 
						|
	IAX_COMMAND_TXREJ =     27,
 | 
						|
	/*! Stop audio/video transmission */
 | 
						|
	IAX_COMMAND_QUELCH =    28,
 | 
						|
	/*! Resume audio/video transmission */
 | 
						|
	IAX_COMMAND_UNQUELCH =  29,
 | 
						|
	/*! Like ping, but does not require an open connection */
 | 
						|
	IAX_COMMAND_POKE =      30,
 | 
						|
	/*! Paging description */
 | 
						|
	IAX_COMMAND_PAGE =      31,
 | 
						|
	/*! Stand-alone message waiting indicator */
 | 
						|
	IAX_COMMAND_MWI =       32,
 | 
						|
	/*! Unsupported message received */
 | 
						|
	IAX_COMMAND_UNSUPPORT = 33,
 | 
						|
	/*! Request remote transfer */
 | 
						|
	IAX_COMMAND_TRANSFER =  34,
 | 
						|
	/*! Provision device */
 | 
						|
	IAX_COMMAND_PROVISION = 35,
 | 
						|
	/*! Download firmware */
 | 
						|
	IAX_COMMAND_FWDOWNL =   36,
 | 
						|
	/*! Firmware Data */
 | 
						|
	IAX_COMMAND_FWDATA =    37,
 | 
						|
	/*! Transfer media only */
 | 
						|
	IAX_COMMAND_TXMEDIA =   38,
 | 
						|
	/*! Command to rotate key */
 | 
						|
	IAX_COMMAND_RTKEY =     39,
 | 
						|
	/*! Call number token */
 | 
						|
	IAX_COMMAND_CALLTOKEN = 40,
 | 
						|
};
 | 
						|
 | 
						|
/*! By default require re-registration once per minute */
 | 
						|
#define IAX_DEFAULT_REG_EXPIRE  60
 | 
						|
 | 
						|
/*! How long to wait before closing bridged call */
 | 
						|
#define IAX_LINGER_TIMEOUT		10
 | 
						|
 | 
						|
#define IAX_DEFAULT_PORTNO		4569
 | 
						|
 | 
						|
/*! IAX Information elements */
 | 
						|
#define IAX_IE_CALLED_NUMBER		1		/*!< Number/extension being called - string */
 | 
						|
#define IAX_IE_CALLING_NUMBER		2		/*!< Calling number - string */
 | 
						|
#define IAX_IE_CALLING_ANI			3		/*!< Calling number ANI for billing  - string */
 | 
						|
#define IAX_IE_CALLING_NAME			4		/*!< Name of caller - string */
 | 
						|
#define IAX_IE_CALLED_CONTEXT		5		/*!< Context for number - string */
 | 
						|
#define IAX_IE_USERNAME				6		/*!< Username (peer or user) for authentication - string */
 | 
						|
#define IAX_IE_PASSWORD				7		/*!< Password for authentication - string */
 | 
						|
#define IAX_IE_CAPABILITY			8		/*!< Actual codec capability - unsigned int */
 | 
						|
#define IAX_IE_FORMAT				9		/*!< Desired codec format - unsigned int */
 | 
						|
#define IAX_IE_LANGUAGE				10		/*!< Desired language - string */
 | 
						|
#define IAX_IE_VERSION				11		/*!< Protocol version - short */
 | 
						|
#define IAX_IE_ADSICPE				12		/*!< CPE ADSI capability - short */
 | 
						|
#define IAX_IE_DNID					13		/*!< Originally dialed DNID - string */
 | 
						|
#define IAX_IE_AUTHMETHODS			14		/*!< Authentication method(s) - short */
 | 
						|
#define IAX_IE_CHALLENGE			15		/*!< Challenge data for MD5/RSA - string */
 | 
						|
#define IAX_IE_MD5_RESULT			16		/*!< MD5 challenge result - string */
 | 
						|
#define IAX_IE_RSA_RESULT			17		/*!< RSA challenge result - string */
 | 
						|
#define IAX_IE_APPARENT_ADDR		18		/*!< Apparent address of peer - struct sockaddr_in */
 | 
						|
#define IAX_IE_REFRESH				19		/*!< When to refresh registration - short */
 | 
						|
#define IAX_IE_DPSTATUS				20		/*!< Dialplan status - short */
 | 
						|
#define IAX_IE_CALLNO				21		/*!< Call number of peer - short */
 | 
						|
#define IAX_IE_CAUSE				22		/*!< Cause - string */
 | 
						|
#define IAX_IE_IAX_UNKNOWN			23		/*!< Unknown IAX command - byte */
 | 
						|
#define IAX_IE_MSGCOUNT				24		/*!< How many messages waiting - short */
 | 
						|
#define IAX_IE_AUTOANSWER			25		/*!< Request auto-answering -- none */
 | 
						|
#define IAX_IE_MUSICONHOLD			26		/*!< Request musiconhold with QUELCH -- none or string */
 | 
						|
#define IAX_IE_TRANSFERID			27		/*!< Transfer Request Identifier -- int */
 | 
						|
#define IAX_IE_RDNIS				28		/*!< Referring DNIS -- string */
 | 
						|
#define IAX_IE_PROVISIONING			29		/*!< Provisioning info */
 | 
						|
#define IAX_IE_AESPROVISIONING		30		/*!< AES Provisioning info */
 | 
						|
#define IAX_IE_DATETIME				31		/*!< Date/Time */
 | 
						|
#define IAX_IE_DEVICETYPE			32		/*!< Device Type -- string */
 | 
						|
#define IAX_IE_SERVICEIDENT			33		/*!< Service Identifier -- string */
 | 
						|
#define IAX_IE_FIRMWAREVER			34		/*!< Firmware revision -- u16 */
 | 
						|
#define IAX_IE_FWBLOCKDESC			35		/*!< Firmware block description -- u32 */
 | 
						|
#define IAX_IE_FWBLOCKDATA			36		/*!< Firmware block of data -- raw */
 | 
						|
#define IAX_IE_PROVVER				37		/*!< Provisioning Version (u32) */
 | 
						|
#define IAX_IE_CALLINGPRES			38		/*!< Calling presentation (u8) */
 | 
						|
#define IAX_IE_CALLINGTON			39		/*!< Calling type of number (u8) */
 | 
						|
#define IAX_IE_CALLINGTNS			40		/*!< Calling transit network select (u16) */
 | 
						|
#define IAX_IE_SAMPLINGRATE			41		/*!< Supported sampling rates (u16) */
 | 
						|
#define IAX_IE_CAUSECODE			42		/*!< Hangup cause (u8) */
 | 
						|
#define IAX_IE_ENCRYPTION			43		/*!< Encryption format (u16) */
 | 
						|
#define IAX_IE_ENCKEY				44		/*!< Encryption key (raw) */
 | 
						|
#define IAX_IE_CODEC_PREFS          45      /*!< Codec Negotiation */
 | 
						|
 | 
						|
#define IAX_IE_RR_JITTER			46		/*!< Received jitter (as in RFC1889) u32 */
 | 
						|
#define IAX_IE_RR_LOSS				47		/*!< Received loss (high byte loss pct, low 24 bits loss count, as in rfc1889 */
 | 
						|
#define IAX_IE_RR_PKTS				48		/*!< Received frames (total frames received) u32 */
 | 
						|
#define IAX_IE_RR_DELAY				49		/*!< Max playout delay for received frames (in ms) u16 */
 | 
						|
#define IAX_IE_RR_DROPPED			50		/*!< Dropped frames (presumably by jitterbuf) u32 */
 | 
						|
#define IAX_IE_RR_OOO				51		/*!< Frames received Out of Order u32 */
 | 
						|
#define IAX_IE_VARIABLE				52		/*!< Remote variables */
 | 
						|
#define IAX_IE_OSPTOKEN				53		/*!< OSP token */
 | 
						|
#define IAX_IE_CALLTOKEN			54		/*!< Call number security token */
 | 
						|
 | 
						|
#define IAX_IE_CAPABILITY2          55      /*!< Actual codec capability - u8 version + integer array */
 | 
						|
#define IAX_IE_FORMAT2              56      /*!< Desired codec format - u8 version + integer array */
 | 
						|
 | 
						|
#define IAX_MAX_OSPBLOCK_SIZE		254		/*!< Max OSP token block size, 255 bytes - 1 byte OSP token block index */
 | 
						|
#define IAX_MAX_OSPBLOCK_NUM		4
 | 
						|
#define IAX_MAX_OSPTOKEN_SIZE		(IAX_MAX_OSPBLOCK_SIZE * IAX_MAX_OSPBLOCK_NUM)
 | 
						|
#define IAX_MAX_OSPBUFF_SIZE		(IAX_MAX_OSPTOKEN_SIZE + 16)
 | 
						|
 | 
						|
#define IAX_AUTH_PLAINTEXT			(1 << 0)
 | 
						|
#define IAX_AUTH_MD5				(1 << 1)
 | 
						|
#define IAX_AUTH_RSA				(1 << 2)
 | 
						|
 | 
						|
#define IAX_ENCRYPT_AES128			(1 << 0)
 | 
						|
#define IAX_ENCRYPT_KEYROTATE			(1 << 15)       /*!< Keyrotation support */
 | 
						|
 | 
						|
#define IAX_META_TRUNK				1		/*!< Trunk meta-message */
 | 
						|
#define IAX_META_VIDEO				2		/*!< Video frame */
 | 
						|
 | 
						|
#define IAX_META_TRUNK_SUPERMINI		0	/*!< This trunk frame contains classic supermini frames */
 | 
						|
#define IAX_META_TRUNK_MINI			1	/*!< This trunk frame contains trunked mini frames */
 | 
						|
 | 
						|
#define IAX_RATE_8KHZ				(1 << 0) /*!< 8khz sampling (default if absent) */
 | 
						|
#define IAX_RATE_11KHZ				(1 << 1) /*!< 11.025khz sampling */
 | 
						|
#define IAX_RATE_16KHZ				(1 << 2) /*!< 16khz sampling */
 | 
						|
#define IAX_RATE_22KHZ				(1 << 3) /*!< 22.05khz sampling */
 | 
						|
#define IAX_RATE_44KHZ				(1 << 4) /*!< 44.1khz sampling */
 | 
						|
#define IAX_RATE_48KHZ				(1 << 5) /*!< 48khz sampling */
 | 
						|
 | 
						|
#define IAX_DPSTATUS_EXISTS			(1 << 0)
 | 
						|
#define IAX_DPSTATUS_CANEXIST		(1 << 1)
 | 
						|
#define IAX_DPSTATUS_NONEXISTENT	(1 << 2)
 | 
						|
#define IAX_DPSTATUS_IGNOREPAT		(1 << 14)
 | 
						|
#define IAX_DPSTATUS_MATCHMORE		(1 << 15)
 | 
						|
 | 
						|
/*! iax2 format bit field for handling codecs the old way */
 | 
						|
typedef int64_t iax2_format;
 | 
						|
 | 
						|
/*!\brief iax2 wrapper function for ast_getformatname */
 | 
						|
const char *iax2_getformatname(iax2_format format);
 | 
						|
 | 
						|
/*! Full frames are always delivered reliably */
 | 
						|
struct ast_iax2_full_hdr {
 | 
						|
	unsigned short scallno;	/*!< Source call number -- high bit must be 1 */
 | 
						|
	unsigned short dcallno;	/*!< Destination call number -- high bit is 1 if retransmission */
 | 
						|
	unsigned int ts;		/*!< 32-bit timestamp in milliseconds (from 1st transmission) */
 | 
						|
	unsigned char oseqno;	/*!< Packet number (outgoing) */
 | 
						|
	unsigned char iseqno;	/*!< Packet number (next incoming expected) */
 | 
						|
	unsigned char type;		/*!< Frame type */
 | 
						|
	unsigned char csub;		/*!< Compressed subclass */
 | 
						|
	unsigned char iedata[0];
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
 | 
						|
/*! Full frames are always delivered reliably */
 | 
						|
struct ast_iax2_full_enc_hdr {
 | 
						|
	unsigned short scallno;	/*!< Source call number -- high bit must be 1 */
 | 
						|
	unsigned short dcallno;	/*!< Destination call number -- high bit is 1 if retransmission */
 | 
						|
	unsigned char encdata[0];
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
 | 
						|
/*! Mini header is used only for voice frames -- delivered unreliably */
 | 
						|
struct ast_iax2_mini_hdr {
 | 
						|
	unsigned short callno;	/*!< Source call number -- high bit must be 0, rest must be non-zero */
 | 
						|
	unsigned short ts;		/*!< 16-bit Timestamp (high 16 bits from last ast_iax2_full_hdr) */
 | 
						|
							/* Frametype implicitly VOICE_FRAME */
 | 
						|
							/* subclass implicit from last ast_iax2_full_hdr */
 | 
						|
	unsigned char data[0];
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
 | 
						|
/*! Mini header is used only for voice frames -- delivered unreliably */
 | 
						|
struct ast_iax2_mini_enc_hdr {
 | 
						|
	unsigned short callno;	/*!< Source call number -- high bit must be 0, rest must be non-zero */
 | 
						|
	unsigned char encdata[0];
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
 | 
						|
struct ast_iax2_meta_hdr {
 | 
						|
	unsigned short zeros;			/*!< Zeros field -- must be zero */
 | 
						|
	unsigned char metacmd;			/*!< Meta command */
 | 
						|
	unsigned char cmddata;			/*!< Command Data */
 | 
						|
	unsigned char data[0];
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
 | 
						|
struct ast_iax2_video_hdr {
 | 
						|
	unsigned short zeros;			/*!< Zeros field -- must be zero */
 | 
						|
	unsigned short callno;			/*!< Video call number */
 | 
						|
	unsigned short ts;				/*!< Timestamp and mark if present */
 | 
						|
	unsigned char data[0];
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
 | 
						|
struct ast_iax2_meta_trunk_hdr {
 | 
						|
	unsigned int ts;				/*!< 32-bit timestamp for all messages */
 | 
						|
	unsigned char data[0];
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
 | 
						|
struct ast_iax2_meta_trunk_entry {
 | 
						|
	unsigned short callno;			/*!< Call number */
 | 
						|
	unsigned short len;				/*!< Length of data for this callno */
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
 | 
						|
/*! When trunktimestamps are used, we use this format instead */
 | 
						|
struct ast_iax2_meta_trunk_mini {
 | 
						|
	unsigned short len;
 | 
						|
	struct ast_iax2_mini_hdr mini;		/*!< this is an actual miniframe */
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
 | 
						|
#define IAX_FIRMWARE_MAGIC 0x69617879
 | 
						|
 | 
						|
struct ast_iax2_firmware_header {
 | 
						|
	unsigned int magic;		/*!< Magic number */
 | 
						|
	unsigned short version;		/*!< Software version */
 | 
						|
	unsigned char devname[16];	/*!< Device */
 | 
						|
	unsigned int datalen;		/*!< Data length of file beyond header */
 | 
						|
	unsigned char chksum[16];	/*!< Checksum of all data */
 | 
						|
	unsigned char data[0];
 | 
						|
} __attribute__ ((__packed__));
 | 
						|
#endif
 |