aboutsummaryrefslogtreecommitdiffhomepage
path: root/libmpdemux/realrtsp
diff options
context:
space:
mode:
authorGravatar ben <ben@b3059339-0415-0410-9bf9-f77b7e298cf2>2006-06-23 19:30:15 +0000
committerGravatar ben <ben@b3059339-0415-0410-9bf9-f77b7e298cf2>2006-06-23 19:30:15 +0000
commit67d4bff07e9e789e5f988d653a904d03ab7fb90d (patch)
tree35bef4358e6950bc714267823f12ac2487ae44a3 /libmpdemux/realrtsp
parenteebd69a0513107fbeb6471c45434b493fa5e12aa (diff)
move real_rtsp init/uninit code to its dedicated place to simplify a bit rtsp session demuxer
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@18795 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpdemux/realrtsp')
-rw-r--r--libmpdemux/realrtsp/real.c23
-rw-r--r--libmpdemux/realrtsp/real.h16
-rw-r--r--libmpdemux/realrtsp/rtsp_session.c83
3 files changed, 83 insertions, 39 deletions
diff --git a/libmpdemux/realrtsp/real.c b/libmpdemux/realrtsp/real.c
index 2fe4d69459..af692f6862 100644
--- a/libmpdemux/realrtsp/real.c
+++ b/libmpdemux/realrtsp/real.c
@@ -59,6 +59,8 @@ const unsigned char xor_table[] = {
#define MAX(x,y) ((x>y) ? x : y)
#endif
+#define BUF_SIZE 4096
+
#ifdef LOG
static void hexdump (const char *buf, int length) {
@@ -846,3 +848,24 @@ rmff_header_t *real_setup_and_get_header(rtsp_t *rtsp_session, uint32_t bandwid
buf = xbuffer_free(buf);
return h;
}
+
+struct real_rtsp_session_t *
+init_real_rtsp_session (void)
+{
+ struct real_rtsp_session_t *real_rtsp_session = NULL;
+
+ real_rtsp_session = malloc (sizeof (struct real_rtsp_session_t));
+ real_rtsp_session->recv = xbuffer_init (BUF_SIZE);
+
+ return real_rtsp_session;
+}
+
+void
+free_real_rtsp_session (struct real_rtsp_session_t* real_session)
+{
+ if (!real_session)
+ return;
+
+ xbuffer_free (real_session->recv);
+ free (real_session);
+}
diff --git a/libmpdemux/realrtsp/real.h b/libmpdemux/realrtsp/real.h
index 410cc4f5c2..7fed8a239b 100644
--- a/libmpdemux/realrtsp/real.h
+++ b/libmpdemux/realrtsp/real.h
@@ -33,6 +33,20 @@
#include "rmff.h"
#include "rtsp.h"
+#define HEADER_SIZE 4096
+
+struct real_rtsp_session_t {
+ /* receive buffer */
+ uint8_t *recv;
+ int recv_size;
+ int recv_read;
+
+ /* header buffer */
+ uint8_t header[HEADER_SIZE];
+ int header_len;
+ int header_read;
+};
+
/*
* calculates response and checksum of a given challenge
* (RealChallenge1 in rtsp). See implementation for details.
@@ -41,6 +55,8 @@ void real_calc_response_and_checksum (char *response, char *chksum, char *challe
int real_get_rdt_chunk(rtsp_t *rtsp_session, char **buffer);
rmff_header_t *real_parse_sdp(char *data, char **stream_rules, uint32_t bandwidth);
rmff_header_t *real_setup_and_get_header(rtsp_t *rtsp_session, uint32_t bandwidth);
+struct real_rtsp_session_t *init_real_rtsp_session (void);
+void free_real_rtsp_session (struct real_rtsp_session_t* real_session);
#endif
diff --git a/libmpdemux/realrtsp/rtsp_session.c b/libmpdemux/realrtsp/rtsp_session.c
index 5a5a46eda9..71451b5bd5 100644
--- a/libmpdemux/realrtsp/rtsp_session.c
+++ b/libmpdemux/realrtsp/rtsp_session.c
@@ -52,35 +52,23 @@
#define LOG
*/
-#define BUF_SIZE 4096
-#define HEADER_SIZE 4096
-
struct rtsp_session_s {
-
rtsp_t *s;
-
- /* receive buffer */
- uint8_t *recv;
- int recv_size;
- int recv_read;
-
- /* header buffer */
- uint8_t header[HEADER_SIZE];
- int header_len;
- int header_read;
-
+ struct real_rtsp_session_t* real_session;
};
//rtsp_session_t *rtsp_session_start(char *mrl) {
rtsp_session_t *rtsp_session_start(int fd, char **mrl, char *path, char *host, int port, int *redir, uint32_t bandwidth) {
- rtsp_session_t *rtsp_session=malloc(sizeof(rtsp_session_t));
+ rtsp_session_t *rtsp_session = NULL;
char *server;
char *mrl_line = NULL;
rmff_header_t *h;
- rtsp_session->recv = xbuffer_init(BUF_SIZE);
-
+ rtsp_session = malloc (sizeof (rtsp_session_t));
+ rtsp_session->s = NULL;
+ rtsp_session->real_session = NULL;
+
//connect:
*redir = 0;
@@ -89,7 +77,6 @@ rtsp_session_t *rtsp_session_start(int fd, char **mrl, char *path, char *host, i
if (!rtsp_session->s)
{
printf("rtsp_session: failed to connect to server %s\n", path);
- rtsp_session->recv = xbuffer_free(rtsp_session->recv);
free(rtsp_session);
return NULL;
}
@@ -128,24 +115,29 @@ rtsp_session_t *rtsp_session_start(int fd, char **mrl, char *path, char *host, i
{
printf("rtsp_session: session can not be established.\n");
rtsp_close(rtsp_session->s);
- rtsp_session->recv = xbuffer_free(rtsp_session->recv);
+ free (server);
free(rtsp_session);
return NULL;
}
}
- rtsp_session->header_len=rmff_dump_header(h,rtsp_session->header,1024);
-
- rtsp_session->recv = xbuffer_copyin(rtsp_session->recv, 0, rtsp_session->header, rtsp_session->header_len);
- rtsp_session->recv_size = rtsp_session->header_len;
- rtsp_session->recv_read = 0;
-
+ rtsp_session->real_session = init_real_rtsp_session ();
+ rtsp_session->real_session->header_len =
+ rmff_dump_header (h, (char *) rtsp_session->real_session->header, 1024);
+
+ rtsp_session->real_session->recv =
+ xbuffer_copyin (rtsp_session->real_session->recv, 0,
+ rtsp_session->real_session->header,
+ rtsp_session->real_session->header_len);
+
+ rtsp_session->real_session->recv_size =
+ rtsp_session->real_session->header_len;
+ rtsp_session->real_session->recv_read = 0;
} else
{
printf("rtsp_session: Not a Real server. Server type is '%s'.\n",server);
rtsp_close(rtsp_session->s);
free(server);
- rtsp_session->recv = xbuffer_free(rtsp_session->recv);
free(rtsp_session);
return NULL;
}
@@ -156,10 +148,12 @@ rtsp_session_t *rtsp_session_start(int fd, char **mrl, char *path, char *host, i
int rtsp_session_read (rtsp_session_t *this, char *data, int len) {
+ if (this->real_session) {
int to_copy=len;
char *dest=data;
- char *source=this->recv + this->recv_read;
- int fill=this->recv_size - this->recv_read;
+ char *source =
+ (char *) (this->real_session->recv + this->real_session->recv_read);
+ int fill = this->real_session->recv_size - this->real_session->recv_read;
if (len < 0) return 0;
while (to_copy > fill) {
@@ -167,14 +161,15 @@ int rtsp_session_read (rtsp_session_t *this, char *data, int len) {
memcpy(dest, source, fill);
to_copy -= fill;
dest += fill;
- this->recv_read = 0;
- this->recv_size = real_get_rdt_chunk (this->s, (char **)&(this->recv));
- if (this->recv_size < 0)
+ this->real_session->recv_read = 0;
+ this->real_session->recv_size =
+ real_get_rdt_chunk (this->s, (char **)&(this->real_session->recv));
+ if (this->real_session->recv_size < 0)
return -1;
- source = this->recv;
- fill = this->recv_size;
+ source = (char *) this->real_session->recv;
+ fill = this->real_session->recv_size;
- if (this->recv_size == 0) {
+ if (this->real_session->recv_size == 0) {
#ifdef LOG
printf ("librtsp: %d of %d bytes provided\n", len-to_copy, len);
#endif
@@ -183,28 +178,38 @@ int rtsp_session_read (rtsp_session_t *this, char *data, int len) {
}
memcpy(dest, source, to_copy);
- this->recv_read += to_copy;
+ this->real_session->recv_read += to_copy;
#ifdef LOG
printf ("librtsp: %d bytes provided\n", len);
#endif
return len;
+ }
+
+ return 0;
}
int rtsp_session_peek_header(rtsp_session_t *this, char *buf, int maxsize) {
int len;
- len = (this->header_len < maxsize) ? this->header_len : maxsize;
+ if (this->real_session)
+ {
+ len = (this->real_session->header_len < maxsize)
+ ? this->real_session->header_len : maxsize;
- memcpy(buf, this->header, len);
+ memcpy(buf, this->real_session->header, len);
return len;
+ }
+
+ return 0;
}
void rtsp_session_end(rtsp_session_t *session) {
rtsp_close(session->s);
- session->recv = xbuffer_free(session->recv);
+ if (session->real_session)
+ free_real_rtsp_session (session->real_session);
free(session);
}