aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat
diff options
context:
space:
mode:
authorFabrice Bellard <fabrice@bellard.org>2003-07-17 10:27:47 +0000
committerFabrice Bellard <fabrice@bellard.org>2003-07-17 10:27:47 +0000
commitb7b8fc340632d15cb3b26a57915ebea84f37d03e (patch)
tree2c3285f135a719b41bb58b0a03d18fe5ac2cae49 /libavformat
parent590403c7023c37a7dd43216446a9780e2add0097 (diff)
downloadffmpeg-b7b8fc340632d15cb3b26a57915ebea84f37d03e.tar.gz
suppressed RTSP abort hack - added PLAY/PAUSE
Originally committed as revision 2060 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat')
-rw-r--r--libavformat/rtsp.c89
-rw-r--r--libavformat/rtsp.h6
2 files changed, 84 insertions, 11 deletions
diff --git a/libavformat/rtsp.c b/libavformat/rtsp.c
index 601f20daef..98225cdccd 100644
--- a/libavformat/rtsp.c
+++ b/libavformat/rtsp.c
@@ -52,9 +52,6 @@ typedef struct RTSPStream {
int sdp_payload_type; /* payload type - only used in SDP */
} RTSPStream;
-/* suppress this hack */
-int rtsp_abort_req = 0;
-
/* XXX: currently, the only way to change the protocols consists in
changing this variable */
#if 1
@@ -518,6 +515,31 @@ void rtsp_parse_line(RTSPHeader *reply, const char *buf)
}
}
+/* skip a RTP/TCP interleaved packet */
+static void rtsp_skip_packet(AVFormatContext *s)
+{
+ RTSPState *rt = s->priv_data;
+ int ret, len, len1;
+ uint8_t buf[1024];
+
+ ret = url_read(rt->rtsp_hd, buf, 3);
+ if (ret != 3)
+ return;
+ len = (buf[1] << 8) | buf[2];
+#ifdef DEBUG
+ printf("skipping RTP packet len=%d\n", len);
+#endif
+ /* skip payload */
+ while (len > 0) {
+ len1 = len;
+ if (len1 > sizeof(buf))
+ len1 = sizeof(buf);
+ ret = url_read(rt->rtsp_hd, buf, len1);
+ if (ret != len1)
+ return;
+ len -= len1;
+ }
+}
static void rtsp_send_cmd(AVFormatContext *s,
const char *cmd, RTSPHeader *reply,
@@ -552,11 +574,14 @@ static void rtsp_send_cmd(AVFormatContext *s,
for(;;) {
q = buf;
for(;;) {
- if (url_read(rt->rtsp_hd, &ch, 1) == 0)
+ if (url_read(rt->rtsp_hd, &ch, 1) != 1)
break;
if (ch == '\n')
break;
- if (ch != '\r') {
+ if (ch == '$') {
+ /* XXX: only parse it if first char on line ? */
+ rtsp_skip_packet(s);
+ } else if (ch != '\r') {
if ((q - buf) < sizeof(buf) - 1)
*q++ = ch;
}
@@ -617,8 +642,6 @@ static int rtsp_read_header(AVFormatContext *s,
RTSPStream *rtsp_st;
int protocol_mask;
- rtsp_abort_req = 0;
-
/* extract hostname and port */
url_split(NULL, 0,
host, sizeof(host), &port, path, sizeof(path), s->filename);
@@ -904,7 +927,7 @@ static int udp_read_packet(AVFormatContext *s,
struct timeval tv;
for(;;) {
- if (rtsp_abort_req)
+ if (url_interrupt_cb())
return -EIO;
FD_ZERO(&rfds);
fd_max = -1;
@@ -920,7 +943,7 @@ static int udp_read_packet(AVFormatContext *s,
}
/* XXX: also add proper API to abort */
tv.tv_sec = 0;
- tv.tv_usec = 500000;
+ tv.tv_usec = 100 * 1000;
n = select(fd_max + 1, &rfds, NULL, NULL, &tv);
if (n > 0) {
for(i = 0; i < s->nb_streams; i++) {
@@ -959,6 +982,52 @@ static int rtsp_read_packet(AVFormatContext *s,
return ret;
}
+/* pause the stream */
+int rtsp_pause(AVFormatContext *s)
+{
+ RTSPState *rt;
+ RTSPHeader reply1, *reply = &reply1;
+ char cmd[1024];
+
+ if (s->iformat != &rtsp_demux)
+ return -1;
+
+ rt = s->priv_data;
+
+ snprintf(cmd, sizeof(cmd),
+ "PAUSE %s RTSP/1.0\r\n",
+ s->filename);
+ rtsp_send_cmd(s, cmd, reply, NULL);
+ if (reply->status_code != RTSP_STATUS_OK) {
+ return -1;
+ } else {
+ return 0;
+ }
+}
+
+/* resume the stream */
+int rtsp_resume(AVFormatContext *s)
+{
+ RTSPState *rt;
+ RTSPHeader reply1, *reply = &reply1;
+ char cmd[1024];
+
+ if (s->iformat != &rtsp_demux)
+ return -1;
+
+ rt = s->priv_data;
+
+ snprintf(cmd, sizeof(cmd),
+ "PLAY %s RTSP/1.0\r\n",
+ s->filename);
+ rtsp_send_cmd(s, cmd, reply, NULL);
+ if (reply->status_code != RTSP_STATUS_OK) {
+ return -1;
+ } else {
+ return 0;
+ }
+}
+
static int rtsp_read_close(AVFormatContext *s)
{
RTSPState *rt = s->priv_data;
@@ -997,7 +1066,7 @@ static int rtsp_read_close(AVFormatContext *s)
return 0;
}
-static AVInputFormat rtsp_demux = {
+AVInputFormat rtsp_demux = {
"rtsp",
"RTSP input format",
sizeof(RTSPState),
diff --git a/libavformat/rtsp.h b/libavformat/rtsp.h
index f237268db8..83d88633b5 100644
--- a/libavformat/rtsp.h
+++ b/libavformat/rtsp.h
@@ -34,6 +34,7 @@ enum RTSPProtocol {
#define RTSP_DEFAULT_PORT 554
#define RTSP_MAX_TRANSPORTS 8
+#define RTSP_TCP_MAX_PACKET_SIZE 1472
typedef struct RTSPTransportField {
int interleaved_min, interleaved_max; /* interleave ids, if TCP transport */
@@ -77,10 +78,13 @@ void rtsp_set_callback(FFRTSPCallback *rtsp_cb);
int rtsp_init(void);
void rtsp_parse_line(RTSPHeader *reply, const char *buf);
-extern int rtsp_abort_req;
extern int rtsp_default_protocols;
extern int rtsp_rtp_port_min;
extern int rtsp_rtp_port_max;
extern FFRTSPCallback *ff_rtsp_callback;
+extern AVInputFormat rtsp_demux;
+
+int rtsp_pause(AVFormatContext *s);
+int rtsp_resume(AVFormatContext *s);
#endif /* RTSP_H */