Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
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-2-2
Commits
bd056290
Commit
bd056290
authored
Feb 27, 2007
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
- Support for customizing the checksum coverage
- Make UDP-Lite an option rather than a distinct shortcut
parent
c2862474
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
48 additions
and
26 deletions
+48
-26
modules/access_output/udp.c
modules/access_output/udp.c
+48
-26
No files found.
modules/access_output/udp.c
View file @
bd056290
...
@@ -105,6 +105,10 @@ static void Close( vlc_object_t * );
...
@@ -105,6 +105,10 @@ static void Close( vlc_object_t * );
#define AUTO_MCAST_TEXT N_("Automatic multicast streaming")
#define AUTO_MCAST_TEXT N_("Automatic multicast streaming")
#define AUTO_MCAST_LONGTEXT N_("Allocates an outbound multicast address " \
#define AUTO_MCAST_LONGTEXT N_("Allocates an outbound multicast address " \
"automatically.")
"automatically.")
#define UDPLITE_TEXT N_("UDP-Lite")
#define UDPLITE_LONGTEXT N_("Use UDP-Lite/IP instead of normal UDP/IP")
#define CSCOV_TEXT N_("Checksum coverage")
#define CSCOV_LONGTEXT N_("Payload bytes covered by layer-4 checksum")
vlc_module_begin
();
vlc_module_begin
();
set_description
(
_
(
"UDP stream output"
)
);
set_description
(
_
(
"UDP stream output"
)
);
...
@@ -119,11 +123,12 @@ vlc_module_begin();
...
@@ -119,11 +123,12 @@ vlc_module_begin();
VLC_TRUE
);
VLC_TRUE
);
add_bool
(
SOUT_CFG_PREFIX
"auto-mcast"
,
0
,
NULL
,
AUTO_MCAST_TEXT
,
add_bool
(
SOUT_CFG_PREFIX
"auto-mcast"
,
0
,
NULL
,
AUTO_MCAST_TEXT
,
AUTO_MCAST_LONGTEXT
,
VLC_TRUE
);
AUTO_MCAST_LONGTEXT
,
VLC_TRUE
);
add_bool
(
SOUT_CFG_PREFIX
"udplite"
,
0
,
NULL
,
UDPLITE_TEXT
,
UDPLITE_LONGTEXT
,
VLC_TRUE
);
add_integer
(
SOUT_CFG_PREFIX
"cscov"
,
12
,
NULL
,
CSCOV_TEXT
,
CSCOV_LONGTEXT
,
VLC_TRUE
);
set_capability
(
"sout access"
,
100
);
set_capability
(
"sout access"
,
100
);
add_shortcut
(
"udp"
);
add_shortcut
(
"udp"
);
add_shortcut
(
"rtp"
);
// Will work only with ts muxer
add_shortcut
(
"rtp"
);
// Will work only with ts muxer
add_shortcut
(
"udplite"
);
set_callbacks
(
Open
,
Close
);
set_callbacks
(
Open
,
Close
);
vlc_module_end
();
vlc_module_end
();
...
@@ -136,6 +141,8 @@ static const char *ppsz_sout_options[] = {
...
@@ -136,6 +141,8 @@ static const char *ppsz_sout_options[] = {
"caching"
,
"caching"
,
"group"
,
"group"
,
"raw"
,
"raw"
,
"lite"
,
"cscov"
,
NULL
NULL
};
};
...
@@ -204,14 +211,13 @@ static void CloseRTCP (sout_access_thread_t *obj);
...
@@ -204,14 +211,13 @@ static void CloseRTCP (sout_access_thread_t *obj);
/*****************************************************************************
/*****************************************************************************
* Open: open the file
* Open: open the file
*****************************************************************************/
*****************************************************************************/
/* FIXME: lots of leaks in error handling here! */
static
int
Open
(
vlc_object_t
*
p_this
)
static
int
Open
(
vlc_object_t
*
p_this
)
{
{
sout_access_out_t
*
p_access
=
(
sout_access_out_t
*
)
p_this
;
sout_access_out_t
*
p_access
=
(
sout_access_out_t
*
)
p_this
;
sout_access_out_sys_t
*
p_sys
;
sout_access_out_sys_t
*
p_sys
;
char
*
psz_dst_addr
=
NULL
;
char
*
psz_dst_addr
=
NULL
;
int
i_dst_port
,
proto
=
IPPROTO_UDP
,
cscov
=
8
;
int
i_dst_port
,
proto
=
IPPROTO_UDP
;
const
char
*
protoname
=
"UDP"
;
const
char
*
protoname
=
"UDP"
;
int
i_handle
;
int
i_handle
;
...
@@ -223,10 +229,18 @@ static int Open( vlc_object_t *p_this )
...
@@ -223,10 +229,18 @@ static int Open( vlc_object_t *p_this )
config_ChainParse
(
p_access
,
""
,
config_ChainParse
(
p_access
,
""
,
ppsz_core_options
,
p_access
->
p_cfg
);
ppsz_core_options
,
p_access
->
p_cfg
);
if
(
var_Create
(
p_access
,
"dst-port"
,
VLC_VAR_INTEGER
)
||
var_Create
(
p_access
,
"src-port"
,
VLC_VAR_INTEGER
)
||
var_Create
(
p_access
,
"dst-addr"
,
VLC_VAR_STRING
)
||
var_Create
(
p_access
,
"src-addr"
,
VLC_VAR_STRING
))
{
return
VLC_ENOMEM
;
}
if
(
!
(
p_sys
=
calloc
(
1
,
sizeof
(
sout_access_out_sys_t
)
)
)
)
if
(
!
(
p_sys
=
calloc
(
1
,
sizeof
(
sout_access_out_sys_t
)
)
)
)
{
{
msg_Err
(
p_access
,
"not enough memory"
);
msg_Err
(
p_access
,
"not enough memory"
);
return
VLC_E
GENERIC
;
return
VLC_E
NOMEM
;
}
}
p_access
->
p_sys
=
p_sys
;
p_access
->
p_sys
=
p_sys
;
...
@@ -234,18 +248,16 @@ static int Open( vlc_object_t *p_this )
...
@@ -234,18 +248,16 @@ static int Open( vlc_object_t *p_this )
{
{
if
(
strcmp
(
p_access
->
psz_access
,
"rtp"
)
==
0
)
if
(
strcmp
(
p_access
->
psz_access
,
"rtp"
)
==
0
)
p_sys
->
b_rtpts
=
VLC_TRUE
;
p_sys
->
b_rtpts
=
VLC_TRUE
;
if
(
strcmp
(
p_access
->
psz_access
,
"udplite"
)
==
0
)
}
if
(
var_GetBool
(
p_access
,
SOUT_CFG_PREFIX
"lite"
))
{
{
protoname
=
"UDP-Lite"
;
protoname
=
"UDP-Lite"
;
proto
=
IPPROTO_UDPLITE
;
proto
=
IPPROTO_UDPLITE
;
p_sys
->
b_rtpts
=
VLC_TRUE
;
}
}
}
if
(
p_sys
->
b_rtpts
)
cscov
+=
RTP_HEADER_LENGTH
;
i_dst_port
=
DEFAULT_PORT
;
i_dst_port
=
DEFAULT_PORT
;
if
(
var_
Create
GetBool
(
p_access
,
SOUT_CFG_PREFIX
"auto-mcast"
))
if
(
var_GetBool
(
p_access
,
SOUT_CFG_PREFIX
"auto-mcast"
))
{
{
char
buf
[
INET6_ADDRSTRLEN
];
char
buf
[
INET6_ADDRSTRLEN
];
if
(
MakeRandMulticast
(
AF_INET
,
buf
,
sizeof
(
buf
))
!=
NULL
)
if
(
MakeRandMulticast
(
AF_INET
,
buf
,
sizeof
(
buf
))
!=
NULL
)
...
@@ -266,16 +278,6 @@ static int Open( vlc_object_t *p_this )
...
@@ -266,16 +278,6 @@ static int Open( vlc_object_t *p_this )
}
}
}
}
if
(
var_Create
(
p_access
,
"dst-port"
,
VLC_VAR_INTEGER
)
||
var_Create
(
p_access
,
"src-port"
,
VLC_VAR_INTEGER
)
||
var_Create
(
p_access
,
"dst-addr"
,
VLC_VAR_STRING
)
||
var_Create
(
p_access
,
"src-addr"
,
VLC_VAR_STRING
))
{
free
(
p_sys
);
free
(
psz_dst_addr
);
return
VLC_ENOMEM
;
}
p_sys
->
p_thread
=
p_sys
->
p_thread
=
vlc_object_create
(
p_access
,
sizeof
(
sout_access_thread_t
)
);
vlc_object_create
(
p_access
,
sizeof
(
sout_access_thread_t
)
);
if
(
!
p_sys
->
p_thread
)
if
(
!
p_sys
->
p_thread
)
...
@@ -325,11 +327,31 @@ static int Open( vlc_object_t *p_this )
...
@@ -325,11 +327,31 @@ static int Open( vlc_object_t *p_this )
p_sys
->
p_thread
->
i_handle
=
i_handle
;
p_sys
->
p_thread
->
i_handle
=
i_handle
;
shutdown
(
i_handle
,
SHUT_RD
);
shutdown
(
i_handle
,
SHUT_RD
);
int
cscov
=
var_GetInteger
(
p_access
,
SOUT_CFG_PREFIX
"cscov"
);
if
(
cscov
)
{
switch
(
proto
)
{
#ifdef UDPLITE_SEND_CSCOV
#ifdef UDPLITE_SEND_CSCOV
if
(
proto
==
IPPROTO_UDPLITE
)
case
IPPROTO_UDPLITE
:
cscov
+=
8
;
setsockopt
(
i_handle
,
SOL_UDPLITE
,
UDPLITE_SEND_CSCOV
,
setsockopt
(
i_handle
,
SOL_UDPLITE
,
UDPLITE_SEND_CSCOV
,
&
cscov
,
sizeof
(
cscov
));
&
(
int
){
cscov
},
sizeof
(
cscov
));
break
;
#endif
#endif
#ifdef DCCP_SOCKOPT_RECV_CSCOV
/* FIXME: ^^is this the right name ? */
/* FIXME: is this inherited by accept() ? */
case
IPPROTO_DCCP
:
cscov
=
((
cscov
+
3
)
>>
2
)
+
1
;
if
(
cscov
>
15
)
break
;
/* out of DCCP cscov range */
setsockopt
(
i_handle
,
SOL_DCCP
,
DCCP_SOCKOPT_RECV_CSCOV
,
&
(
int
){
cscov
},
sizeof
(
cscov
));
break
;
#endif
}
}
var_Get
(
p_access
,
SOUT_CFG_PREFIX
"caching"
,
&
val
);
var_Get
(
p_access
,
SOUT_CFG_PREFIX
"caching"
,
&
val
);
p_sys
->
p_thread
->
i_caching
=
(
int64_t
)
val
.
i_int
*
1000
;
p_sys
->
p_thread
->
i_caching
=
(
int64_t
)
val
.
i_int
*
1000
;
...
...
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