forked from len0rd/rockbox
		
	Change-Id: Id7f4717d51ed02d67cb9f9cb3c0ada4a81843f97 Reviewed-on: http://gerrit.rockbox.org/137 Reviewed-by: Nils Wallménius <nils@rockbox.org> Tested-by: Nils Wallménius <nils@rockbox.org>
		
			
				
	
	
		
			197 lines
		
	
	
	
		
			7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			197 lines
		
	
	
	
		
			7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Copyright (C) 2002 Jean-Marc Valin */
 | |
| /**
 | |
|    @file speex_jitter.h
 | |
|    @brief Adaptive jitter buffer for Speex
 | |
| */
 | |
| /*
 | |
|    Redistribution and use in source and binary forms, with or without
 | |
|    modification, are permitted provided that the following conditions
 | |
|    are met:
 | |
|    
 | |
|    - Redistributions of source code must retain the above copyright
 | |
|    notice, this list of conditions and the following disclaimer.
 | |
|    
 | |
|    - Redistributions in binary form must reproduce the above copyright
 | |
|    notice, this list of conditions and the following disclaimer in the
 | |
|    documentation and/or other materials provided with the distribution.
 | |
|    
 | |
|    - Neither the name of the Xiph.org Foundation nor the names of its
 | |
|    contributors may be used to endorse or promote products derived from
 | |
|    this software without specific prior written permission.
 | |
|    
 | |
|    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 | |
|    ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 | |
|    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 | |
|    A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
 | |
|    CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 | |
|    EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 | |
|    PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 | |
|    PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 | |
|    LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 | |
|    NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 | |
|    SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | |
| 
 | |
| */
 | |
| 
 | |
| #ifndef SPEEX_JITTER_H
 | |
| #define SPEEX_JITTER_H
 | |
| /** @defgroup JitterBuffer JitterBuffer: Adaptive jitter buffer
 | |
|  *  This is the jitter buffer that reorders UDP/RTP packets and adjusts the buffer size
 | |
|  * to maintain good quality and low latency.
 | |
|  *  @{
 | |
|  */
 | |
| 
 | |
| #include "speex_types.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /** Generic adaptive jitter buffer state */
 | |
| struct JitterBuffer_;
 | |
| 
 | |
| /** Generic adaptive jitter buffer state */
 | |
| typedef struct JitterBuffer_ JitterBuffer;
 | |
| 
 | |
| /** Definition of an incoming packet */
 | |
| typedef struct _JitterBufferPacket JitterBufferPacket;
 | |
| 
 | |
| /** Definition of an incoming packet */
 | |
| struct _JitterBufferPacket {
 | |
|    char        *data;       /**< Data bytes contained in the packet */
 | |
|    spx_uint32_t len;        /**< Length of the packet in bytes */
 | |
|    spx_uint32_t timestamp;  /**< Timestamp for the packet */
 | |
|    spx_uint32_t span;       /**< Time covered by the packet (same units as timestamp) */
 | |
|    spx_uint16_t sequence;   /**< RTP Sequence number if available (0 otherwise) */
 | |
|    spx_uint32_t user_data;  /**< Put whatever data you like here (it's ignored by the jitter buffer) */
 | |
| };
 | |
| 
 | |
| /** Packet has been retrieved */
 | |
| #define JITTER_BUFFER_OK 0
 | |
| /** Packet is lost or is late */
 | |
| #define JITTER_BUFFER_MISSING 1
 | |
| /** A "fake" packet is meant to be inserted here to increase buffering */
 | |
| #define JITTER_BUFFER_INSERTION 2
 | |
| /** There was an error in the jitter buffer */
 | |
| #define JITTER_BUFFER_INTERNAL_ERROR -1
 | |
| /** Invalid argument */
 | |
| #define JITTER_BUFFER_BAD_ARGUMENT -2
 | |
| 
 | |
| 
 | |
| /** Set minimum amount of extra buffering required (margin) */
 | |
| #define JITTER_BUFFER_SET_MARGIN 0
 | |
| /** Get minimum amount of extra buffering required (margin) */
 | |
| #define JITTER_BUFFER_GET_MARGIN 1
 | |
| /* JITTER_BUFFER_SET_AVAILABLE_COUNT wouldn't make sense */
 | |
| 
 | |
| /** Get the amount of available packets currently buffered */
 | |
| #define JITTER_BUFFER_GET_AVAILABLE_COUNT 3
 | |
| /** Included because of an early misspelling (will remove in next release) */
 | |
| #define JITTER_BUFFER_GET_AVALIABLE_COUNT 3
 | |
| 
 | |
| /** Assign a function to destroy unused packet. When setting that, the jitter 
 | |
|     buffer no longer copies packet data. */
 | |
| #define JITTER_BUFFER_SET_DESTROY_CALLBACK 4
 | |
| /**  */
 | |
| #define JITTER_BUFFER_GET_DESTROY_CALLBACK 5
 | |
| 
 | |
| /** Tell the jitter buffer to only adjust the delay in multiples of the step parameter provided */
 | |
| #define JITTER_BUFFER_SET_DELAY_STEP 6
 | |
| /**  */
 | |
| #define JITTER_BUFFER_GET_DELAY_STEP 7
 | |
| 
 | |
| /** Tell the jitter buffer to only do concealment in multiples of the size parameter provided */
 | |
| #define JITTER_BUFFER_SET_CONCEALMENT_SIZE 8
 | |
| #define JITTER_BUFFER_GET_CONCEALMENT_SIZE 9
 | |
| 
 | |
| /** Absolute max amount of loss that can be tolerated regardless of the delay. Typical loss 
 | |
|     should be half of that or less. */
 | |
| #define JITTER_BUFFER_SET_MAX_LATE_RATE 10
 | |
| #define JITTER_BUFFER_GET_MAX_LATE_RATE 11
 | |
| 
 | |
| /** Equivalent cost of one percent late packet in timestamp units */
 | |
| #define JITTER_BUFFER_SET_LATE_COST 12
 | |
| #define JITTER_BUFFER_GET_LATE_COST 13
 | |
| 
 | |
| 
 | |
| /** Initialises jitter buffer 
 | |
|  * 
 | |
|  * @param step_size Starting value for the size of concleanment packets and delay 
 | |
|        adjustment steps. Can be changed at any time using JITTER_BUFFER_SET_DELAY_STEP
 | |
|        and JITTER_BUFFER_GET_CONCEALMENT_SIZE.
 | |
|  * @return Newly created jitter buffer state
 | |
|  */
 | |
| JitterBuffer *jitter_buffer_init(int step_size);
 | |
| 
 | |
| /** Restores jitter buffer to its original state 
 | |
|  * 
 | |
|  * @param jitter Jitter buffer state
 | |
|  */
 | |
| void jitter_buffer_reset(JitterBuffer *jitter);
 | |
| 
 | |
| /** Destroys jitter buffer 
 | |
|  * 
 | |
|  * @param jitter Jitter buffer state
 | |
|  */
 | |
| void jitter_buffer_destroy(JitterBuffer *jitter);
 | |
| 
 | |
| /** Put one packet into the jitter buffer
 | |
|  * 
 | |
|  * @param jitter Jitter buffer state
 | |
|  * @param packet Incoming packet
 | |
| */
 | |
| void jitter_buffer_put(JitterBuffer *jitter, const JitterBufferPacket *packet);
 | |
| 
 | |
| /** Get one packet from the jitter buffer
 | |
|  * 
 | |
|  * @param jitter Jitter buffer state
 | |
|  * @param packet Returned packet
 | |
|  * @param desired_span Number of samples (or units) we wish to get from the buffer (no guarantee)
 | |
|  * @param current_timestamp Timestamp for the returned packet 
 | |
| */
 | |
| int jitter_buffer_get(JitterBuffer *jitter, JitterBufferPacket *packet, spx_int32_t desired_span, spx_int32_t *start_offset);
 | |
| 
 | |
| /** Used right after jitter_buffer_get() to obtain another packet that would have the same timestamp.
 | |
|  * This is mainly useful for media where a single "frame" can be split into several packets.
 | |
|  * 
 | |
|  * @param jitter Jitter buffer state
 | |
|  * @param packet Returned packet
 | |
|  */
 | |
| int jitter_buffer_get_another(JitterBuffer *jitter, JitterBufferPacket *packet);
 | |
| 
 | |
| /** Get pointer timestamp of jitter buffer
 | |
|  * 
 | |
|  * @param jitter Jitter buffer state
 | |
| */
 | |
| int jitter_buffer_get_pointer_timestamp(JitterBuffer *jitter);
 | |
| 
 | |
| /** Advance by one tick
 | |
|  * 
 | |
|  * @param jitter Jitter buffer state
 | |
| */
 | |
| void jitter_buffer_tick(JitterBuffer *jitter);
 | |
| 
 | |
| /** Telling the jitter buffer about the remaining data in the application buffer
 | |
|  * @param jitter Jitter buffer state
 | |
|  * @param rem Amount of data buffered by the application (timestamp units)
 | |
|  */
 | |
| void jitter_buffer_remaining_span(JitterBuffer *jitter, spx_uint32_t rem);
 | |
| 
 | |
| /** Used like the ioctl function to control the jitter buffer parameters
 | |
|  * 
 | |
|  * @param jitter Jitter buffer state
 | |
|  * @param request ioctl-type request (one of the JITTER_BUFFER_* macros)
 | |
|  * @param ptr Data exchanged to-from function
 | |
|  * @return 0 if no error, -1 if request in unknown
 | |
| */
 | |
| int jitter_buffer_ctl(JitterBuffer *jitter, int request, void *ptr);
 | |
| 
 | |
| int jitter_buffer_update_delay(JitterBuffer *jitter, JitterBufferPacket *packet, spx_int32_t *start_offset);
 | |
| 
 | |
| /* @} */
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif
 |