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
f8dcf07f
Unverified
Commit
f8dcf07f
authored
Feb 03, 2021
by
Stéphane Graber
Committed by
GitHub
Feb 03, 2021
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #3648 from brauner/2021-02-03/fixes
conf: open hardening & fd-only operations
parents
b5e75029
a26822c5
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
102 additions
and
66 deletions
+102
-66
configure.ac
configure.ac
+1
-1
conf.c
src/lxc/conf.c
+51
-61
macro.h
src/lxc/macro.h
+2
-0
rexec.c
src/lxc/rexec.c
+8
-2
syscall_numbers.h
src/lxc/syscall_numbers.h
+20
-0
syscall_wrappers.h
src/lxc/syscall_wrappers.h
+17
-0
device_add_remove.c
src/tests/device_add_remove.c
+3
-2
No files found.
configure.ac
View file @
f8dcf07f
...
@@ -644,7 +644,7 @@ AC_CHECK_HEADER([ifaddrs.h],
...
@@ -644,7 +644,7 @@ AC_CHECK_HEADER([ifaddrs.h],
AC_HEADER_MAJOR
AC_HEADER_MAJOR
# Check for some syscalls functions
# Check for some syscalls functions
AC_CHECK_FUNCS([setns pivot_root sethostname unshare rand_r confstr faccessat gettid memfd_create move_mount open_tree execveat clone3 fsopen fspick fsconfig fsmount, openat2])
AC_CHECK_FUNCS([setns pivot_root sethostname unshare rand_r confstr faccessat gettid memfd_create move_mount open_tree execveat clone3 fsopen fspick fsconfig fsmount, openat2
, close_range
])
AC_CHECK_TYPES([struct open_how], [], [], [[#include <linux/openat2.h>]])
AC_CHECK_TYPES([struct open_how], [], [], [[#include <linux/openat2.h>]])
AC_CHECK_TYPES([struct clone_args], [], [], [[#include <linux/sched.h>]])
AC_CHECK_TYPES([struct clone_args], [], [], [[#include <linux/sched.h>]])
AC_CHECK_MEMBERS([struct clone_args.set_tid],[],[],[[#include <linux/sched.h>]])
AC_CHECK_MEMBERS([struct clone_args.set_tid],[],[],[[#include <linux/sched.h>]])
...
...
src/lxc/conf.c
View file @
f8dcf07f
This diff is collapsed.
Click to expand it.
src/lxc/macro.h
View file @
f8dcf07f
...
@@ -672,4 +672,6 @@ enum {
...
@@ -672,4 +672,6 @@ enum {
#define ENOCGROUP2 ENOMEDIUM
#define ENOCGROUP2 ENOMEDIUM
#define MAX_FILENO ~0U
#endif
/* __LXC_MACRO_H */
#endif
/* __LXC_MACRO_H */
src/lxc/rexec.c
View file @
f8dcf07f
...
@@ -127,10 +127,13 @@ static void lxc_rexec_as_memfd(char **argv, char **envp, const char *memfd_name)
...
@@ -127,10 +127,13 @@ static void lxc_rexec_as_memfd(char **argv, char **envp, const char *memfd_name)
sent
=
lxc_sendfile_nointr
(
memfd
>=
0
?
memfd
:
tmpfd
,
fd
,
NULL
,
sent
=
lxc_sendfile_nointr
(
memfd
>=
0
?
memfd
:
tmpfd
,
fd
,
NULL
,
st
.
st_size
-
bytes_sent
);
st
.
st_size
-
bytes_sent
);
if
(
sent
<
0
)
{
if
(
sent
<
0
)
{
/* Fallback to shoveling data between kernel- and
/*
* Fallback to shoveling data between kernel- and
* userspace.
* userspace.
*/
*/
lseek
(
fd
,
0
,
SEEK_SET
);
if
(
lseek
(
fd
,
0
,
SEEK_SET
)
==
(
off_t
)
-
1
)
fprintf
(
stderr
,
"Failed to seek to beginning of file"
);
if
(
fd_to_fd
(
fd
,
memfd
>=
0
?
memfd
:
tmpfd
))
if
(
fd_to_fd
(
fd
,
memfd
>=
0
?
memfd
:
tmpfd
))
break
;
break
;
...
@@ -159,6 +162,9 @@ static void lxc_rexec_as_memfd(char **argv, char **envp, const char *memfd_name)
...
@@ -159,6 +162,9 @@ static void lxc_rexec_as_memfd(char **argv, char **envp, const char *memfd_name)
if
(
execfd
<
0
)
if
(
execfd
<
0
)
return
;
return
;
ret
=
close_range
(
STDERR_FILENO
,
MAX_FILENO
,
CLOSE_RANGE_CLOEXEC
);
if
(
ret
&&
(
errno
!=
ENOSYS
&&
errno
!=
EINVAL
))
fprintf
(
stderr
,
"%m - Failed to mark all file descriptors as close-on-exec
\n
"
);
fexecve
(
execfd
,
argv
,
envp
);
fexecve
(
execfd
,
argv
,
envp
);
}
}
...
...
src/lxc/syscall_numbers.h
View file @
f8dcf07f
...
@@ -660,4 +660,24 @@
...
@@ -660,4 +660,24 @@
#endif
#endif
#endif
#endif
#ifndef __NR_close_range
#if defined __alpha__
#define __NR_close_range 546
#elif defined _MIPS_SIM
#if _MIPS_SIM == _MIPS_SIM_ABI32
/* o32 */
#define __NR_close_range (436 + 4000)
#endif
#if _MIPS_SIM == _MIPS_SIM_NABI32
/* n32 */
#define __NR_close_range (436 + 6000)
#endif
#if _MIPS_SIM == _MIPS_SIM_ABI64
/* n64 */
#define __NR_close_range (436 + 5000)
#endif
#elif defined __ia64__
#define __NR_close_range (436 + 1024)
#else
#define __NR_close_range 436
#endif
#endif
#endif
/* __LXC_SYSCALL_NUMBERS_H */
#endif
/* __LXC_SYSCALL_NUMBERS_H */
src/lxc/syscall_wrappers.h
View file @
f8dcf07f
...
@@ -257,10 +257,12 @@ struct lxc_open_how {
...
@@ -257,10 +257,12 @@ struct lxc_open_how {
#define PROTECT_LOOKUP_BENEATH (RESOLVE_BENEATH | RESOLVE_NO_XDEV | RESOLVE_NO_MAGICLINKS | RESOLVE_NO_SYMLINKS)
#define PROTECT_LOOKUP_BENEATH (RESOLVE_BENEATH | RESOLVE_NO_XDEV | RESOLVE_NO_MAGICLINKS | RESOLVE_NO_SYMLINKS)
#define PROTECT_LOOKUP_BENEATH_WITH_SYMLINKS (PROTECT_LOOKUP_BENEATH & ~RESOLVE_NO_SYMLINKS)
#define PROTECT_LOOKUP_BENEATH_WITH_SYMLINKS (PROTECT_LOOKUP_BENEATH & ~RESOLVE_NO_SYMLINKS)
#define PROTECT_LOOKUP_BENEATH_WITH_MAGICLINKS (PROTECT_LOOKUP_BENEATH & ~(RESOLVE_NO_SYMLINKS | RESOLVE_NO_MAGICLINKS))
#define PROTECT_LOOKUP_BENEATH_WITH_MAGICLINKS (PROTECT_LOOKUP_BENEATH & ~(RESOLVE_NO_SYMLINKS | RESOLVE_NO_MAGICLINKS))
#define PROTECT_LOOKUP_BENEATH_XDEV (PROTECT_LOOKUP_BENEATH & ~RESOLVE_NO_XDEV)
#define PROTECT_LOOKUP_ABSOLUTE (PROTECT_LOOKUP_BENEATH & ~RESOLVE_BENEATH)
#define PROTECT_LOOKUP_ABSOLUTE (PROTECT_LOOKUP_BENEATH & ~RESOLVE_BENEATH)
#define PROTECT_LOOKUP_ABSOLUTE_WITH_SYMLINKS (PROTECT_LOOKUP_ABSOLUTE & ~RESOLVE_NO_SYMLINKS)
#define PROTECT_LOOKUP_ABSOLUTE_WITH_SYMLINKS (PROTECT_LOOKUP_ABSOLUTE & ~RESOLVE_NO_SYMLINKS)
#define PROTECT_LOOKUP_ABSOLUTE_WITH_MAGICLINKS (PROTECT_LOOKUP_ABSOLUTE & ~(RESOLVE_NO_SYMLINKS | RESOLVE_NO_MAGICLINKS))
#define PROTECT_LOOKUP_ABSOLUTE_WITH_MAGICLINKS (PROTECT_LOOKUP_ABSOLUTE & ~(RESOLVE_NO_SYMLINKS | RESOLVE_NO_MAGICLINKS))
#define PROTECT_LOOKUP_ABSOLUTE_XDEV (PROTECT_LOOKUP_ABSOLUTE & ~RESOLVE_NO_XDEV)
#define PROTECT_OPATH_FILE (O_NOFOLLOW | O_PATH | O_CLOEXEC)
#define PROTECT_OPATH_FILE (O_NOFOLLOW | O_PATH | O_CLOEXEC)
#define PROTECT_OPATH_DIRECTORY (PROTECT_OPATH_FILE | O_DIRECTORY)
#define PROTECT_OPATH_DIRECTORY (PROTECT_OPATH_FILE | O_DIRECTORY)
...
@@ -282,4 +284,19 @@ static inline int openat2(int dfd, const char *filename, struct lxc_open_how *ho
...
@@ -282,4 +284,19 @@ static inline int openat2(int dfd, const char *filename, struct lxc_open_how *ho
}
}
#endif
/* HAVE_OPENAT2 */
#endif
/* HAVE_OPENAT2 */
#ifndef CLOSE_RANGE_UNSHARE
#define CLOSE_RANGE_UNSHARE (1U << 1)
#endif
#ifndef CLOSE_RANGE_CLOEXEC
#define CLOSE_RANGE_CLOEXEC (1U << 2)
#endif
#ifndef HAVE_CLOSE_RANGE
static
inline
int
close_range
(
unsigned
int
fd
,
unsigned
int
max_fd
,
unsigned
int
flags
)
{
return
syscall
(
__NR_close_range
,
fd
,
max_fd
,
flags
);
}
#endif
#endif
/* __LXC_SYSCALL_WRAPPER_H */
#endif
/* __LXC_SYSCALL_WRAPPER_H */
src/tests/device_add_remove.c
View file @
f8dcf07f
...
@@ -36,8 +36,8 @@ int main(int argc, char *argv[])
...
@@ -36,8 +36,8 @@ int main(int argc, char *argv[])
__do_close
int
fd_log
=
-
EBADF
;
__do_close
int
fd_log
=
-
EBADF
;
int
ret
=
1
;
int
ret
=
1
;
struct
lxc_log
log
=
{};
struct
lxc_log
log
=
{};
struct
lxc_container
*
c
=
NULL
;
char
template
[
sizeof
(
P_tmpdir
"/attach_XXXXXX"
)];
char
template
[
sizeof
(
P_tmpdir
"/attach_XXXXXX"
)];
struct
lxc_container
*
c
;
(
void
)
strlcpy
(
template
,
P_tmpdir
"/attach_XXXXXX"
,
sizeof
(
template
));
(
void
)
strlcpy
(
template
,
P_tmpdir
"/attach_XXXXXX"
,
sizeof
(
template
));
...
@@ -107,6 +107,7 @@ out:
...
@@ -107,6 +107,7 @@ out:
}
}
(
void
)
unlink
(
template
);
(
void
)
unlink
(
template
);
lxc_container_put
(
c
);
if
(
c
)
lxc_container_put
(
c
);
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