* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
-#include <stdio.h>
-#include <string.h>
-#include <vlc/vlc.h>
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <vlc_common.h>
#include "rtsp.h"
#include "real.h"
b = ((b << 0x17) | (b >> 0x09)) + c;
a = ((~d | b) ^ c) + LE_32((param+0x00)) + a - 0x0BD6DDBC;
- a = ((a << 0x06) | (a >> 0x1a)) + b;
+ a = ((a << 0x06) | (a >> 0x1a)) + b;
d = ((~c | a) ^ b) + LE_32((param+0x1c)) + d + 0x432AFF97;
- d = ((d << 0x0a) | (d >> 0x16)) + a;
+ d = ((d << 0x0a) | (d >> 0x16)) + a;
c = ((~b | d) ^ a) + LE_32((param+0x38)) + c - 0x546BDC59;
- c = ((c << 0x0f) | (c >> 0x11)) + d;
+ c = ((c << 0x0f) | (c >> 0x11)) + d;
b = ((~a | c) ^ d) + LE_32((param+0x14)) + b - 0x036C5FC7;
- b = ((b << 0x15) | (b >> 0x0b)) + c;
+ b = ((b << 0x15) | (b >> 0x0b)) + c;
a = ((~d | b) ^ c) + LE_32((param+0x30)) + a + 0x655B59C3;
- a = ((a << 0x06) | (a >> 0x1a)) + b;
+ a = ((a << 0x06) | (a >> 0x1a)) + b;
d = ((~c | a) ^ b) + LE_32((param+0x0C)) + d - 0x70F3336E;
- d = ((d << 0x0a) | (d >> 0x16)) + a;
+ d = ((d << 0x0a) | (d >> 0x16)) + a;
c = ((~b | d) ^ a) + LE_32((param+0x28)) + c - 0x00100B83;
- c = ((c << 0x0f) | (c >> 0x11)) + d;
+ c = ((c << 0x0f) | (c >> 0x11)) + d;
b = ((~a | c) ^ d) + LE_32((param+0x04)) + b - 0x7A7BA22F;
- b = ((b << 0x15) | (b >> 0x0b)) + c;
+ b = ((b << 0x15) | (b >> 0x0b)) + c;
a = ((~d | b) ^ c) + LE_32((param+0x20)) + a + 0x6FA87E4F;
- a = ((a << 0x06) | (a >> 0x1a)) + b;
+ a = ((a << 0x06) | (a >> 0x1a)) + b;
d = ((~c | a) ^ b) + LE_32((param+0x3c)) + d - 0x01D31920;
- d = ((d << 0x0a) | (d >> 0x16)) + a;
+ d = ((d << 0x0a) | (d >> 0x16)) + a;
c = ((~b | d) ^ a) + LE_32((param+0x18)) + c - 0x5CFEBCEC;
- c = ((c << 0x0f) | (c >> 0x11)) + d;
+ c = ((c << 0x0f) | (c >> 0x11)) + d;
b = ((~a | c) ^ d) + LE_32((param+0x34)) + b + 0x4E0811A1;
- b = ((b << 0x15) | (b >> 0x0b)) + c;
+ b = ((b << 0x15) | (b >> 0x0b)) + c;
a = ((~d | b) ^ c) + LE_32((param+0x10)) + a - 0x08AC817E;
- a = ((a << 0x06) | (a >> 0x1a)) + b;
+ a = ((a << 0x06) | (a >> 0x1a)) + b;
d = ((~c | a) ^ b) + LE_32((param+0x2c)) + d - 0x42C50DCB;
- d = ((d << 0x0a) | (d >> 0x16)) + a;
+ d = ((d << 0x0a) | (d >> 0x16)) + a;
c = ((~b | d) ^ a) + LE_32((param+0x08)) + c + 0x2AD7D2BB;
- c = ((c << 0x0f) | (c >> 0x11)) + d;
+ c = ((c << 0x0f) | (c >> 0x11)) + d;
b = ((~a | c) ^ d) + LE_32((param+0x24)) + b - 0x14792C6F;
- b = ((b << 0x15) | (b >> 0x0b)) + c;
+ b = ((b << 0x15) | (b >> 0x0b)) + c;
lprintf("hash output: %x %x %x %x\n", a, b, c, d);
desc=sdpplin_parse(data);
if( !desc ) return NULL;
- buf= (char *)malloc(sizeof(char)*2048);
+ buf= (char *)malloc(2048);
if( !buf ) goto error;
header = (rmff_header_t*)malloc(sizeof(rmff_header_t));
if (!desc->stream[i]->mlti_data) {
len = 0;
- if( buf ) free( buf );
+ free( buf );
buf = NULL;
} else
len=select_mlti_data(desc->stream[i]->mlti_data,
rmff_fix_header(header);
if( desc ) sdpplin_free( desc );
- if( buf ) free(buf);
+ free( buf );
return header;
error:
if( desc ) sdpplin_free( desc );
if( header ) rmff_free_header( header );
- if( buf ) free( buf );
+ free( buf );
return NULL;
}
char challenge2[64];
char checksum[34];
char *subscribe=NULL;
- char *buf=(char*)malloc(sizeof(char)*256);
+ char *buf=(char*)malloc(256);
char *mrl=rtsp_get_mrl(rtsp_session);
unsigned int size;
int status;
if (alert) {
lprintf("real: got message from server:\n%s\n", alert);
}
- printf( "bou\n");
- rtsp_send_ok(rtsp_session);
- if( challenge1 ) free(challenge1);
- if( alert ) free(alert);
- if( buf ) free(buf);
+ rtsp_send_ok( rtsp_session );
+ free( challenge1 );
+ free( alert );
+ free( buf );
return NULL;
}
lprintf("Stream description size: %i\n", size);
- description = (char*)malloc(sizeof(char)*(size+1));
+ description = (char*)malloc(size+1);
if( !description )
goto error;
if( rtsp_read_data(rtsp_session, (uint8_t*)description, size) <= 0)
goto error;
description[size]=0;
- fprintf(stderr, "%s", description);
+ //fprintf(stderr, "%s", description);
/* parse sdp (sdpplin) and create a header and a subscribe string */
- subscribe = (char *) malloc(sizeof(char)*256);
+ subscribe = (char *) malloc(256);
if( !subscribe )
goto error;
rtsp_schedule_field(rtsp_session, "Range: npt=0-");
rtsp_request_play(rtsp_session,NULL);
- if( challenge1 ) free( challenge1 );
- if( session_id ) free( session_id );
- if( description ) free(description);
- if( subscribe ) free(subscribe);
- if( buf ) free(buf);
+ free( challenge1 );
+ free( session_id );
+ free( description );
+ free( subscribe );
+ free( buf );
return h;
error:
if( h ) rmff_free_header( h );
- if( challenge1 ) free( challenge1 );
- if( session_id ) free( session_id );
- if( description ) free(description);
- if( subscribe ) free(subscribe);
- if( buf ) free(buf);
+ free( challenge1 );
+ free( session_id );
+ free( description );
+ free( subscribe );
+ free( buf );
return NULL;
}