Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
L
lxc
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Chen Yisong
lxc
Commits
59c6b066
Unverified
Commit
59c6b066
authored
Nov 16, 2020
by
Stéphane Graber
Committed by
GitHub
Nov 16, 2020
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #3581 from brauner/2020-11-16/fixes
conf: improve mountinfo and config parsing
parents
c875dc63
a39fc34b
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
40 additions
and
32 deletions
+40
-32
conf.c
src/lxc/conf.c
+3
-7
file_utils.c
src/lxc/file_utils.c
+5
-2
file_utils.h
src/lxc/file_utils.h
+5
-1
parse.c
src/lxc/parse.c
+27
-22
No files found.
src/lxc/conf.c
View file @
59c6b066
...
@@ -2980,9 +2980,9 @@ void turn_into_dependent_mounts(void)
...
@@ -2980,9 +2980,9 @@ void turn_into_dependent_mounts(void)
__do_free
char
*
line
=
NULL
;
__do_free
char
*
line
=
NULL
;
__do_fclose
FILE
*
f
=
NULL
;
__do_fclose
FILE
*
f
=
NULL
;
__do_close
int
memfd
=
-
EBADF
,
mntinfo_fd
=
-
EBADF
;
__do_close
int
memfd
=
-
EBADF
,
mntinfo_fd
=
-
EBADF
;
int
ret
;
ssize_t
copied
;
size_t
len
=
0
;
size_t
len
=
0
;
ssize_t
copied
;
int
ret
;
mntinfo_fd
=
open
(
"/proc/self/mountinfo"
,
O_RDONLY
|
O_CLOEXEC
);
mntinfo_fd
=
open
(
"/proc/self/mountinfo"
,
O_RDONLY
|
O_CLOEXEC
);
if
(
mntinfo_fd
<
0
)
{
if
(
mntinfo_fd
<
0
)
{
...
@@ -3006,12 +3006,8 @@ void turn_into_dependent_mounts(void)
...
@@ -3006,12 +3006,8 @@ void turn_into_dependent_mounts(void)
}
}
}
}
again:
copied
=
fd_to_fd
(
mntinfo_fd
,
memfd
);
copied
=
lxc_sendfile_nointr
(
memfd
,
mntinfo_fd
,
NULL
,
LXC_SENDFILE_MAX
);
if
(
copied
<
0
)
{
if
(
copied
<
0
)
{
if
(
errno
==
EINTR
)
goto
again
;
SYSERROR
(
"Failed to copy
\"
/proc/self/mountinfo
\"
"
);
SYSERROR
(
"Failed to copy
\"
/proc/self/mountinfo
\"
"
);
return
;
return
;
}
}
...
...
src/lxc/file_utils.c
View file @
59c6b066
...
@@ -382,8 +382,10 @@ ssize_t lxc_sendfile_nointr(int out_fd, int in_fd, off_t *offset, size_t count)
...
@@ -382,8 +382,10 @@ ssize_t lxc_sendfile_nointr(int out_fd, int in_fd, off_t *offset, size_t count)
return
ret
;
return
ret
;
}
}
int
fd_to_fd
(
int
from
,
int
to
)
ssize_t
__
fd_to_fd
(
int
from
,
int
to
)
{
{
ssize_t
total_bytes
=
0
;
for
(;;)
{
for
(;;)
{
uint8_t
buf
[
PATH_MAX
];
uint8_t
buf
[
PATH_MAX
];
uint8_t
*
p
=
buf
;
uint8_t
*
p
=
buf
;
...
@@ -407,9 +409,10 @@ int fd_to_fd(int from, int to)
...
@@ -407,9 +409,10 @@ int fd_to_fd(int from, int to)
bytes_to_write
-=
bytes_written
;
bytes_to_write
-=
bytes_written
;
p
+=
bytes_written
;
p
+=
bytes_written
;
}
while
(
bytes_to_write
>
0
);
}
while
(
bytes_to_write
>
0
);
total_bytes
+=
bytes_to_write
;
}
}
return
0
;
return
total_bytes
;
}
}
int
fd_to_buf
(
int
fd
,
char
**
buf
,
size_t
*
length
)
int
fd_to_buf
(
int
fd
,
char
**
buf
,
size_t
*
length
)
...
...
src/lxc/file_utils.h
View file @
59c6b066
...
@@ -68,7 +68,11 @@ __hidden extern FILE *fopen_cloexec(const char *path, const char *mode);
...
@@ -68,7 +68,11 @@ __hidden extern FILE *fopen_cloexec(const char *path, const char *mode);
__hidden
extern
ssize_t
lxc_sendfile_nointr
(
int
out_fd
,
int
in_fd
,
off_t
*
offset
,
size_t
count
);
__hidden
extern
ssize_t
lxc_sendfile_nointr
(
int
out_fd
,
int
in_fd
,
off_t
*
offset
,
size_t
count
);
__hidden
extern
char
*
file_to_buf
(
const
char
*
path
,
size_t
*
length
);
__hidden
extern
char
*
file_to_buf
(
const
char
*
path
,
size_t
*
length
);
__hidden
extern
int
fd_to_buf
(
int
fd
,
char
**
buf
,
size_t
*
length
);
__hidden
extern
int
fd_to_buf
(
int
fd
,
char
**
buf
,
size_t
*
length
);
__hidden
extern
int
fd_to_fd
(
int
from
,
int
to
);
__hidden
extern
ssize_t
__fd_to_fd
(
int
from
,
int
to
);
static
inline
int
fd_to_fd
(
int
from
,
int
to
)
{
return
__fd_to_fd
(
from
,
to
)
>=
0
;
}
__hidden
extern
int
lxc_open_dirfd
(
const
char
*
dir
);
__hidden
extern
int
lxc_open_dirfd
(
const
char
*
dir
);
__hidden
extern
FILE
*
fdopen_cached
(
int
fd
,
const
char
*
mode
,
void
**
caller_freed_buffer
);
__hidden
extern
FILE
*
fdopen_cached
(
int
fd
,
const
char
*
mode
,
void
**
caller_freed_buffer
);
__hidden
extern
FILE
*
fopen_cached
(
const
char
*
path
,
const
char
*
mode
,
void
**
caller_freed_buffer
);
__hidden
extern
FILE
*
fopen_cached
(
const
char
*
path
,
const
char
*
mode
,
void
**
caller_freed_buffer
);
...
...
src/lxc/parse.c
View file @
59c6b066
...
@@ -5,6 +5,7 @@
...
@@ -5,6 +5,7 @@
#endif
#endif
#include <dirent.h>
#include <dirent.h>
#include <errno.h>
#include <errno.h>
#include <limits.h>
#include <stdio.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdlib.h>
#include <string.h>
#include <string.h>
...
@@ -50,11 +51,12 @@ int lxc_strmunmap(void *addr, size_t length)
...
@@ -50,11 +51,12 @@ int lxc_strmunmap(void *addr, size_t length)
int
lxc_file_for_each_line_mmap
(
const
char
*
file
,
lxc_file_cb
callback
,
void
*
data
)
int
lxc_file_for_each_line_mmap
(
const
char
*
file
,
lxc_file_cb
callback
,
void
*
data
)
{
{
int
saved_errno
;
__do_close
int
fd
=
-
EBADF
,
memfd
=
-
EBADF
;
ssize_t
ret
=
-
1
,
bytes_sent
;
ssize_t
ret
=
-
1
;
char
*
line
;
int
fd
=
-
1
,
memfd
=
-
1
;
char
*
buf
=
NULL
;
char
*
buf
=
NULL
;
struct
stat
st
=
{};
ssize_t
bytes
;
char
*
line
;
memfd
=
memfd_create
(
".lxc_config_file"
,
MFD_CLOEXEC
);
memfd
=
memfd_create
(
".lxc_config_file"
,
MFD_CLOEXEC
);
if
(
memfd
<
0
)
{
if
(
memfd
<
0
)
{
...
@@ -65,8 +67,7 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
...
@@ -65,8 +67,7 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
goto
on_error
;
goto
on_error
;
}
}
TRACE
(
"Failed to create in-memory file. Falling back to "
TRACE
(
"Failed to create in-memory file. Falling back to temporary file"
);
"temporary file"
);
memfd
=
lxc_make_tmpfile
(
template
,
true
);
memfd
=
lxc_make_tmpfile
(
template
,
true
);
if
(
memfd
<
0
)
{
if
(
memfd
<
0
)
{
SYSERROR
(
"Failed to create temporary file
\"
%s
\"
"
,
template
);
SYSERROR
(
"Failed to create temporary file
\"
%s
\"
"
,
template
);
...
@@ -80,10 +81,21 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
...
@@ -80,10 +81,21 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
goto
on_error
;
goto
on_error
;
}
}
/* sendfile() handles up to 2GB. No config file should be that big. */
ret
=
fstat
(
fd
,
&
st
);
bytes_sent
=
lxc_sendfile_nointr
(
memfd
,
fd
,
NULL
,
LXC_SENDFILE_MAX
);
if
(
ret
)
{
if
(
bytes_sent
<
0
)
{
SYSERROR
(
"Failed to stat file
\"
%s
\"
"
,
file
);
SYSERROR
(
"Failed to sendfile
\"
%s
\"
"
,
file
);
goto
on_error
;
}
if
(
st
.
st_size
>
INT_MAX
)
{
SYSERROR
(
"Excessively large config file
\"
%s
\"
"
,
file
);
goto
on_error
;
}
bytes
=
__fd_to_fd
(
fd
,
memfd
);
if
(
bytes
<
0
)
{
SYSERROR
(
"Failed to copy config file
\"
%s
\"
"
,
file
);
goto
on_error
;
goto
on_error
;
}
}
...
@@ -92,7 +104,7 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
...
@@ -92,7 +104,7 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
SYSERROR
(
"Failed to append zero byte"
);
SYSERROR
(
"Failed to append zero byte"
);
goto
on_error
;
goto
on_error
;
}
}
bytes
_sent
++
;
bytes
++
;
ret
=
lseek
(
memfd
,
0
,
SEEK_SET
);
ret
=
lseek
(
memfd
,
0
,
SEEK_SET
);
if
(
ret
<
0
)
{
if
(
ret
<
0
)
{
...
@@ -101,8 +113,7 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
...
@@ -101,8 +113,7 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
}
}
ret
=
-
1
;
ret
=
-
1
;
buf
=
mmap
(
NULL
,
bytes_sent
,
PROT_READ
|
PROT_WRITE
,
buf
=
mmap
(
NULL
,
bytes
,
PROT_READ
|
PROT_WRITE
,
MAP_PRIVATE
|
MAP_POPULATE
,
memfd
,
0
);
MAP_SHARED
|
MAP_POPULATE
,
memfd
,
0
);
if
(
buf
==
MAP_FAILED
)
{
if
(
buf
==
MAP_FAILED
)
{
buf
=
NULL
;
buf
=
NULL
;
SYSERROR
(
"Failed to mmap"
);
SYSERROR
(
"Failed to mmap"
);
...
@@ -117,24 +128,18 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
...
@@ -117,24 +128,18 @@ int lxc_file_for_each_line_mmap(const char *file, lxc_file_cb callback, void *da
* error.
* error.
*/
*/
if
(
ret
<
0
)
if
(
ret
<
0
)
ERROR
(
"Failed to parse config file
\"
%s
\"
at
"
ERROR
(
"Failed to parse config file
\"
%s
\"
at
line
\"
%s
\"
"
,
"line
\"
%s
\"
"
,
file
,
line
);
file
,
line
);
break
;
break
;
}
}
}
}
on_error:
on_error:
saved_errno
=
errno
;
if
(
buf
&&
munmap
(
buf
,
bytes
))
{
if
(
fd
>=
0
)
close
(
fd
);
if
(
memfd
>=
0
)
close
(
memfd
);
if
(
buf
&&
munmap
(
buf
,
bytes_sent
))
{
SYSERROR
(
"Failed to unmap"
);
SYSERROR
(
"Failed to unmap"
);
if
(
ret
==
0
)
if
(
ret
==
0
)
ret
=
-
1
;
ret
=
-
1
;
}
}
errno
=
saved_errno
;
return
ret
;
return
ret
;
}
}
...
...
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