Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
5c8acc49
Commit
5c8acc49
authored
Jul 27, 2005
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Put correct owner address in SAP-generated SDP
parent
0f55beac
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
133 additions
and
151 deletions
+133
-151
include/stream_output.h
include/stream_output.h
+1
-4
include/vlc_symbols.h
include/vlc_symbols.h
+1
-1
modules/stream_out/standard.c
modules/stream_out/standard.c
+0
-2
src/stream_output/announce.c
src/stream_output/announce.c
+4
-8
src/stream_output/sap.c
src/stream_output/sap.c
+127
-136
No files found.
include/stream_output.h
View file @
5c8acc49
...
...
@@ -257,9 +257,6 @@ struct session_descriptor_t
struct
announce_method_t
{
int
i_type
;
/* For SAP */
char
*
psz_address
;
/* If we use a custom address */
};
...
...
@@ -291,7 +288,7 @@ struct sap_handler_t
int
i_current_session
;
int
(
*
pf_add
)
(
sap_handler_t
*
,
session_descriptor_t
*
,
announce_method_t
*
);
int
(
*
pf_add
)
(
sap_handler_t
*
,
session_descriptor_t
*
);
int
(
*
pf_del
)
(
sap_handler_t
*
,
session_descriptor_t
*
);
/* private data, not in p_sys as there is one kind of sap_handler_t */
...
...
include/vlc_symbols.h
View file @
5c8acc49
...
...
@@ -92,7 +92,7 @@ struct module_symbols_t
int
(
*
__net_OpenTCP_inner
)
(
vlc_object_t
*
p_this
,
const
char
*
psz_host
,
int
i_port
);
int
*
(
*
__net_ListenTCP_inner
)
(
vlc_object_t
*
,
const
char
*
,
int
);
int
(
*
__net_Accept_inner
)
(
vlc_object_t
*
,
int
*
,
mtime_t
);
int
(
*
__net_OpenUDP_inner
)
(
vlc_object_t
*
p_this
,
c
har
*
psz_bind
,
int
i_bind
,
char
*
psz_server
,
int
i_server
);
int
(
*
__net_OpenUDP_inner
)
(
vlc_object_t
*
p_this
,
c
onst
char
*
psz_bind
,
int
i_bind
,
const
char
*
psz_server
,
int
i_server
);
void
(
*
net_Close_inner
)
(
int
fd
);
int
(
*
__net_Read_inner
)
(
vlc_object_t
*
p_this
,
int
fd
,
v_socket_t
*
,
uint8_t
*
p_data
,
int
i_data
,
vlc_bool_t
b_retry
);
int
(
*
__net_ReadNonBlock_inner
)
(
vlc_object_t
*
p_this
,
int
fd
,
v_socket_t
*
,
uint8_t
*
p_data
,
int
i_data
,
mtime_t
i_wait
);
...
...
modules/stream_out/standard.c
View file @
5c8acc49
...
...
@@ -361,8 +361,6 @@ static int Open( vlc_object_t *p_this )
}
vlc_UrlClean
(
&
url
);
/* FIXME: Free p_method */
if
(
p_method
->
psz_address
)
free
(
p_method
->
psz_address
);
free
(
p_method
);
}
...
...
src/stream_output/announce.c
View file @
5c8acc49
...
...
@@ -199,14 +199,10 @@ announce_method_t * sout_AnnounceMethodCreate( int i_type )
announce_method_t
*
p_method
;
p_method
=
(
announce_method_t
*
)
malloc
(
sizeof
(
announce_method_t
)
);
if
(
p_method
==
NULL
)
return
NULL
;
if
(
p_method
)
{
p_method
->
i_type
=
i_type
;
if
(
i_type
==
METHOD_TYPE_SAP
)
/* Default value */
p_method
->
psz_address
=
NULL
;
}
return
p_method
;
}
...
...
@@ -286,7 +282,7 @@ int announce_Register( announce_handler_t *p_announce,
}
/* this will set p_session->p_sap for later deletion */
msg_Dbg
(
p_announce
,
"adding SAP session"
);
p_announce
->
p_sap
->
pf_add
(
p_announce
->
p_sap
,
p_session
,
p_method
);
p_announce
->
p_sap
->
pf_add
(
p_announce
->
p_sap
,
p_session
);
}
else
if
(
p_method
->
i_type
==
METHOD_TYPE_SLP
)
{
...
...
src/stream_output/sap.c
View file @
5c8acc49
...
...
@@ -65,6 +65,7 @@
struct
sap_address_t
{
char
*
psz_address
;
char
psz_machine
[
NI_MAXNUMERICHOST
];
int
i_port
;
int
i_rfd
;
/* Read socket */
int
i_wfd
;
/* Write socket */
...
...
@@ -83,15 +84,16 @@ struct sap_address_t
*****************************************************************************/
static
void
RunThread
(
vlc_object_t
*
p_this
);
static
int
CalculateRate
(
sap_handler_t
*
p_sap
,
sap_address_t
*
p_address
);
static
int
SDPGenerate
(
sap_handler_t
*
p_sap
,
session_descriptor_t
*
p_session
);
static
char
*
SDPGenerate
(
sap_handler_t
*
p_sap
,
const
session_descriptor_t
*
p_session
,
const
sap_address_t
*
p_addr
);
static
int
announce_SendSAPAnnounce
(
sap_handler_t
*
p_sap
,
sap_session_t
*
p_session
);
static
int
announce_SAPAnnounceAdd
(
sap_handler_t
*
p_sap
,
session_descriptor_t
*
p_session
,
announce_method_t
*
p_method
);
session_descriptor_t
*
p_session
);
static
int
announce_SAPAnnounceDel
(
sap_handler_t
*
p_sap
,
session_descriptor_t
*
p_session
);
...
...
@@ -125,9 +127,7 @@ sap_handler_t *announce_SAPHandlerCreate( announce_handler_t *p_announce )
p_sap
->
iconvHandle
=
vlc_iconv_open
(
"UTF-8"
,
psz_charset
);
free
(
psz_charset
);
if
(
p_sap
->
iconvHandle
==
(
vlc_iconv_t
)(
-
1
)
)
{
msg_Warn
(
p_sap
,
"Unable to do requested conversion"
);
}
p_sap
->
pf_add
=
announce_SAPAnnounceAdd
;
p_sap
->
pf_del
=
announce_SAPAnnounceDel
;
...
...
@@ -252,36 +252,22 @@ static void RunThread( vlc_object_t *p_this)
/* Add a SAP announce */
static
int
announce_SAPAnnounceAdd
(
sap_handler_t
*
p_sap
,
session_descriptor_t
*
p_session
,
announce_method_t
*
p_method
)
session_descriptor_t
*
p_session
)
{
int
i
;
char
*
psz_type
=
"application/sdp"
;
c
onst
c
har
*
psz_type
=
"application/sdp"
;
int
i_header_size
;
char
*
psz_head
;
vlc_bool_t
b_
found
=
VLC_FALSE
,
b_
ipv6
=
VLC_FALSE
;
vlc_bool_t
b_ipv6
=
VLC_FALSE
;
sap_session_t
*
p_sap_session
;
mtime_t
i_hash
;
vlc_mutex_lock
(
&
p_sap
->
object_lock
);
/* If needed, build the SDP */
if
(
!
p_session
->
psz_sdp
)
{
if
(
SDPGenerate
(
p_sap
,
p_session
)
!=
VLC_SUCCESS
)
{
vlc_mutex_unlock
(
&
p_sap
->
object_lock
);
return
VLC_EGENERIC
;
}
}
if
(
p_method
->
psz_address
==
NULL
)
{
/* Determine SAP multicast address automatically */
char
psz_buf
[
NI_MAXNUMERICHOST
],
*
ptr
;
const
char
*
psz_addr
;
struct
addrinfo
hints
,
*
res
;
vlc_mutex_lock
(
&
p_sap
->
object_lock
);
if
(
p_session
->
psz_uri
==
NULL
)
{
msg_Err
(
p_sap
,
"*FIXME* Unexpected NULL URI for SAP announce"
);
...
...
@@ -290,6 +276,7 @@ static int announce_SAPAnnounceAdd( sap_handler_t *p_sap,
return
VLC_EGENERIC
;
}
/* Determine SAP multicast address automatically (FIXME: gruik) */
/* Canonicalize IP address (e.g. 224.00.010.1 => 224.0.10.1) */
memset
(
&
hints
,
0
,
sizeof
(
hints
)
);
hints
.
ai_socktype
=
SOCK_DGRAM
;
...
...
@@ -353,31 +340,23 @@ static int announce_SAPAnnounceAdd( sap_handler_t *p_sap,
psz_addr
=
"224.2.127.254"
;
}
p_method
->
psz_address
=
strdup
(
psz_addr
);
}
else
b_ipv6
=
(
strchr
(
p_method
->
psz_address
,
':'
)
!=
NULL
);
msg_Dbg
(
p_sap
,
"using SAP address: %s"
,
p_method
->
psz_address
);
msg_Dbg
(
p_sap
,
"using SAP address: %s"
,
psz_addr
);
/* XXX: Check for dupes */
p_sap_session
=
(
sap_session_t
*
)
malloc
(
sizeof
(
sap_session_t
));
p_sap_session
->
psz_sdp
=
strdup
(
p_session
->
psz_sdp
);
p_sap_session
->
i_last
=
0
;
p_sap_session
->
p_address
=
NULL
;
/* Add the address to the buffer */
for
(
i
=
0
;
i
<
p_sap
->
i_addresses
;
i
++
)
for
(
i
=
0
;
i
<
p_sap
->
i_addresses
;
i
++
)
{
if
(
!
strcmp
(
p_method
->
psz_address
,
p_sap
->
pp_addresses
[
i
]
->
psz_address
)
)
if
(
!
strcmp
(
psz_addr
,
p_sap
->
pp_addresses
[
i
]
->
psz_address
)
)
{
p_sap_session
->
p_address
=
p_sap
->
pp_addresses
[
i
];
b_found
=
VLC_TRUE
;
break
;
}
}
if
(
b_found
==
VLC_FALSE
)
if
(
p_sap_session
->
p_address
==
NULL
)
{
sap_address_t
*
p_address
=
(
sap_address_t
*
)
malloc
(
sizeof
(
sap_address_t
)
);
...
...
@@ -386,19 +365,21 @@ static int announce_SAPAnnounceAdd( sap_handler_t *p_sap,
msg_Err
(
p_sap
,
"out of memory"
);
return
VLC_ENOMEM
;
}
p_address
->
psz_address
=
strdup
(
p
_method
->
psz_address
);
p_address
->
psz_address
=
strdup
(
p
sz_addr
);
p_address
->
i_port
=
9875
;
p_address
->
i_wfd
=
net_OpenUDP
(
p_sap
,
""
,
0
,
p_address
->
psz_address
,
p_address
->
i_wfd
=
net_OpenUDP
(
p_sap
,
""
,
0
,
psz_addr
,
p_address
->
i_port
);
if
(
p_address
->
i_wfd
!=
-
1
)
{
net_StopRecv
(
p_address
->
i_wfd
);
net_GetSockAddress
(
p_sap
,
p_address
->
i_wfd
,
p_address
->
psz_machine
,
NULL
);
}
if
(
p_sap
->
b_control
==
VLC_TRUE
)
{
p_address
->
i_rfd
=
net_OpenUDP
(
p_sap
,
p_method
->
psz_address
,
p_address
->
i_port
,
""
,
0
);
p_address
->
i_rfd
=
net_OpenUDP
(
p_sap
,
psz_addr
,
p_address
->
i_port
,
""
,
0
);
if
(
p_address
->
i_rfd
!=
-
1
)
net_StopSend
(
p_address
->
i_rfd
);
p_address
->
i_buff
=
0
;
...
...
@@ -429,10 +410,11 @@ static int announce_SAPAnnounceAdd( sap_handler_t *p_sap,
p_sap_session
->
p_address
=
p_address
;
}
/* Build the SAP Headers */
i_header_size
=
(
b_ipv6
?
20
:
8
)
+
strlen
(
psz_type
)
+
1
;
psz_head
=
(
char
*
)
malloc
(
i_header_size
*
sizeof
(
char
)
);
if
(
!
psz_head
)
if
(
psz_head
==
NULL
)
{
msg_Err
(
p_sap
,
"out of memory"
);
return
VLC_ENOMEM
;
...
...
@@ -484,6 +466,21 @@ static int announce_SAPAnnounceAdd( sap_handler_t *p_sap,
strncpy
(
psz_head
+
8
,
psz_type
,
15
);
}
/* If needed, build the SDP */
if
(
p_session
->
psz_sdp
==
NULL
)
{
p_session
->
psz_sdp
=
SDPGenerate
(
p_sap
,
p_session
,
p_sap_session
->
p_address
);
if
(
p_session
->
psz_sdp
==
NULL
)
{
vlc_mutex_unlock
(
&
p_sap
->
object_lock
);
return
VLC_ENOMEM
;
}
}
p_sap_session
->
psz_sdp
=
strdup
(
p_session
->
psz_sdp
);
p_sap_session
->
i_last
=
0
;
psz_head
[
i_header_size
-
1
]
=
'\0'
;
p_sap_session
->
i_length
=
i_header_size
+
strlen
(
p_sap_session
->
psz_sdp
);
...
...
@@ -570,7 +567,7 @@ static int announce_SendSAPAnnounce( sap_handler_t *p_sap,
i_ret
=
net_Write
(
p_sap
,
p_session
->
p_address
->
i_wfd
,
NULL
,
p_session
->
psz_data
,
p_session
->
i_length
);
if
(
i_ret
!=
p_session
->
i_length
)
if
(
i_ret
!=
(
int
)
p_session
->
i_length
)
{
msg_Warn
(
p_sap
,
"SAP send failed on address %s (%i %i)"
,
p_session
->
p_address
->
psz_address
,
...
...
@@ -587,15 +584,23 @@ static int announce_SendSAPAnnounce( sap_handler_t *p_sap,
return
VLC_SUCCESS
;
}
static
int
SDPGenerate
(
sap_handler_t
*
p_sap
,
session_descriptor_t
*
p_session
)
static
char
*
SDPGenerate
(
sap_handler_t
*
p_sap
,
const
session_descriptor_t
*
p_session
,
const
sap_address_t
*
p_addr
)
{
int64_t
i_sdp_id
=
mdate
();
int
i_sdp_version
=
1
+
p_sap
->
i_sessions
+
(
rand
()
&
0xfff
);
char
*
psz_group
,
*
psz_name
,
psz_uribuf
[
NI_MAXNUMERICHOST
],
*
psz_uri
;
char
*
psz_group
,
*
psz_name
,
psz_uribuf
[
NI_MAXNUMERICHOST
],
*
psz_uri
,
*
psz_sdp
;
char
ipv
;
psz_group
=
convert_to_utf8
(
p_sap
,
p_session
->
psz_group
);
psz_name
=
convert_to_utf8
(
p_sap
,
p_session
->
psz_name
);
if
(
psz_name
==
NULL
)
{
FREE
(
psz_group
);
return
NULL
;
}
/* FIXME: really check that psz_uri is a real IP address
* FIXME: make a common function to obtain a canonical IP address */
...
...
@@ -618,30 +623,9 @@ static int SDPGenerate( sap_handler_t *p_sap, session_descriptor_t *p_session )
psz_uri
=
p_session
->
psz_uri
;
/* see the lists in modules/stream_out/rtp.c for compliance stuff */
p_session
->
psz_sdp
=
(
char
*
)
malloc
(
sizeof
(
"v=0
\r\n
"
"o=- 45383436098 45398 IN IP4 127.0.0.1
\r\n
"
/* FIXME */
"s=
\r\n
"
"t=0 0
\r\n
"
"c=IN IP4 /
\r\n
"
"m=video udp
\r\n
"
"a=tool:"
PACKAGE_STRING
"
\r\n
"
"a=type:broadcast
\r\n
"
)
+
strlen
(
psz_name
)
+
strlen
(
psz_uri
)
+
300
+
(
psz_group
?
strlen
(
psz_group
)
:
0
)
);
if
(
p_session
->
psz_sdp
==
NULL
||
psz_name
==
NULL
)
{
msg_Err
(
p_sap
,
"out of memory"
);
FREE
(
psz_name
);
FREE
(
psz_group
);
return
VLC_ENOMEM
;
}
sprintf
(
p_session
->
psz_sdp
,
if
(
asprintf
(
&
psz_sdp
,
"v=0
\r\n
"
"o=- "
I64Fd
" %d IN IP
4 127.0.0.1
\r\n
"
"o=- "
I64Fd
" %d IN IP
%c %s
\r\n
"
"s=%s
\r\n
"
"t=0 0
\r\n
"
"c=IN IP%c %s/%d
\r\n
"
...
...
@@ -649,21 +633,28 @@ static int SDPGenerate( sap_handler_t *p_sap, session_descriptor_t *p_session )
"a=tool:"
PACKAGE_STRING
"
\r\n
"
"a=type:broadcast
\r\n
"
,
i_sdp_id
,
i_sdp_version
,
ipv
,
p_addr
->
psz_machine
,
psz_name
,
ipv
,
psz_uri
,
p_session
->
i_ttl
,
p_session
->
i_port
,
p_session
->
i_payload
);
p_session
->
i_port
,
p_session
->
i_payload
)
==
-
1
)
{
free
(
psz_name
);
FREE
(
psz_group
);
return
NULL
;
}
free
(
psz_name
);
if
(
psz_group
)
{
sprintf
(
p_session
->
psz_sdp
,
"%sa=x-plgroup:%s
\r\n
"
,
p_session
->
psz_sdp
,
psz_group
);
/* FIXME: this is illegal use of sprintf */
sprintf
(
psz_sdp
,
"%sa=x-plgroup:%s
\r\n
"
,
psz_sdp
,
psz_group
);
free
(
psz_group
);
}
msg_Dbg
(
p_sap
,
"Generated SDP (%i bytes):
\n
%s"
,
strlen
(
p
_session
->
p
sz_sdp
),
p_session
->
psz_sdp
);
return
VLC_SUCCESS
;
msg_Dbg
(
p_sap
,
"Generated SDP (%i bytes):
\n
%s"
,
strlen
(
psz_sdp
),
psz_sdp
);
return
psz_sdp
;
}
static
int
CalculateRate
(
sap_handler_t
*
p_sap
,
sap_address_t
*
p_address
)
...
...
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