Commit 64310cf3 authored by Sam Hocevar's avatar Sam Hocevar

* ./modules/access/mms/mms.c: fixed signed/unsigned comparisons, and fixed

    a bug I found in Read(). No idea whether it was triggered before nor what
    it was doing, though :)
parent ee0a2449
......@@ -2,7 +2,7 @@
* buffer.c: MMS access plug-in
*****************************************************************************
* Copyright (C) 2001, 2002 VideoLAN
* $Id: buffer.c,v 1.2 2002/11/25 00:22:04 fenrir Exp $
* $Id: buffer.c,v 1.3 2002/12/06 13:05:22 sam Exp $
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
......@@ -10,7 +10,7 @@
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
......@@ -49,7 +49,7 @@ int var_buffer_initwrite( var_buffer_t *p_buf, int i_default_size )
int var_buffer_reinitwrite( var_buffer_t *p_buf, int i_default_size )
{
p_buf->i_data = 0;
if( p_buf->i_size < i_default_size )
if( p_buf->i_size < i_default_size )
{
p_buf->i_size = i_default_size;
if( p_buf->p_data )
......@@ -102,14 +102,14 @@ void var_buffer_add64( var_buffer_t *p_buf, uint64_t i_long )
void var_buffer_addmemory( var_buffer_t *p_buf, void *p_mem, int i_mem )
{
{
/* check if there is enough data */
if( p_buf->i_data + i_mem >= p_buf->i_size )
{
p_buf->i_size += i_mem + 1024;
p_buf->p_data = realloc( p_buf->p_data, p_buf->i_size );
}
memcpy( p_buf->p_data + p_buf->i_data,
p_mem,
i_mem );
......@@ -118,7 +118,7 @@ void var_buffer_addmemory( var_buffer_t *p_buf, void *p_mem, int i_mem )
void var_buffer_addUTF16( var_buffer_t *p_buf, char *p_str )
{
int i;
unsigned int i;
if( !p_str )
{
var_buffer_add16( p_buf, 0 );
......@@ -165,7 +165,7 @@ uint8_t var_buffer_get8 ( var_buffer_t *p_buf )
uint16_t var_buffer_get16( var_buffer_t *p_buf )
{
uint16_t i_b1, i_b2;
i_b1 = var_buffer_get8( p_buf );
i_b2 = var_buffer_get8( p_buf );
......@@ -176,7 +176,7 @@ uint16_t var_buffer_get16( var_buffer_t *p_buf )
uint32_t var_buffer_get32( var_buffer_t *p_buf )
{
uint32_t i_w1, i_w2;
i_w1 = var_buffer_get16( p_buf );
i_w2 = var_buffer_get16( p_buf );
......@@ -186,7 +186,7 @@ uint32_t var_buffer_get32( var_buffer_t *p_buf )
uint64_t var_buffer_get64( var_buffer_t *p_buf )
{
uint64_t i_dw1, i_dw2;
i_dw1 = var_buffer_get32( p_buf );
i_dw2 = var_buffer_get32( p_buf );
......@@ -219,7 +219,7 @@ int var_buffer_readempty( var_buffer_t *p_buf )
void var_buffer_getguid( var_buffer_t *p_buf, guid_t *p_guid )
{
int i;
p_guid->v1 = var_buffer_get32( p_buf );
p_guid->v2 = var_buffer_get16( p_buf );
p_guid->v3 = var_buffer_get16( p_buf );
......
......@@ -2,7 +2,7 @@
* mms.c: MMS access plug-in
*****************************************************************************
* Copyright (C) 2001, 2002 VideoLAN
* $Id: mms.c,v 1.11 2002/12/04 06:23:08 titer Exp $
* $Id: mms.c,v 1.12 2002/12/06 13:05:22 sam Exp $
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
......@@ -10,7 +10,7 @@
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
......@@ -70,7 +70,7 @@
#include "mms.h"
/****************************************************************************
* NOTES:
* NOTES:
* MMSProtocole documentation found at http://get.to/sdp
****************************************************************************/
......@@ -83,7 +83,7 @@ static void Close ( vlc_object_t * );
static int Read ( input_thread_t * p_input, byte_t * p_buffer,
size_t i_len );
static void Seek ( input_thread_t *, off_t );
static int SetProgram ( input_thread_t *, pgrm_descriptor_t * );
static int SetProgram ( input_thread_t *, pgrm_descriptor_t * );
static int MMSOpen( input_thread_t *, url_t *, int, char * );
......@@ -100,21 +100,21 @@ static int mms_CommandSend( input_thread_t *, int, uint32_t, uint32_t, uint8_t
static int mms_HeaderMediaRead( input_thread_t *, int );
static int mms_ReceivePacket( input_thread_t * );
static void mms_ParseURL( url_t *p_url, char *psz_url );
/*
/*
* XXX DON'T FREE MY MEMORY !!! XXX
* non mais :P
*/
/*
/*
* Ok, ok, j'le ferai plus...
*/
/*
* Merci :))
* Merci :))
*/
/*****************************************************************************
......@@ -124,14 +124,14 @@ vlc_module_begin();
set_description( _("MMS access module") );
set_capability( "access", 0 );
add_category_hint( "stream", NULL );
add_bool( "mms-all", 0, NULL,
add_bool( "mms-all", 0, NULL,
"force selection of all streams",
"force selection of all streams" );
add_string( "mms-stream", NULL, NULL,
"streams selection",
"force this stream selection" );
add_integer( "mms-maxbitrate", 0, NULL,
add_integer( "mms-maxbitrate", 0, NULL,
"max bitrate",
"set max bitrate for auto streams selections" );
add_shortcut( "mms" );
......@@ -152,14 +152,14 @@ static int Open( vlc_object_t *p_this )
input_thread_t *p_input = (input_thread_t*)p_this;
/* *** allocate p_access_data *** */
p_input->p_access_data =
p_input->p_access_data =
(void*)p_access = malloc( sizeof( access_t ) );
memset( p_access, 0, sizeof( access_t ) );
/* *** Parse URL and get server addr/port and path *** */
mms_ParseURL( &p_access->url, p_input->psz_name );
if( p_access->url.psz_server_addr == NULL ||
if( p_access->url.psz_server_addr == NULL ||
!( *p_access->url.psz_server_addr ) )
{
FREE( p_access->url.psz_private );
......@@ -167,14 +167,14 @@ static int Open( vlc_object_t *p_this )
return( -1 );
}
if( p_access->url.i_server_port == 0 )
{
{
p_access->url.i_server_port = 1755; /* default port */
}
if( p_access->url.i_bind_port == 0 )
{
{
p_access->url.i_bind_port = 7000; /* default port */
}
/* *** connect to this server *** */
/* 1: look at requested protocol (udp/tcp) */
......@@ -203,18 +203,18 @@ static int Open( vlc_object_t *p_this )
/* 3: connect */
if( i_proto == MMS_PROTO_AUTO )
{ /* first try with TCP */
i_status =
i_status =
MMSOpen( p_input, &p_access->url, MMS_PROTO_TCP, psz_network );
if( i_status < 0 )
{ /* then with UDP */
i_status =
i_status =
MMSOpen( p_input, &p_access->url, MMS_PROTO_UDP, psz_network );
}
}
else
{
i_status =
i_status =
MMSOpen( p_input, &p_access->url, i_proto, psz_network );
}
......@@ -226,13 +226,13 @@ static int Open( vlc_object_t *p_this )
}
msg_Dbg( p_input, "connected to %s", p_access->url.psz_server_addr );
/* *** set exported functions *** */
p_input->pf_read = Read;
p_input->pf_seek = Seek;
p_input->pf_set_program = SetProgram;
p_input->pf_set_area = NULL;
p_input->p_private = NULL;
/* *** finished to set some variable *** */
......@@ -254,11 +254,11 @@ static int Open( vlc_object_t *p_this )
else
{
p_input->stream.b_seekable = 1;
p_input->stream.p_selected_area->i_size =
p_access->i_header +
p_input->stream.p_selected_area->i_size =
p_access->i_header +
p_access->i_packet_count * p_access->i_packet_length;
}
p_input->stream.i_method = INPUT_METHOD_NETWORK;
vlc_mutex_unlock( &p_input->stream.stream_lock );
......@@ -270,7 +270,7 @@ static int Open( vlc_object_t *p_this )
FREE( p_access->url.psz_private );
return( -1 );
}
return( 0 );
}
......@@ -281,10 +281,10 @@ static void Close( vlc_object_t *p_this )
{
input_thread_t * p_input = (input_thread_t *)p_this;
access_t *p_access = (access_t*)p_input->p_access_data;
/* close connection with server */
MMSClose( p_input );
/* free memory */
FREE( p_access->url.psz_private );
}
......@@ -303,12 +303,12 @@ static int SetProgram( input_thread_t * p_input,
*****************************************************************************/
static void Seek( input_thread_t * p_input, off_t i_pos )
{
/*
* FIXME
/*
* FIXME
* Don't work
* Probably some bad or missing command
*
*
*
*/
#if 1
......@@ -316,20 +316,20 @@ static void Seek( input_thread_t * p_input, off_t i_pos )
uint32_t i_packet;
uint32_t i_offset;
var_buffer_t buffer;
if( i_pos < 0 )
{
return;
}
}
vlc_mutex_lock( &p_input->stream.stream_lock );
if( i_pos < p_access->i_header)
{
if( p_access->i_pos < p_access->i_header )
{
/* no need to restart stream, it was already one
/* no need to restart stream, it was already one
* or no stream was yet read */
p_access->i_pos = i_pos;
return;
......@@ -353,19 +353,19 @@ static void Seek( input_thread_t * p_input, off_t i_pos )
/* *** restart stream *** */
var_buffer_initwrite( &buffer, 0 );
var_buffer_add64( &buffer, 0 ); /* seek point in second */
var_buffer_add32( &buffer, 0xffffffff );
var_buffer_add32( &buffer, 0xffffffff );
var_buffer_add32( &buffer, i_packet ); // begin from start
var_buffer_add8( &buffer, 0xff ); // stream time limit
var_buffer_add8( &buffer, 0xff ); // on 3bytes ...
var_buffer_add8( &buffer, 0xff ); //
var_buffer_add8( &buffer, 0x00 ); // don't use limit
var_buffer_add32( &buffer, p_access->i_media_packet_id_type );
mms_CommandSend( p_input, 0x07, p_access->i_command_level, 0x0001ffff,
var_buffer_add32( &buffer, p_access->i_media_packet_id_type );
mms_CommandSend( p_input, 0x07, p_access->i_command_level, 0x0001ffff,
buffer.p_data, buffer.i_data );
var_buffer_free( &buffer );
for( ;; )
{
......@@ -376,7 +376,7 @@ static void Seek( input_thread_t * p_input, off_t i_pos )
break;
}
}
for( ;; )
{
mms_HeaderMediaRead( p_input, MMS_PACKET_CMD );
......@@ -386,11 +386,11 @@ static void Seek( input_thread_t * p_input, off_t i_pos )
break;
}
}
/* get a packet */
mms_HeaderMediaRead( p_input, MMS_PACKET_MEDIA );
msg_Dbg( p_input, "Streaming restarted" );
p_access->i_media_used += i_offset;
p_access->i_pos = i_pos;
p_input->stream.p_selected_area->i_tell = i_pos;
......@@ -407,14 +407,14 @@ static int Read ( input_thread_t * p_input, byte_t * p_buffer,
size_t i_copy;
i_data = 0;
/* *** send header if needed ** */
if( p_access->i_pos < p_access->i_header )
{
{
i_copy = __MIN( i_len, p_access->i_header - p_access->i_pos );
if( i_copy > 0 )
{
memcpy( p_buffer,
memcpy( p_buffer,
p_access->p_header + p_access->i_pos,
i_copy );
}
......@@ -426,15 +426,15 @@ static int Read ( input_thread_t * p_input, byte_t * p_buffer,
{
if( p_access->i_media_used < p_access->i_media )
{
i_copy = __MIN( i_len - i_data ,
i_copy = __MIN( i_len - i_data ,
p_access->i_media - p_access->i_media_used );
memcpy( p_buffer + i_data,
memcpy( p_buffer + i_data,
p_access->p_media + p_access->i_media_used,
i_copy );
i_data += i_copy;
p_access->i_media_used += i_copy;
}
else if( p_access->p_media != NULL &&
else if( p_access->p_media != NULL &&
p_access->i_media_used < p_access->i_packet_length )
{
i_copy = __MIN( i_len - i_data,
......@@ -446,7 +446,8 @@ static int Read ( input_thread_t * p_input, byte_t * p_buffer,
}
else
{
if( p_access->i_eos || mms_HeaderMediaRead( p_input, MMS_PACKET_MEDIA ) < 0 );
if( p_access->i_eos
|| mms_HeaderMediaRead( p_input, MMS_PACKET_MEDIA ) < 0 )
{
p_access->i_pos += i_data;
return( i_data );
......@@ -465,7 +466,7 @@ static void asf_HeaderParse( mms_stream_t stream[128],
guid_t guid;
uint64_t i_size;
int i;
for( i = 0; i < 128; i++ )
{
stream[i].i_cat = MMS_STREAM_UNKNOWN;
......@@ -473,7 +474,7 @@ static void asf_HeaderParse( mms_stream_t stream[128],
// fprintf( stderr, " ---------------------header:%d\n", i_header );
var_buffer_initread( &buffer, p_header, i_header );
var_buffer_getguid( &buffer, &guid );
if( !CmpGuid( &guid, &asf_object_header_guid ) )
......@@ -482,7 +483,7 @@ static void asf_HeaderParse( mms_stream_t stream[128],
// fprintf( stderr, " ---------------------ERROR------\n" );
}
var_buffer_getmemory( &buffer, NULL, 30 - 16 );
for( ;; )
{
// fprintf( stderr, " ---------------------data:%d\n", buffer.i_data );
......@@ -498,14 +499,14 @@ static void asf_HeaderParse( mms_stream_t stream[128],
int i_stream_id;
guid_t stream_type;
// msg_Dbg( p_input, "found stream_properties" );
var_buffer_getguid( &buffer, &stream_type );
var_buffer_getmemory( &buffer, NULL, 32 );
i_stream_id = var_buffer_get8( &buffer ) & 0x7f;
// fprintf( stderr, " 1---------------------skip:%lld\n", i_size - 24 - 32 - 16 - 1 );
var_buffer_getmemory( &buffer, NULL, i_size - 24 - 32 - 16 - 1);
if( CmpGuid( &stream_type, &asf_object_stream_type_video ) )
{
// msg_Dbg( p_input, "video stream[%d] found", i_stream_id );
......@@ -526,7 +527,7 @@ static void asf_HeaderParse( mms_stream_t stream[128],
{
int i_count;
uint8_t i_stream_id;
i_count = var_buffer_get16( &buffer );
i_size -= 2;
while( i_count > 0 )
......@@ -539,7 +540,7 @@ static void asf_HeaderParse( mms_stream_t stream[128],
// fprintf( stderr, " 2---------------------skip:%lld\n", i_size - 24);
var_buffer_getmemory( &buffer, NULL, i_size - 24 );
}
else
else
{
// skip unknown guid
var_buffer_getmemory( &buffer, NULL, i_size - 24 );
......@@ -548,7 +549,7 @@ static void asf_HeaderParse( mms_stream_t stream[128],
}
}
static void mms_StreamSelect( input_thread_t * p_input,
static void mms_StreamSelect( input_thread_t * p_input,
mms_stream_t stream[128] )
{
/* XXX FIXME use mututal eclusion information */
......@@ -617,18 +618,18 @@ static void mms_StreamSelect( input_thread_t * p_input,
FREE( psz_stream );
/* big test:
* select a stream if
* - no audio nor video stream
* - or:
* select a stream if
* - no audio nor video stream
* - or:
* - if i_bitrate_max not set keep the highest bitrate
* - if i_bitrate_max is set, keep stream that make we used best
* quality regarding i_bitrate_max
*
* XXX: little buggy:
* - it doesn't use mutual exclusion info..
* - when selecting a better stream we could select
* - when selecting a better stream we could select
* something that make i_bitrate_total> i_bitrate_max
*/
*/
for( i = 1; i < 128; i++ )
{
if( stream[i].i_cat == MMS_STREAM_UNKNOWN )
......@@ -636,11 +637,11 @@ static void mms_StreamSelect( input_thread_t * p_input,
continue;
}
else if( stream[i].i_cat == MMS_STREAM_AUDIO && b_audio &&
( i_audio <= 0 ||
( ( ( stream[i].i_bitrate > stream[i_audio].i_bitrate &&
( i_bitrate_total + stream[i].i_bitrate - stream[i_audio].i_bitrate
( i_audio <= 0 ||
( ( ( stream[i].i_bitrate > stream[i_audio].i_bitrate &&
( i_bitrate_total + stream[i].i_bitrate - stream[i_audio].i_bitrate
< i_bitrate_max || !i_bitrate_max) ) ||
( stream[i].i_bitrate < stream[i_audio].i_bitrate &&
( stream[i].i_bitrate < stream[i_audio].i_bitrate &&
i_bitrate_max != 0 && i_bitrate_total > i_bitrate_max )
) ) ) )
{
......@@ -662,12 +663,12 @@ static void mms_StreamSelect( input_thread_t * p_input,
i_audio = i;
}
else if( stream[i].i_cat == MMS_STREAM_VIDEO && b_video &&
( i_video <= 0 ||
( i_video <= 0 ||
(
( ( stream[i].i_bitrate > stream[i_video].i_bitrate &&
( i_bitrate_total + stream[i].i_bitrate - stream[i_video].i_bitrate
( ( stream[i].i_bitrate > stream[i_video].i_bitrate &&
( i_bitrate_total + stream[i].i_bitrate - stream[i_video].i_bitrate
< i_bitrate_max || !i_bitrate_max) ) ||
( stream[i].i_bitrate < stream[i_video].i_bitrate &&
( stream[i].i_bitrate < stream[i_video].i_bitrate &&
i_bitrate_max != 0 && i_bitrate_total > i_bitrate_max )
) ) ) )
{
......@@ -690,14 +691,14 @@ static void mms_StreamSelect( input_thread_t * p_input,
}
if( i_bitrate_max > 0 )
{
msg_Dbg( p_input,
"requested bitrate:%d real bitrate:%d",
msg_Dbg( p_input,
"requested bitrate:%d real bitrate:%d",
i_bitrate_max, i_bitrate_total );
}
else
{
msg_Dbg( p_input,
"total bitrate:%d",
msg_Dbg( p_input,
"total bitrate:%d",
i_bitrate_total );
}
}
......@@ -744,7 +745,7 @@ static int MMSOpen( input_thread_t *p_input,
module_Unneed( p_input, p_network );
p_access->socket_tcp.i_handle = socket_desc.i_handle;
p_input->i_mtu = 0; /*socket_desc.i_mtu;*/
msg_Dbg( p_input,
msg_Dbg( p_input,
"connection(tcp) with \"%s:%d\" successful",
p_url->psz_server_addr,
p_url->i_server_port );
......@@ -757,7 +758,7 @@ static int MMSOpen( input_thread_t *p_input,
struct sockaddr_in name;
socklen_t i_namelen = sizeof( struct sockaddr_in );
if( getsockname( p_access->socket_tcp.i_handle,
if( getsockname( p_access->socket_tcp.i_handle,
(struct sockaddr*)&name, &i_namelen ) < 0 )
{
......@@ -807,8 +808,8 @@ static int MMSOpen( input_thread_t *p_input,
/* *** Init context for mms prototcol *** */
GenerateGuid( &p_access->guid ); /* used to identify client by server */
msg_Dbg( p_input,
"generated guid: "GUID_FMT,
msg_Dbg( p_input,
"generated guid: "GUID_FMT,
GUID_PRINT( p_access->guid ) );
p_access->i_command_level = 1; /* updated after 0x1A command */
p_access->i_seq_num = 0;
......@@ -833,12 +834,12 @@ static int MMSOpen( input_thread_t *p_input,
var_buffer_initwrite( &buffer, 0 );
var_buffer_add16( &buffer, 0x001c );
var_buffer_add16( &buffer, 0x0003 );
sprintf( tmp,
sprintf( tmp,
"NSPlayer/7.0.0.1956; {"GUID_FMT"}; Host: %s",
GUID_PRINT( p_access->guid ),
p_url->psz_server_addr );
var_buffer_addUTF16( &buffer, tmp );
mms_CommandSend( p_input,
0x01, /* connexion request */
0x00000000, /* flags, FIXME */
......@@ -868,7 +869,7 @@ static int MMSOpen( input_thread_t *p_input,
GETUTF16( p_access->psz_update_player_url, i_update_player_url );
GETUTF16( p_access->psz_encryption_type, i_encryption_type );
#undef GETUTF16
msg_Dbg( p_input,
msg_Dbg( p_input,
"0x01 --> server_version:\"%s\" tool_version:\"%s\" update_player_url:\"%s\" encryption_type:\"%s\"",
p_access->psz_server_version,
p_access->psz_tool_version,
......@@ -876,7 +877,7 @@ static int MMSOpen( input_thread_t *p_input,
p_access->psz_encryption_type );
/* *** should make an 18 command to make data timing *** */
/* *** send command 2 : transport protocol selection *** */
var_buffer_reinitwrite( &buffer, 0 );
var_buffer_add32( &buffer, 0x00000000 );
......@@ -884,7 +885,7 @@ static int MMSOpen( input_thread_t *p_input,
var_buffer_add32( &buffer, 0x00000002 );
if( b_udp )
{
sprintf( tmp,
sprintf( tmp,
"\\\\%s\\UDP\\%d",
p_access->psz_bind_addr,
p_url->i_bind_port );
......@@ -895,7 +896,7 @@ static int MMSOpen( input_thread_t *p_input,
}
var_buffer_addUTF16( &buffer, tmp );
var_buffer_add16( &buffer, '0' );
mms_CommandSend( p_input,
0x02, /* connexion request */
0x00000000, /* flags, FIXME */
......@@ -907,7 +908,7 @@ static int MMSOpen( input_thread_t *p_input,
mms_CommandRead( p_input, 0x02, 0x03 );
if( p_access->i_command == 0x03 )
{
msg_Err( p_input,
msg_Err( p_input,
"%s protocol selection failed", b_udp ? "UDP" : "TCP" );
var_buffer_free( &buffer );
MMSClose( p_input );
......@@ -917,13 +918,13 @@ static int MMSOpen( input_thread_t *p_input,
{
msg_Warn( p_input, "received command isn't 0x02 in reponse to 0x02" );
}
/* *** send command 5 : media file name/path requested *** */
var_buffer_reinitwrite( &buffer, 0 );
var_buffer_add64( &buffer, 0 );
var_buffer_addUTF16( &buffer, p_url->psz_path );
mms_CommandSend( p_input,
mms_CommandSend( p_input,
0x05,
p_access->i_command_level,
0xffffffff,
......@@ -932,7 +933,7 @@ static int MMSOpen( input_thread_t *p_input,
/* *** wait for reponse *** */
mms_CommandRead( p_input, 0x1a, 0x06 );
/* test if server send 0x1A answer */
if( p_access->i_command == 0x1A )
{
......@@ -944,7 +945,7 @@ static int MMSOpen( input_thread_t *p_input,
}
if( p_access->i_command != 0x06 )
{
msg_Err( p_input,
msg_Err( p_input,
"unknown answer (0x%x instead of 0x06)",
p_access->i_command );
var_buffer_free( &buffer );
......@@ -970,7 +971,7 @@ static int MMSOpen( input_thread_t *p_input,
return( -1 );
}
p_access->i_flags_broadcast =
p_access->i_flags_broadcast =
GetDWLE( p_access->p_cmd + MMS_CMD_HEADERSIZE + 12 );
p_access->i_media_length =
GetDWLE( p_access->p_cmd + MMS_CMD_HEADERSIZE + 24 );
......@@ -991,12 +992,12 @@ static int MMSOpen( input_thread_t *p_input,
p_access->i_packet_count,
p_access->i_max_bit_rate,
p_access->i_header_size );
/* XXX XXX dirty hack XXX XXX */
p_input->i_mtu = 3 * p_access->i_packet_length;
/* *** send command 15 *** */
var_buffer_reinitwrite( &buffer, 0 );
var_buffer_add32( &buffer, 0 );
var_buffer_add32( &buffer, 0x8000 );
......@@ -1006,7 +1007,7 @@ static int MMSOpen( input_thread_t *p_input,
var_buffer_add32( &buffer, 0x00 );
var_buffer_add64( &buffer, 0x40ac200000000000 );
var_buffer_add32( &buffer, p_access->i_header_packet_id_type );
mms_CommandSend( p_input, 0x15, p_access->i_command_level, 0x00,
mms_CommandSend( p_input, 0x15, p_access->i_command_level, 0x00,
buffer.p_data, buffer.i_data );
/* *** wait for reponse *** */
......@@ -1014,7 +1015,7 @@ static int MMSOpen( input_thread_t *p_input,
if( p_access->i_command != 0x11 )
{
msg_Err( p_input,
msg_Err( p_input,
"unknown answer (0x%x instead of 0x11)",
p_access->i_command );
var_buffer_free( &buffer );
......@@ -1031,10 +1032,10 @@ static int MMSOpen( input_thread_t *p_input,
}
/* *** parse header and get stream and their id *** */
/* get all streams properties,
*
*
* TODO : stream bitrates properties(optional)
* and bitrate mutual exclusion(optional) */
asf_HeaderParse( p_access->stream,
asf_HeaderParse( p_access->stream,