Mercurial > libavformat.hg
annotate rtsp.h @ 479:d84d9d8bb0a4 libavformat
pass timestamps correctly for -sync 0
use zero sized frames in avi to handle duplicate frames
author | michael |
---|---|
date | Tue, 15 Jun 2004 13:49:12 +0000 |
parents | d58c8859ff8c |
children | 820863425158 |
rev | line source |
---|---|
0 | 1 /* |
2 * RTSP definitions | |
3 * Copyright (c) 2002 Fabrice Bellard. | |
4 * | |
5 * This library is free software; you can redistribute it and/or | |
6 * modify it under the terms of the GNU Lesser General Public | |
7 * License as published by the Free Software Foundation; either | |
8 * version 2 of the License, or (at your option) any later version. | |
9 * | |
10 * This library is distributed in the hope that it will be useful, | |
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
13 * Lesser General Public License for more details. | |
14 * | |
15 * You should have received a copy of the GNU Lesser General Public | |
16 * License along with this library; if not, write to the Free Software | |
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
18 */ | |
19 #ifndef RTSP_H | |
20 #define RTSP_H | |
21 | |
22 /* RTSP handling */ | |
23 enum RTSPStatusCode { | |
24 #define DEF(n, c, s) c = n, | |
25 #include "rtspcodes.h" | |
26 #undef DEF | |
27 }; | |
28 | |
29 enum RTSPProtocol { | |
30 RTSP_PROTOCOL_RTP_UDP = 0, | |
31 RTSP_PROTOCOL_RTP_TCP = 1, | |
32 RTSP_PROTOCOL_RTP_UDP_MULTICAST = 2, | |
33 }; | |
34 | |
35 #define RTSP_DEFAULT_PORT 554 | |
36 #define RTSP_MAX_TRANSPORTS 8 | |
179 | 37 #define RTSP_TCP_MAX_PACKET_SIZE 1472 |
0 | 38 |
39 typedef struct RTSPTransportField { | |
40 int interleaved_min, interleaved_max; /* interleave ids, if TCP transport */ | |
41 int port_min, port_max; /* RTP ports */ | |
42 int client_port_min, client_port_max; /* RTP ports */ | |
43 int server_port_min, server_port_max; /* RTP ports */ | |
44 int ttl; /* ttl value */ | |
65 | 45 uint32_t destination; /* destination IP address */ |
0 | 46 enum RTSPProtocol protocol; |
47 } RTSPTransportField; | |
48 | |
49 typedef struct RTSPHeader { | |
50 int content_length; | |
51 enum RTSPStatusCode status_code; /* response code from server */ | |
52 int nb_transports; | |
304
d58c8859ff8c
initial seek support - more generic play/pause support
bellard
parents:
179
diff
changeset
|
53 /* in AV_TIME_BASE unit, AV_NOPTS_VALUE if not used */ |
d58c8859ff8c
initial seek support - more generic play/pause support
bellard
parents:
179
diff
changeset
|
54 int64_t range_start, range_end; |
0 | 55 RTSPTransportField transports[RTSP_MAX_TRANSPORTS]; |
56 int seq; /* sequence number */ | |
57 char session_id[512]; | |
58 } RTSPHeader; | |
59 | |
60 /* the callback can be used to extend the connection setup/teardown step */ | |
61 enum RTSPCallbackAction { | |
62 RTSP_ACTION_SERVER_SETUP, | |
63 RTSP_ACTION_SERVER_TEARDOWN, | |
64 RTSP_ACTION_CLIENT_SETUP, | |
65 RTSP_ACTION_CLIENT_TEARDOWN, | |
66 }; | |
67 | |
68 typedef struct RTSPActionServerSetup { | |
65 | 69 uint32_t ipaddr; |
0 | 70 char transport_option[512]; |
71 } RTSPActionServerSetup; | |
72 | |
73 typedef int FFRTSPCallback(enum RTSPCallbackAction action, | |
74 const char *session_id, | |
75 char *buf, int buf_size, | |
76 void *arg); | |
77 | |
78 void rtsp_set_callback(FFRTSPCallback *rtsp_cb); | |
79 | |
80 int rtsp_init(void); | |
81 void rtsp_parse_line(RTSPHeader *reply, const char *buf); | |
82 | |
83 extern int rtsp_default_protocols; | |
84 extern int rtsp_rtp_port_min; | |
85 extern int rtsp_rtp_port_max; | |
86 extern FFRTSPCallback *ff_rtsp_callback; | |
179 | 87 extern AVInputFormat rtsp_demux; |
88 | |
89 int rtsp_pause(AVFormatContext *s); | |
90 int rtsp_resume(AVFormatContext *s); | |
0 | 91 |
92 #endif /* RTSP_H */ |