Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
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-1.1
Commits
8ccbbab4
Commit
8ccbbab4
authored
Oct 11, 2008
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Decomp: vmsplice support
parent
b9cf76e8
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
10 deletions
+28
-10
modules/demux/decomp.c
modules/demux/decomp.c
+28
-10
No files found.
modules/demux/decomp.c
View file @
8ccbbab4
...
@@ -32,6 +32,10 @@
...
@@ -32,6 +32,10 @@
#include <spawn.h>
#include <spawn.h>
#include <sys/wait.h>
#include <sys/wait.h>
#include <sys/ioctl.h>
#include <sys/ioctl.h>
#ifdef __linux__
# include <sys/uio.h>
# include <sys/mman.h>
#endif
#include <assert.h>
#include <assert.h>
...
@@ -71,11 +75,13 @@ static void cloexec (int fd)
...
@@ -71,11 +75,13 @@ static void cloexec (int fd)
extern
char
**
environ
;
extern
char
**
environ
;
static
void
cleanup_fd
(
void
*
data
)
static
const
size_t
bufsize
=
65536
;
static
void
cleanup_mmap
(
void
*
addr
)
{
{
close
((
intptr_t
)
data
);
munmap
(
addr
,
bufsize
);
}
}
static
void
*
Thread
(
void
*
data
)
static
void
*
Thread
(
void
*
data
)
{
{
demux_t
*
demux
=
data
;
demux_t
*
demux
=
data
;
...
@@ -83,17 +89,19 @@ static void *Thread (void *data)
...
@@ -83,17 +89,19 @@ static void *Thread (void *data)
int
fd
=
p_sys
->
write_fd
;
int
fd
=
p_sys
->
write_fd
;
bool
error
=
false
;
bool
error
=
false
;
vlc_cleanup_push
(
cleanup_fd
,
(
void
*
)(
intptr_t
)
fd
);
do
do
{
{
ssize_t
len
;
int
canc
=
vlc_savecancel
();
#ifdef __linux__
#ifdef __linux__
/* TODO: mmap() + vmsplice() */
unsigned
char
*
buf
=
mmap
(
NULL
,
bufsize
,
PROT_READ
|
PROT_WRITE
,
MAP_PRIVATE
|
MAP_ANONYMOUS
,
-
1
,
0
);
vlc_cleanup_push
(
cleanup_mmap
,
buf
);
#else
unsigned
char
buf
[
bufsize
];
#endif
#endif
unsigned
char
buf
[
65536
];
int
canc
=
vlc_savecancel
();
ssize_t
len
=
stream_Read
(
demux
->
s
,
buf
,
sizeof
(
buf
));
len
=
stream_Read
(
demux
->
s
,
buf
,
bufsize
);
vlc_restorecancel
(
canc
);
vlc_restorecancel
(
canc
);
if
(
len
<=
0
)
if
(
len
<=
0
)
...
@@ -101,7 +109,13 @@ static void *Thread (void *data)
...
@@ -101,7 +109,13 @@ static void *Thread (void *data)
for
(
ssize_t
i
=
0
,
j
=
0
;
i
<
len
;
i
+=
j
)
for
(
ssize_t
i
=
0
,
j
=
0
;
i
<
len
;
i
+=
j
)
{
{
j
=
write
(
fd
,
buf
+
i
,
len
-
i
);
struct
iovec
iov
[
1
]
=
{
{
buf
+
i
,
len
-
i
,
}
};
#ifdef __linux__
j
=
vmsplice
(
fd
,
iov
,
1
,
SPLICE_F_GIFT
);
#else
j
=
writev
(
fd
,
iov
,
1
);
#endif
if
(
j
==
-
1
)
if
(
j
==
-
1
)
{
{
msg_Err
(
demux
,
"cannot write data (%m)"
);
msg_Err
(
demux
,
"cannot write data (%m)"
);
...
@@ -109,10 +123,13 @@ static void *Thread (void *data)
...
@@ -109,10 +123,13 @@ static void *Thread (void *data)
break
;
break
;
}
}
}
}
#ifdef __linux__
vlc_cleanup_run
();
/* munmap (buf, bufsize) */
#endif
}
}
while
(
!
error
);
while
(
!
error
);
vlc_cleanup_run
();
/* close(fd) */
msg_Dbg
(
demux
,
"compressed stream at EOF"
);
return
NULL
;
return
NULL
;
}
}
...
@@ -249,6 +266,7 @@ static void Close (vlc_object_t *obj)
...
@@ -249,6 +266,7 @@ static void Close (vlc_object_t *obj)
stream_DemuxDelete
(
p_sys
->
out
);
stream_DemuxDelete
(
p_sys
->
out
);
close
(
p_sys
->
read_fd
);
close
(
p_sys
->
read_fd
);
vlc_join
(
p_sys
->
thread
,
NULL
);
vlc_join
(
p_sys
->
thread
,
NULL
);
close
(
p_sys
->
write_fd
);
msg_Dbg
(
obj
,
"waiting for PID %u"
,
(
unsigned
)
p_sys
->
pid
);
msg_Dbg
(
obj
,
"waiting for PID %u"
,
(
unsigned
)
p_sys
->
pid
);
while
(
waitpid
(
p_sys
->
pid
,
&
status
,
0
)
==
-
1
);
while
(
waitpid
(
p_sys
->
pid
,
&
status
,
0
)
==
-
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