/* * FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application * Copyright (C) 2005/2006, Anthony Minessale II * * Version: MPL 1.1 * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application * * The Initial Developer of the Original Code is * Anthony Minessale II * Portions created by the Initial Developer are Copyright (C) * the Initial Developer. All Rights Reserved. * * Contributor(s): * * Anthony Minessale II * * * switch_channel.h -- Media Channel Interface * */ /** * @file switch_rtp.h * @brief RTP * */ #ifndef SWITCH_RTP_H #define SWITCH_RTP_H SWITCH_BEGIN_EXTERN_C #define SWITCH_RTP_MAX_BUF_LEN 16384 ///\defgroup rtp RTP (RealTime Transport Protocol) ///\ingroup core1 ///\{ typedef void (*switch_rtp_invalid_handler_t)(switch_rtp_t *rtp_session, switch_socket_t *sock, void *data, switch_size_t datalen, switch_sockaddr_t *from_addr); /*! \brief Initilize the RTP System \param pool the memory pool to use for long term allocations \note Generally called by the core_init */ SWITCH_DECLARE(void) switch_rtp_init(switch_memory_pool_t *pool); /*! \brief Request a new port to be used for media \return the new port to use */ SWITCH_DECLARE(switch_port_t) switch_rtp_request_port(void); /*! \brief create a new RTP session handle \param new_rtp_session a poiter to aim at the new session \param payload the IANA payload number \param packet_size the default packet_size \param ms_per_packet time in microseconds per packet \param flags flags to control behaviour \param crypto_key optional crypto key \param timer_name timer interface to use \param err a pointer to resolve error messages \param pool a memory pool to use for the session \return the new RTP session or NULL on failure */ SWITCH_DECLARE(switch_status_t)switch_rtp_create(switch_rtp_t **new_rtp_session, switch_payload_t payload, uint32_t packet_size, uint32_t ms_per_packet, switch_rtp_flag_t flags, char *crypto_key, char *timer_name, const char **err, switch_memory_pool_t *pool); /*! \brief prepare a new RTP session handle and fully initilize it \param rx_host the local address \param rx_port the local port \param tx_host the remote address \param tx_port the remote port \param payload the IANA payload number \param packet_size the default packet_size \param ms_per_packet time in microseconds per packet \param flags flags to control behaviour \param crypto_key optional crypto key \param timer_name timer interface to use \param err a pointer to resolve error messages \param pool a memory pool to use for the session \return the new RTP session or NULL on failure */ SWITCH_DECLARE(switch_rtp_t *)switch_rtp_new(char *rx_host, switch_port_t rx_port, char *tx_host, switch_port_t tx_port, switch_payload_t payload, uint32_t packet_size, uint32_t ms_per_packet, switch_rtp_flag_t flags, char *crypto_key, char *timer_name, const char **err, switch_memory_pool_t *pool); /*! \brief Assign a remote address to the RTP session \param rtp_session an RTP session to assign the remote address to \param host the ip or fqhn of the remote address \param port the remote port \param err pointer for error messages */ SWITCH_DECLARE(switch_status_t) switch_rtp_set_remote_address(switch_rtp_t *rtp_session, char *host, switch_port_t port, const char **err); /*! \brief Assign a local address to the RTP session \param rtp_session an RTP session to assign the local address to \param host the ip or fqhn of the local address \param port the local port \param err pointer for error messages \note this call also binds the RTP session's socket to the new address */ SWITCH_DECLARE(switch_status_t) switch_rtp_set_local_address(switch_rtp_t *rtp_session, char *host, switch_port_t port, const char **err); /*! \brief Kill the socket on an existing RTP session \param rtp_session an RTP session to kill the socket of */ SWITCH_DECLARE(void) switch_rtp_kill_socket(switch_rtp_t *rtp_session); /*! \brief Test if an RTP session is ready \param rtp_session an RTP session to test \return a true value if it's ready */ SWITCH_DECLARE(uint8_t) switch_rtp_ready(switch_rtp_t *rtp_session); /*! \brief Destroy an RTP session \param rtp_session an RTP session to destroy */ SWITCH_DECLARE(void) switch_rtp_destroy(switch_rtp_t **rtp_session); /*! \brief Acvite ICE on an RTP session \return SWITCH_STATUS_SUCCESS */ SWITCH_DECLARE(switch_status_t) switch_rtp_activate_ice(switch_rtp_t *rtp_session, char *login, char *rlogin); /*! \brief Set an RTP Flag \param rtp_session the RTP session \param flags the flags to set */ SWITCH_DECLARE(void) switch_rtp_set_flag(switch_rtp_t *rtp_session, switch_rtp_flag_t flags); /*! \brief Test an RTP Flag \param rtp_session the RTP session \param flags the flags to test \return TRUE or FALSE */ SWITCH_DECLARE(uint8_t) switch_rtp_test_flag(switch_rtp_t *rtp_session, switch_rtp_flag_t flags); /*! \brief Clear an RTP Flag \param rtp_session the RTP session \param flags the flags to clear */ SWITCH_DECLARE(void) switch_rtp_clear_flag(switch_rtp_t *rtp_session, switch_rtp_flag_t flags); /*! \brief Retrieve the socket from an existing RTP session \param rtp_session the RTP session to retrieve the socket from \return the socket from the RTP session */ SWITCH_DECLARE(switch_socket_t *)switch_rtp_get_rtp_socket(switch_rtp_t *rtp_session); /*! \brief Set the default packet size for a given RTP session \param rtp_session the RTP session to set the packet size on \param packet_size the new default packet size */ SWITCH_DECLARE(void) switch_rtp_set_default_packet_size(switch_rtp_t *rtp_session, uint16_t packet_size); /*! \brief Get the default packet size for a given RTP session \param rtp_session the RTP session to get the packet size from \return the default packet_size of the RTP session */ SWITCH_DECLARE(uint32_t) switch_rtp_get_default_packet_size(switch_rtp_t *rtp_session); /*! \brief Set the default payload number for a given RTP session \param rtp_session the RTP session to set the payload number on \param payload the new default payload number */ SWITCH_DECLARE(void) switch_rtp_set_default_payload(switch_rtp_t *rtp_session, switch_payload_t payload); /*! \brief Get the default payload number for a given RTP session \param rtp_session the RTP session to get the payload number from \return the default payload of the RTP session */ SWITCH_DECLARE(uint32_t) switch_rtp_get_default_payload(switch_rtp_t *rtp_session); /*! \brief Set a callback function to execute when an invalid RTP packet is encountered \param rtp_session the RTP session \param on_invalid the function to set \return */ SWITCH_DECLARE(void) switch_rtp_set_invald_handler(switch_rtp_t *rtp_session, switch_rtp_invalid_handler_t on_invalid); /*! \brief Read data from a given RTP session \param rtp_session the RTP session to read from \param data the data to read \param datalen a pointer to the datalen \param payload_type the IANA payload of the packet \param flags flags \return the number of bytes read */ SWITCH_DECLARE(switch_status_t) switch_rtp_read(switch_rtp_t *rtp_session, void *data, uint32_t *datalen, switch_payload_t *payload_type, switch_frame_flag_t *flags); /*! \brief Queue RFC2833 DTMF data into an RTP Session \param rtp_session the rtp session to use \param digits the digit string to queue \param duration the duration of the dtmf */ SWITCH_DECLARE(switch_status_t) switch_rtp_queue_rfc2833(switch_rtp_t *rtp_session, char *digits, uint32_t duration); /*! \brief Test for presence of DTMF on a given RTP session \param rtp_session session to test \return number of digits in the queue */ SWITCH_DECLARE(switch_size_t) switch_rtp_has_dtmf(switch_rtp_t *rtp_session); /*! \brief Queue DTMF on a given RTP session \param rtp_session RTP session to queue DTMF to \param dtmf string of digits to queue \return SWITCH_STATUS_SUCCESS if successful */ SWITCH_DECLARE(switch_status_t) switch_rtp_queue_dtmf(switch_rtp_t *rtp_session, char *dtmf); /*! \brief Retrieve DTMF digits from a given RTP session \param rtp_session RTP session to retrieve digits from \param dtmf buffer to write dtmf to \param len max size in bytes of the buffer \return number of bytes read into the buffer */ SWITCH_DECLARE(switch_size_t) switch_rtp_dequeue_dtmf(switch_rtp_t *rtp_session, char *dtmf, switch_size_t len); /*! \brief Read data from a given RTP session without copying \param rtp_session the RTP session to read from \param data a pointer to point directly to the RTP read buffer \param datalen a pointer to the datalen \param payload_type the IANA payload of the packet \param flags flags \return the number of bytes read */ SWITCH_DECLARE(switch_status_t) switch_rtp_zerocopy_read(switch_rtp_t *rtp_session, void **data, uint32_t *datalen, switch_payload_t *payload_type, switch_frame_flag_t *flags); /*! \brief Read data from a given RTP session without copying \param rtp_session the RTP session to read from \param frame a frame to populate with information \return the number of bytes read */ SWITCH_DECLARE(switch_status_t) switch_rtp_zerocopy_read_frame(switch_rtp_t *rtp_session, switch_frame_t *frame); /*! \brief Write data to a given RTP session \param rtp_session the RTP session to write to \param data data to write \param datalen the size of the data \param ts then number of bytes to increment the timestamp by \param flags frame flags \return the number of bytes written */ SWITCH_DECLARE(int) switch_rtp_write(switch_rtp_t *rtp_session, void *data, uint32_t datalen, uint32_t ts, switch_frame_flag_t *flags); /*! \brief Enable VAD on an RTP Session \param rtp_session the RTP session \param session the core session associated with the RTP session \param codec the codec the channel is currenty using \param flags flags for control \return SWITCH_STAUTS_SUCCESS on success */ SWITCH_DECLARE(switch_status_t) switch_rtp_enable_vad(switch_rtp_t *rtp_session, switch_core_session_t *session, switch_codec_t *codec, switch_vad_flag_t flags); /*! \brief Disable VAD on an RTP Session \param rtp_session the RTP session \return SWITCH_STAUTS_SUCCESS on success */ SWITCH_DECLARE(switch_status_t) switch_rtp_disable_vad(switch_rtp_t *rtp_session); /*! \brief Write data to a given RTP session \param rtp_session the RTP session to write to \param frame the frame to write \param ts then number of bytes to increment the timestamp by \return the number of bytes written */ SWITCH_DECLARE(int) switch_rtp_write_frame(switch_rtp_t *rtp_session, switch_frame_t *frame, uint32_t ts); /*! \brief Write data with a specified payload and sequence number to a given RTP session \param rtp_session the RTP session to write to \param data data to write \param datalen the size of the data \param m set mark bit or not \param payload the IANA payload number \param ts then number of bytes to increment the timestamp by \param mseq the specific sequence number to use \param flags frame flags \return the number of bytes written */ SWITCH_DECLARE(int) switch_rtp_write_manual(switch_rtp_t *rtp_session, void *data, uint16_t datalen, uint8_t m, switch_payload_t payload, uint32_t ts, uint16_t mseq, switch_frame_flag_t *flags); /*! \brief Retrieve the SSRC from a given RTP session \param rtp_session the RTP session to retrieve from \return the SSRC */ SWITCH_DECLARE(uint32_t) switch_rtp_get_ssrc(switch_rtp_t *rtp_session); /*! \brief Associate an arbitrary data pointer with and RTP session \param rtp_session the RTP session to assign the pointer to \param private_data the private data to assign */ SWITCH_DECLARE(void) switch_rtp_set_private(switch_rtp_t *rtp_session, void *private_data); /*! \brief Set the payload type to consider RFC2833 DTMF \param rtp_session the RTP session to modify \param te the payload type */ SWITCH_DECLARE(void) switch_rtp_set_telephony_event(switch_rtp_t *rtp_session, switch_payload_t te); /*! \brief Retrieve the private data from a given RTP session \param rtp_session the RTP session to retrieve the data from \return the pointer to the private data */ SWITCH_DECLARE(void *)switch_rtp_get_private(switch_rtp_t *rtp_session); /*! \} */ SWITCH_END_EXTERN_C #endif /* For Emacs: * Local Variables: * mode:c * indent-tabs-mode:nil * tab-width:4 * c-basic-offset:4 * End: * For VIM: * vim:set softtabstop=4 shiftwidth=4 tabstop=4 expandtab: */