libavformat/rtpdec.h File Reference

#include "libavcodec/avcodec.h"
#include "avformat.h"
#include "rtp.h"
#include "url.h"

Go to the source code of this file.

Data Structures

struct  RTPStatistics
struct  RTPDynamicProtocolHandler_s
struct  RTPPacket
struct  RTPDemuxContext

Defines

#define RTP_MIN_PACKET_LENGTH   12
#define RTP_MAX_PACKET_LENGTH   1500
#define RTP_REORDER_QUEUE_DEFAULT_SIZE   10
#define RTP_NOTS_VALUE   ((uint32_t)-1)
#define RTP_FLAG_KEY   0x1
 RTP packet contains a keyframe.
#define RTP_FLAG_MARKER   0x2
 RTP marker bit was set for this packet.

Typedefs

typedef struct PayloadContext PayloadContext
typedef struct
RTPDynamicProtocolHandler_s 
RTPDynamicProtocolHandler
typedef struct RTPDemuxContext RTPDemuxContext
typedef int(* DynamicPayloadPacketHandlerProc )(AVFormatContext *ctx, PayloadContext *s, AVStream *st, AVPacket *pkt, uint32_t *timestamp, const uint8_t *buf, int len, int flags)
 Packet parsing for "private" payloads in the RTP specs.

Functions

RTPDemuxContextrtp_parse_open (AVFormatContext *s1, AVStream *st, URLContext *rtpc, int payload_type, int queue_size)
 open a new RTP parse context for stream 'st'.
void rtp_parse_set_dynamic_protocol (RTPDemuxContext *s, PayloadContext *ctx, RTPDynamicProtocolHandler *handler)
int rtp_parse_packet (RTPDemuxContext *s, AVPacket *pkt, uint8_t **buf, int len)
 Parse an RTP or RTCP packet directly sent as a buffer.
void rtp_parse_close (RTPDemuxContext *s)
int64_t ff_rtp_queued_packet_time (RTPDemuxContext *s)
void ff_rtp_reset_packet_queue (RTPDemuxContext *s)
int rtp_get_local_rtp_port (URLContext *h)
 Return the local rtp port used by the RTP connection.
int rtp_get_local_rtcp_port (URLContext *h)
 Return the local rtcp port used by the RTP connection.
int rtp_set_remote_url (URLContext *h, const char *uri)
 If no filename is given to av_open_input_file because you want to get the local port first, then you must call this function to set the remote server address.
void rtp_send_punch_packets (URLContext *rtp_handle)
 Send a dummy packet on both port pairs to set up the connection state in potential NAT routers, so that we're able to receive packets.
int rtp_check_and_send_back_rr (RTPDemuxContext *s, int count)
 some rtp servers assume client is dead if they don't hear from them.
int rtp_get_rtcp_file_handle (URLContext *h)
 Get the file handle for the RTCP socket.
void ff_register_dynamic_payload_handler (RTPDynamicProtocolHandler *handler)
RTPDynamicProtocolHandlerff_rtp_handler_find_by_name (const char *name, enum AVMediaType codec_type)
RTPDynamicProtocolHandlerff_rtp_handler_find_by_id (int id, enum AVMediaType codec_type)
int ff_rtsp_next_attr_and_value (const char **p, char *attr, int attr_size, char *value, int value_size)
 from rtsp.c, but used by rtp dynamic protocol handlers.
int ff_parse_fmtp (AVStream *stream, PayloadContext *data, const char *p, int(*parse_fmtp)(AVStream *stream, PayloadContext *data, char *attr, char *value))
void av_register_rtp_dynamic_payload_handlers (void)


Define Documentation

#define RTP_FLAG_KEY   0x1

RTP packet contains a keyframe.

Definition at line 93 of file rtpdec.h.

Referenced by asfrtp_parse_packet(), ff_rdt_parse_packet(), qt_rtp_parse_packet(), and rdt_parse_packet().

#define RTP_FLAG_MARKER   0x2

RTP marker bit was set for this packet.

Definition at line 94 of file rtpdec.h.

Referenced by asfrtp_parse_packet(), latm_parse_packet(), qt_rtp_parse_packet(), rtp_parse_packet_internal(), and vp8_handle_packet().

#define RTP_MAX_PACKET_LENGTH   1500

Definition at line 34 of file rtpdec.h.

Referenced by rtp_parse_mp4_au().

#define RTP_MIN_PACKET_LENGTH   12

Definition at line 33 of file rtpdec.h.

#define RTP_NOTS_VALUE   ((uint32_t)-1)

Definition at line 38 of file rtpdec.h.

Referenced by finalize_packet(), qdm2_parse_packet(), rtp_parse_one_packet(), and store_packet().

#define RTP_REORDER_QUEUE_DEFAULT_SIZE   10

Definition at line 36 of file rtpdec.h.

Referenced by rtsp_open_transport_ctx().


Typedef Documentation

typedef int(* DynamicPayloadPacketHandlerProc)(AVFormatContext *ctx, PayloadContext *s, AVStream *st, AVPacket *pkt, uint32_t *timestamp, const uint8_t *buf, int len, int flags)

Packet parsing for "private" payloads in the RTP specs.

Parameters:
ctx RTSP demuxer context
s stream context
st stream that this packet belongs to
pkt packet in which to write the parsed data
timestamp pointer in which to write the timestamp of this RTP packet
buf pointer to raw RTP packet data
len length of buf
flags flags from the RTP packet header (RTP_FLAG_*)

Definition at line 107 of file rtpdec.h.

Definition at line 30 of file rtpdec.h.

Definition at line 40 of file rtpdec.h.

Definition at line 31 of file rtpdec.h.


Function Documentation

void av_register_rtp_dynamic_payload_handlers ( void   ) 

Definition at line 60 of file rtpdec.c.

Referenced by av_register_all().

int ff_parse_fmtp ( AVStream stream,
PayloadContext data,
const char *  p,
int(*)(AVStream *stream, PayloadContext *data, char *attr, char *value)  parse_fmtp 
)

void ff_register_dynamic_payload_handler ( RTPDynamicProtocolHandler handler  ) 

RTPDynamicProtocolHandler* ff_rtp_handler_find_by_id ( int  id,
enum AVMediaType  codec_type 
)

Definition at line 104 of file rtpdec.c.

RTPDynamicProtocolHandler* ff_rtp_handler_find_by_name ( const char *  name,
enum AVMediaType  codec_type 
)

Definition at line 92 of file rtpdec.c.

int64_t ff_rtp_queued_packet_time ( RTPDemuxContext s  ) 

Definition at line 633 of file rtpdec.c.

void ff_rtp_reset_packet_queue ( RTPDemuxContext s  ) 

Definition at line 586 of file rtpdec.c.

Referenced by rtp_parse_close(), and rtsp_read_play().

int ff_rtsp_next_attr_and_value ( const char **  p,
char *  attr,
int  attr_size,
char *  value,
int  value_size 
)

from rtsp.c, but used by rtp dynamic protocol handlers.

Referenced by ff_parse_fmtp().

int rtp_check_and_send_back_rr ( RTPDemuxContext s,
int  count 
)

some rtp servers assume client is dead if they don't hear from them.

.. so we send a Receiver Report to the provided ByteIO context (we don't have access to the rtcp handle from here)

Definition at line 241 of file rtpdec.c.

int rtp_get_local_rtcp_port ( URLContext h  ) 

Return the local rtcp port used by the RTP connection.

Parameters:
h media file context
Returns:
the local port number

Definition at line 339 of file rtpproto.c.

Referenced by rtsp_cmd_setup().

int rtp_get_local_rtp_port ( URLContext h  ) 

Return the local rtp port used by the RTP connection.

Parameters:
h media file context
Returns:
the local port number

Definition at line 327 of file rtpproto.c.

Referenced by rtsp_cmd_setup().

int rtp_get_rtcp_file_handle ( URLContext h  ) 

Get the file handle for the RTCP socket.

Definition at line 351 of file rtpproto.c.

void rtp_parse_close ( RTPDemuxContext s  ) 

Definition at line 755 of file rtpdec.c.

Referenced by ff_rtsp_undo_setup().

RTPDemuxContext* rtp_parse_open ( AVFormatContext s1,
AVStream st,
URLContext rtpc,
int  payload_type,
int  queue_size 
)

open a new RTP parse context for stream 'st'.

'st' can be NULL for MPEG2TS streams to indicate that they should be demuxed inside the rtp demux (otherwise CODEC_ID_MPEG2TS packets are returned)

Definition at line 382 of file rtpdec.c.

Referenced by rtsp_open_transport_ctx().

int rtp_parse_packet ( RTPDemuxContext s,
AVPacket pkt,
uint8_t **  bufptr,
int  len 
)

Parse an RTP or RTCP packet directly sent as a buffer.

Parameters:
s RTP parse context.
pkt returned packet
bufptr pointer to the input buffer or NULL to read the next packets
len buffer len
Returns:
0 if a packet is returned, 1 if a packet is returned and more can follow (use buf as NULL to read the next). -1 if no packet (error or no more packet).

Definition at line 745 of file rtpdec.c.

void rtp_parse_set_dynamic_protocol ( RTPDemuxContext s,
PayloadContext ctx,
RTPDynamicProtocolHandler handler 
)

Definition at line 430 of file rtpdec.c.

Referenced by rtsp_open_transport_ctx().

void rtp_send_punch_packets ( URLContext rtp_handle  ) 

Send a dummy packet on both port pairs to set up the connection state in potential NAT routers, so that we're able to receive packets.

Note, this only works if the NAT router doesn't remap ports. This isn't a standardized procedure, but it works in many cases in practice.

The same routine is used with RDT too, even if RDT doesn't use normal RTP packets otherwise.

Definition at line 338 of file rtpdec.c.

int rtp_set_remote_url ( URLContext h,
const char *  uri 
)

If no filename is given to av_open_input_file because you want to get the local port first, then you must call this function to set the remote server address.

Parameters:
h media file context
uri of the remote server
Returns:
zero if no error.

Definition at line 63 of file rtpproto.c.


Generated on Fri Oct 26 02:38:21 2012 for FFmpeg by  doxygen 1.5.8