Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
e6c26135
Commit
e6c26135
authored
Jan 22, 2004
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* mmstu: workaround for low bitrate stream with mmst.
(we don't try anymore to fill our buffer every time).
parent
209771fe
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
69 additions
and
51 deletions
+69
-51
modules/access/mms/mmstu.c
modules/access/mms/mmstu.c
+69
-51
No files found.
modules/access/mms/mmstu.c
View file @
e6c26135
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
* mms.c: MMS access plug-in
* mms.c: MMS access plug-in
*****************************************************************************
*****************************************************************************
* Copyright (C) 2001, 2002 VideoLAN
* Copyright (C) 2001, 2002 VideoLAN
* $Id: mmstu.c,v 1.
7 2004/01/21 16:56:16
fenrir Exp $
* $Id: mmstu.c,v 1.
8 2004/01/22 18:49:38
fenrir Exp $
*
*
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
* Authors: Laurent Aimar <fenrir@via.ecp.fr>
*
*
...
@@ -77,16 +77,13 @@ int E_( MMSTUOpen ) ( input_thread_t * );
...
@@ -77,16 +77,13 @@ int E_( MMSTUOpen ) ( input_thread_t * );
void
E_
(
MMSTUClose
)
(
input_thread_t
*
);
void
E_
(
MMSTUClose
)
(
input_thread_t
*
);
static
ssize_t
Read
(
input_thread_t
*
p_input
,
byte_t
*
p_buffer
,
static
ssize_t
Read
(
input_thread_t
*
,
byte_t
*
,
size_t
);
size_t
i_len
);
static
void
Seek
(
input_thread_t
*
,
off_t
);
static
void
Seek
(
input_thread_t
*
,
off_t
);
static
int
MMSOpen
(
input_thread_t
*
,
url_t
*
,
int
);
static
int
MMSOpen
(
input_thread_t
*
,
url_t
*
,
int
);
static
int
MMSStart
(
input_thread_t
*
,
uint32_t
);
static
int
MMSStart
(
input_thread_t
*
,
uint32_t
);
static
int
MMSStop
(
input_thread_t
*
);
static
int
MMSStop
(
input_thread_t
*
p_input
);
static
void
MMSClose
(
input_thread_t
*
);
static
int
MMSClose
(
input_thread_t
*
);
static
int
mms_CommandRead
(
input_thread_t
*
p_input
,
int
i_command1
,
int
i_command2
);
static
int
mms_CommandRead
(
input_thread_t
*
p_input
,
int
i_command1
,
int
i_command2
);
...
@@ -114,7 +111,7 @@ static int mms_ReceivePacket( input_thread_t * );
...
@@ -114,7 +111,7 @@ static int mms_ReceivePacket( input_thread_t * );
* merde :p.
* merde :p.
*/
*/
int
E_
(
MMSTUOpen
)
(
input_thread_t
*
p_input
)
int
E_
(
MMSTUOpen
)
(
input_thread_t
*
p_input
)
{
{
access_sys_t
*
p_sys
;
access_sys_t
*
p_sys
;
int
i_proto
;
int
i_proto
;
...
@@ -230,7 +227,7 @@ int E_( MMSTUOpen ) ( input_thread_t *p_input )
...
@@ -230,7 +227,7 @@ int E_( MMSTUOpen ) ( input_thread_t *p_input )
/*****************************************************************************
/*****************************************************************************
* Close: free unused data structures
* Close: free unused data structures
*****************************************************************************/
*****************************************************************************/
void
E_
(
MMSTUClose
)
(
input_thread_t
*
p_input
)
void
E_
(
MMSTUClose
)
(
input_thread_t
*
p_input
)
{
{
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
...
@@ -333,8 +330,10 @@ static void Seek( input_thread_t * p_input, off_t i_pos )
...
@@ -333,8 +330,10 @@ static void Seek( input_thread_t * p_input, off_t i_pos )
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
vlc_mutex_unlock
(
&
p_input
->
stream
.
stream_lock
);
}
}
static
ssize_t
Read
(
input_thread_t
*
p_input
,
byte_t
*
p_buffer
,
/*****************************************************************************
size_t
i_len
)
* Read:
*****************************************************************************/
static
ssize_t
Read
(
input_thread_t
*
p_input
,
byte_t
*
p_buffer
,
size_t
i_len
)
{
{
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
size_t
i_data
;
size_t
i_data
;
...
@@ -803,7 +802,7 @@ static int MMSOpen( input_thread_t *p_input, url_t *p_url, int i_proto )
...
@@ -803,7 +802,7 @@ static int MMSOpen( input_thread_t *p_input, url_t *p_url, int i_proto )
/****************************************************************************
/****************************************************************************
* MMSStart : Start streaming
* MMSStart : Start streaming
****************************************************************************/
****************************************************************************/
static
int
MMSStart
(
input_thread_t
*
p_input
,
uint32_t
i_packet
)
static
int
MMSStart
(
input_thread_t
*
p_input
,
uint32_t
i_packet
)
{
{
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
var_buffer_t
buffer
;
var_buffer_t
buffer
;
...
@@ -845,7 +844,7 @@ static int MMSStart ( input_thread_t *p_input, uint32_t i_packet )
...
@@ -845,7 +844,7 @@ static int MMSStart ( input_thread_t *p_input, uint32_t i_packet )
/****************************************************************************
/****************************************************************************
* MMSStop : Stop streaming
* MMSStop : Stop streaming
****************************************************************************/
****************************************************************************/
static
int
MMSStop
(
input_thread_t
*
p_input
)
static
int
MMSStop
(
input_thread_t
*
p_input
)
{
{
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
...
@@ -861,7 +860,7 @@ static int MMSStop ( input_thread_t *p_input )
...
@@ -861,7 +860,7 @@ static int MMSStop ( input_thread_t *p_input )
/****************************************************************************
/****************************************************************************
* MMSClose : Close streaming and connection
* MMSClose : Close streaming and connection
****************************************************************************/
****************************************************************************/
static
int
MMSClose
(
input_thread_t
*
p_input
)
static
void
MMSClose
(
input_thread_t
*
p_input
)
{
{
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
access_sys_t
*
p_sys
=
p_input
->
p_access_data
;
...
@@ -889,8 +888,6 @@ static int MMSClose ( input_thread_t *p_input )
...
@@ -889,8 +888,6 @@ static int MMSClose ( input_thread_t *p_input )
FREE
(
p_sys
->
psz_tool_version
);
FREE
(
p_sys
->
psz_tool_version
);
FREE
(
p_sys
->
psz_update_player_url
);
FREE
(
p_sys
->
psz_update_player_url
);
FREE
(
p_sys
->
psz_encryption_type
);
FREE
(
p_sys
->
psz_encryption_type
);
return
(
0
);
}
}
/****************************************************************************
/****************************************************************************
...
@@ -898,7 +895,6 @@ static int MMSClose ( input_thread_t *p_input )
...
@@ -898,7 +895,6 @@ static int MMSClose ( input_thread_t *p_input )
* MMS specific functions
* MMS specific functions
*
*
****************************************************************************/
****************************************************************************/
static
int
mms_CommandSend
(
input_thread_t
*
p_input
,
static
int
mms_CommandSend
(
input_thread_t
*
p_input
,
int
i_command
,
int
i_command
,
uint32_t
i_prefix1
,
uint32_t
i_prefix2
,
uint32_t
i_prefix1
,
uint32_t
i_prefix2
,
...
@@ -940,11 +936,11 @@ static int mms_CommandSend( input_thread_t *p_input,
...
@@ -940,11 +936,11 @@ static int mms_CommandSend( input_thread_t *p_input,
0
)
==
-
1
)
0
)
==
-
1
)
{
{
msg_Err
(
p_input
,
"failed to send command"
);
msg_Err
(
p_input
,
"failed to send command"
);
return
(
-
1
)
;
return
VLC_EGENERIC
;
}
}
var_buffer_free
(
&
buffer
);
var_buffer_free
(
&
buffer
);
return
(
0
)
;
return
VLC_SUCCESS
;
}
}
static
int
NetFillBuffer
(
input_thread_t
*
p_input
)
static
int
NetFillBuffer
(
input_thread_t
*
p_input
)
...
@@ -1114,7 +1110,7 @@ static int mms_ParseCommand( input_thread_t *p_input,
...
@@ -1114,7 +1110,7 @@ static int mms_ParseCommand( input_thread_t *p_input,
{
{
msg_Warn
(
p_input
,
"truncated command (header incomplete)"
);
msg_Warn
(
p_input
,
"truncated command (header incomplete)"
);
p_sys
->
i_command
=
0
;
p_sys
->
i_command
=
0
;
return
(
-
1
)
;
return
-
1
;
}
}
i_id
=
GetDWLE
(
p_data
+
4
);
i_id
=
GetDWLE
(
p_data
+
4
);
i_length
=
GetDWLE
(
p_data
+
8
)
+
16
;
i_length
=
GetDWLE
(
p_data
+
8
)
+
16
;
...
@@ -1124,7 +1120,7 @@ static int mms_ParseCommand( input_thread_t *p_input,
...
@@ -1124,7 +1120,7 @@ static int mms_ParseCommand( input_thread_t *p_input,
msg_Err
(
p_input
,
msg_Err
(
p_input
,
"incorrect command header (0x%x)"
,
i_id
);
"incorrect command header (0x%x)"
,
i_id
);
p_sys
->
i_command
=
0
;
p_sys
->
i_command
=
0
;
return
(
-
1
)
;
return
-
1
;
}
}
if
(
i_length
>
p_sys
->
i_cmd
)
if
(
i_length
>
p_sys
->
i_cmd
)
...
@@ -1133,7 +1129,7 @@ static int mms_ParseCommand( input_thread_t *p_input,
...
@@ -1133,7 +1129,7 @@ static int mms_ParseCommand( input_thread_t *p_input,
"truncated command (missing %d bytes)"
,
"truncated command (missing %d bytes)"
,
i_length
-
i_data
);
i_length
-
i_data
);
p_sys
->
i_command
=
0
;
p_sys
->
i_command
=
0
;
return
(
-
1
)
;
return
-
1
;
}
}
else
if
(
i_length
<
p_sys
->
i_cmd
)
else
if
(
i_length
<
p_sys
->
i_cmd
)
{
{
...
@@ -1157,8 +1153,9 @@ static int mms_ParseCommand( input_thread_t *p_input,
...
@@ -1157,8 +1153,9 @@ static int mms_ParseCommand( input_thread_t *p_input,
/* 44: extra */
);
/* 44: extra */
);
p_sys
->
i_command
=
GET32
(
36
)
&
0xffff
;
p_sys
->
i_command
=
GET32
(
36
)
&
0xffff
;
#undef GET32
return
(
MMS_PACKET_CMD
)
;
return
MMS_PACKET_CMD
;
}
}
static
int
mms_ParsePacket
(
input_thread_t
*
p_input
,
static
int
mms_ParsePacket
(
input_thread_t
*
p_input
,
...
@@ -1177,7 +1174,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
...
@@ -1177,7 +1174,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
if
(
i_data
<=
8
)
if
(
i_data
<=
8
)
{
{
msg_Warn
(
p_input
,
"truncated packet (header incomplete)"
);
msg_Warn
(
p_input
,
"truncated packet (header incomplete)"
);
return
(
-
1
)
;
return
-
1
;
}
}
i_packet_id
=
p_data
[
4
];
i_packet_id
=
p_data
[
4
];
...
@@ -1192,7 +1189,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
...
@@ -1192,7 +1189,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
"truncated packet (missing %d bytes)"
,
"truncated packet (missing %d bytes)"
,
i_packet_length
-
i_data
);
i_packet_length
-
i_data
);
*
pi_used
=
0
;
*
pi_used
=
0
;
return
(
-
1
)
;
return
-
1
;
}
}
else
if
(
i_packet_length
<
i_data
)
else
if
(
i_packet_length
<
i_data
)
{
{
...
@@ -1210,7 +1207,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
...
@@ -1210,7 +1207,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
i_packet_id
!=
p_sys
->
i_media_packet_id_type
)
i_packet_id
!=
p_sys
->
i_media_packet_id_type
)
{
{
msg_Warn
(
p_input
,
"incorrect Packet Id Type (0x%x)"
,
i_packet_id
);
msg_Warn
(
p_input
,
"incorrect Packet Id Type (0x%x)"
,
i_packet_id
);
return
(
-
1
)
;
return
-
1
;
}
}
/* we now have a media or a header packet */
/* we now have a media or a header packet */
...
@@ -1250,7 +1247,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
...
@@ -1250,7 +1247,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
"receive header packet (%d bytes)",
"receive header packet (%d bytes)",
i_packet_length - 8 ); */
i_packet_length - 8 ); */
return
(
MMS_PACKET_HEADER
)
;
return
MMS_PACKET_HEADER
;
}
}
else
else
{
{
...
@@ -1262,7 +1259,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
...
@@ -1262,7 +1259,7 @@ static int mms_ParsePacket( input_thread_t *p_input,
"receive media packet (%d bytes)",
"receive media packet (%d bytes)",
i_packet_length - 8 ); */
i_packet_length - 8 ); */
return
(
MMS_PACKET_MEDIA
)
;
return
MMS_PACKET_MEDIA
;
}
}
}
}
...
@@ -1274,7 +1271,30 @@ static int mms_ReceivePacket( input_thread_t *p_input )
...
@@ -1274,7 +1271,30 @@ static int mms_ReceivePacket( input_thread_t *p_input )
for
(
;;
)
for
(
;;
)
{
{
if
(
NetFillBuffer
(
p_input
)
<
0
)
vlc_bool_t
b_refill
=
VLC_TRUE
;
/* first if we need to refill buffer */
if
(
p_sys
->
i_buffer_tcp
>=
MMS_CMD_HEADERSIZE
)
{
if
(
GetDWLE
(
p_sys
->
buffer_tcp
+
4
)
==
0xb00bface
)
{
if
(
GetDWLE
(
p_sys
->
buffer_tcp
+
8
)
+
16
<=
p_sys
->
i_buffer_tcp
)
{
b_refill
=
VLC_FALSE
;
}
}
else
if
(
GetWLE
(
p_sys
->
buffer_tcp
+
6
)
<=
p_sys
->
i_buffer_tcp
)
{
b_refill
=
VLC_FALSE
;
}
}
if
(
p_sys
->
i_proto
==
MMS_PROTO_UDP
&&
p_sys
->
i_buffer_udp
>=
8
&&
GetWLE
(
p_sys
->
buffer_udp
+
6
)
<=
p_sys
->
i_buffer_udp
)
{
b_refill
=
VLC_FALSE
;
}
if
(
b_refill
&&
NetFillBuffer
(
p_input
)
<
0
)
{
{
msg_Warn
(
p_input
,
"cannot fill buffer"
);
msg_Warn
(
p_input
,
"cannot fill buffer"
);
continue
;
continue
;
...
@@ -1346,7 +1366,6 @@ static int mms_ReceivePacket( input_thread_t *p_input )
...
@@ -1346,7 +1366,6 @@ static int mms_ReceivePacket( input_thread_t *p_input )
{
{
return
(
i_packet_udp_type
);
return
(
i_packet_udp_type
);
}
}
}
}
}
}
...
@@ -1380,7 +1399,7 @@ static int mms_ReceiveCommand( input_thread_t *p_input )
...
@@ -1380,7 +1399,7 @@ static int mms_ReceiveCommand( input_thread_t *p_input )
if
(
i_status
<
0
)
if
(
i_status
<
0
)
{
{
return
(
-
1
)
;
return
VLC_EGENERIC
;
}
}
if
(
p_sys
->
i_command
==
0x1b
)
if
(
p_sys
->
i_command
==
0x1b
)
...
@@ -1394,11 +1413,11 @@ static int mms_ReceiveCommand( input_thread_t *p_input )
...
@@ -1394,11 +1413,11 @@ static int mms_ReceiveCommand( input_thread_t *p_input )
}
}
else
else
{
{
return
(
-
1
)
;
return
VLC_EGENERIC
;
}
}
}
}
return
(
0
)
;
return
VLC_SUCCESS
;
}
}
#define MMS_RETRY_MAX 10
#define MMS_RETRY_MAX 10
...
@@ -1412,7 +1431,6 @@ static int mms_CommandRead( input_thread_t *p_input, int i_command1, int i_comma
...
@@ -1412,7 +1431,6 @@ static int mms_CommandRead( input_thread_t *p_input, int i_command1, int i_comma
for
(
i_count
=
0
;
i_count
<
MMS_RETRY_MAX
;
)
for
(
i_count
=
0
;
i_count
<
MMS_RETRY_MAX
;
)
{
{
i_status
=
mms_ReceiveCommand
(
p_input
);
i_status
=
mms_ReceiveCommand
(
p_input
);
if
(
i_status
<
0
||
p_sys
->
i_command
==
0
)
if
(
i_status
<
0
||
p_sys
->
i_command
==
0
)
{
{
...
@@ -1421,11 +1439,11 @@ static int mms_CommandRead( input_thread_t *p_input, int i_command1, int i_comma
...
@@ -1421,11 +1439,11 @@ static int mms_CommandRead( input_thread_t *p_input, int i_command1, int i_comma
}
}
else
if
(
i_command1
==
0
&&
i_command2
==
0
)
else
if
(
i_command1
==
0
&&
i_command2
==
0
)
{
{
return
(
0
)
;
return
VLC_SUCCESS
;
}
}
else
if
(
p_sys
->
i_command
==
i_command1
||
p_sys
->
i_command
==
i_command2
)
else
if
(
p_sys
->
i_command
==
i_command1
||
p_sys
->
i_command
==
i_command2
)
{
{
return
(
0
)
;
return
VLC_SUCCESS
;
}
}
else
else
{
{
...
@@ -1434,11 +1452,11 @@ static int mms_CommandRead( input_thread_t *p_input, int i_command1, int i_comma
...
@@ -1434,11 +1452,11 @@ static int mms_CommandRead( input_thread_t *p_input, int i_command1, int i_comma
case
0x03
:
case
0x03
:
msg_Warn
(
p_input
,
"socket closed by server"
);
msg_Warn
(
p_input
,
"socket closed by server"
);
p_sys
->
i_eos
=
1
;
p_sys
->
i_eos
=
1
;
return
(
-
1
)
;
return
VLC_EGENERIC
;
case
0x1e
:
case
0x1e
:
msg_Warn
(
p_input
,
"end of media stream"
);
msg_Warn
(
p_input
,
"end of media stream"
);
p_sys
->
i_eos
=
1
;
p_sys
->
i_eos
=
1
;
return
(
-
1
)
;
return
VLC_EGENERIC
;
default:
default:
break
;
break
;
}
}
...
@@ -1446,7 +1464,7 @@ static int mms_CommandRead( input_thread_t *p_input, int i_command1, int i_comma
...
@@ -1446,7 +1464,7 @@ static int mms_CommandRead( input_thread_t *p_input, int i_command1, int i_comma
}
}
msg_Warn
(
p_input
,
"failed to receive command (abording)"
);
msg_Warn
(
p_input
,
"failed to receive command (abording)"
);
return
(
-
1
)
;
return
VLC_EGENERIC
;
}
}
...
@@ -1469,7 +1487,7 @@ static int mms_HeaderMediaRead( input_thread_t *p_input, int i_type )
...
@@ -1469,7 +1487,7 @@ static int mms_HeaderMediaRead( input_thread_t *p_input, int i_type )
}
}
else
if
(
i_status
==
i_type
||
i_type
==
MMS_PACKET_ANY
)
else
if
(
i_status
==
i_type
||
i_type
==
MMS_PACKET_ANY
)
{
{
return
(
i_type
)
;
return
i_type
;
}
}
else
if
(
i_status
==
MMS_PACKET_CMD
)
else
if
(
i_status
==
MMS_PACKET_CMD
)
{
{
...
@@ -1478,11 +1496,11 @@ static int mms_HeaderMediaRead( input_thread_t *p_input, int i_type )
...
@@ -1478,11 +1496,11 @@ static int mms_HeaderMediaRead( input_thread_t *p_input, int i_type )
case
0x03
:
case
0x03
:
msg_Warn
(
p_input
,
"socket closed by server"
);
msg_Warn
(
p_input
,
"socket closed by server"
);
p_sys
->
i_eos
=
1
;
p_sys
->
i_eos
=
1
;
return
(
-
1
)
;
return
-
1
;
case
0x1e
:
case
0x1e
:
msg_Warn
(
p_input
,
"end of media stream"
);
msg_Warn
(
p_input
,
"end of media stream"
);
p_sys
->
i_eos
=
1
;
p_sys
->
i_eos
=
1
;
return
(
-
1
)
;
return
-
1
;
case
0x20
:
case
0x20
:
/* XXX not too dificult to be done EXCEPT that we
/* XXX not too dificult to be done EXCEPT that we
* need to restart demuxer... and I don't see how we
* need to restart demuxer... and I don't see how we
...
@@ -1490,7 +1508,7 @@ static int mms_HeaderMediaRead( input_thread_t *p_input, int i_type )
...
@@ -1490,7 +1508,7 @@ static int mms_HeaderMediaRead( input_thread_t *p_input, int i_type )
msg_Err
(
p_input
,
msg_Err
(
p_input
,
"reinitialization needed --> unsupported"
);
"reinitialization needed --> unsupported"
);
p_sys
->
i_eos
=
1
;
p_sys
->
i_eos
=
1
;
return
(
-
1
)
;
return
-
1
;
default:
default:
break
;
break
;
}
}
...
@@ -1499,6 +1517,6 @@ static int mms_HeaderMediaRead( input_thread_t *p_input, int i_type )
...
@@ -1499,6 +1517,6 @@ static int mms_HeaderMediaRead( input_thread_t *p_input, int i_type )
msg_Err
(
p_input
,
msg_Err
(
p_input
,
"cannot receive %s (abording)"
,
"cannot receive %s (abording)"
,
(
i_type
==
MMS_PACKET_HEADER
)
?
"header"
:
"media data"
);
(
i_type
==
MMS_PACKET_HEADER
)
?
"header"
:
"media data"
);
return
(
-
1
)
;
return
-
1
;
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment