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
34b47be9
Commit
34b47be9
authored
Mar 17, 2015
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
udp: use the new FIFO functions
parent
757ce256
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
25 additions
and
7 deletions
+25
-7
modules/access/udp.c
modules/access/udp.c
+25
-7
No files found.
modules/access/udp.c
View file @
34b47be9
...
@@ -72,6 +72,7 @@ vlc_module_end ()
...
@@ -72,6 +72,7 @@ vlc_module_end ()
struct
access_sys_t
struct
access_sys_t
{
{
int
fd
;
int
fd
;
bool
running
;
size_t
fifo_size
;
size_t
fifo_size
;
block_fifo_t
*
fifo
;
block_fifo_t
*
fifo
;
vlc_thread_t
thread
;
vlc_thread_t
thread
;
...
@@ -166,6 +167,7 @@ static int Open( vlc_object_t *p_this )
...
@@ -166,6 +167,7 @@ static int Open( vlc_object_t *p_this )
goto
error
;
goto
error
;
}
}
sys
->
running
=
true
;
sys
->
fifo_size
=
var_InheritInteger
(
p_access
,
"udp-buffer"
);
sys
->
fifo_size
=
var_InheritInteger
(
p_access
,
"udp-buffer"
);
if
(
vlc_clone
(
&
sys
->
thread
,
ThreadRead
,
p_access
,
if
(
vlc_clone
(
&
sys
->
thread
,
ThreadRead
,
p_access
,
...
@@ -234,11 +236,17 @@ static block_t *BlockUDP( access_t *p_access )
...
@@ -234,11 +236,17 @@ static block_t *BlockUDP( access_t *p_access )
access_sys_t
*
sys
=
p_access
->
p_sys
;
access_sys_t
*
sys
=
p_access
->
p_sys
;
block_t
*
block
;
block_t
*
block
;
if
(
p_access
->
info
.
b_eof
)
if
(
p_access
->
info
.
b_eof
)
return
NULL
;
return
NULL
;
block
=
block_FifoGet
(
sys
->
fifo
);
vlc_fifo_Lock
(
sys
->
fifo
);
p_access
->
info
.
b_eof
=
block
==
NULL
;
while
(
vlc_fifo_IsEmpty
(
sys
->
fifo
)
&&
sys
->
running
)
vlc_fifo_Wait
(
sys
->
fifo
);
block
=
vlc_fifo_DequeueUnlocked
(
sys
->
fifo
);
p_access
->
info
.
b_eof
=
!
sys
->
running
;
vlc_fifo_Unlock
(
sys
->
fifo
);
return
block
;
return
block
;
}
}
...
@@ -250,7 +258,10 @@ static void* ThreadRead( void *data )
...
@@ -250,7 +258,10 @@ static void* ThreadRead( void *data )
access_t
*
access
=
data
;
access_t
*
access
=
data
;
access_sys_t
*
sys
=
access
->
p_sys
;
access_sys_t
*
sys
=
access
->
p_sys
;
for
(
;;
)
vlc_fifo_Lock
(
sys
->
fifo
);
vlc_fifo_CleanupPush
(
sys
->
fifo
);
for
(;;)
{
{
block_t
*
pkt
=
block_Alloc
(
MTU
);
block_t
*
pkt
=
block_Alloc
(
MTU
);
if
(
unlikely
(
pkt
==
NULL
))
if
(
unlikely
(
pkt
==
NULL
))
...
@@ -271,10 +282,17 @@ static void* ThreadRead( void *data )
...
@@ -271,10 +282,17 @@ static void* ThreadRead( void *data )
}
}
pkt
->
i_buffer
=
len
;
pkt
->
i_buffer
=
len
;
block_FifoPace
(
sys
->
fifo
,
SIZE_MAX
,
sys
->
fifo_size
-
len
);
block_FifoPut
(
sys
->
fifo
,
pkt
);
/* Discard old buffers on overflow */
while
(
vlc_fifo_GetBytes
(
sys
->
fifo
)
+
len
>
sys
->
fifo_size
)
block_Release
(
vlc_fifo_DequeueUnlocked
(
sys
->
fifo
));
vlc_fifo_QueueUnlocked
(
sys
->
fifo
,
pkt
);
}
}
block_FifoWake
(
sys
->
fifo
);
sys
->
running
=
false
;
vlc_fifo_Signal
(
sys
->
fifo
);
vlc_cleanup_run
();
return
NULL
;
return
NULL
;
}
}
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