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
a60d8c4e
Unverified
Commit
a60d8c4e
authored
Feb 01, 2021
by
Christian Brauner
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
file_utils: add fdopenat()
Signed-off-by:
Christian Brauner
<
christian.brauner@ubuntu.com
>
parent
326bb02c
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
60 additions
and
23 deletions
+60
-23
file_utils.c
src/lxc/file_utils.c
+58
-0
file_utils.h
src/lxc/file_utils.h
+2
-0
utils.c
src/lxc/utils.c
+0
-22
utils.h
src/lxc/utils.h
+0
-1
No files found.
src/lxc/file_utils.c
View file @
a60d8c4e
...
@@ -517,6 +517,64 @@ FILE *fdopen_cached(int fd, const char *mode, void **caller_freed_buffer)
...
@@ -517,6 +517,64 @@ FILE *fdopen_cached(int fd, const char *mode, void **caller_freed_buffer)
return
f
;
return
f
;
}
}
int
fd_cloexec
(
int
fd
,
bool
cloexec
)
{
int
oflags
,
nflags
;
oflags
=
fcntl
(
fd
,
F_GETFD
,
0
);
if
(
oflags
<
0
)
return
-
errno
;
if
(
cloexec
)
nflags
=
oflags
|
FD_CLOEXEC
;
else
nflags
=
oflags
&
~
FD_CLOEXEC
;
if
(
nflags
==
oflags
)
return
0
;
if
(
fcntl
(
fd
,
F_SETFD
,
nflags
)
<
0
)
return
-
errno
;
return
0
;
}
static
inline
int
dup_cloexec
(
int
fd
)
{
__do_close
int
fd_dup
=
-
EBADF
;
fd_dup
=
dup
(
fd
);
if
(
fd_dup
<
0
)
return
-
errno
;
if
(
fd_cloexec
(
fd_dup
,
true
))
return
-
errno
;
return
move_fd
(
fd_dup
);
}
FILE
*
fdopenat
(
int
dfd
,
const
char
*
path
,
const
char
*
mode
)
{
__do_close
int
fd
=
-
EBADF
;
__do_fclose
FILE
*
f
=
NULL
;
if
(
is_empty_string
(
path
))
fd
=
dup_cloexec
(
dfd
);
else
fd
=
openat
(
dfd
,
path
,
O_CLOEXEC
|
O_NOCTTY
|
O_NOFOLLOW
);
if
(
fd
<
0
)
return
NULL
;
f
=
fdopen
(
fd
,
"re"
);
if
(
!
f
)
return
NULL
;
/* Transfer ownership of fd. */
move_fd
(
fd
);
return
move_ptr
(
f
);
}
int
timens_offset_write
(
clockid_t
clk_id
,
int64_t
s_offset
,
int64_t
ns_offset
)
int
timens_offset_write
(
clockid_t
clk_id
,
int64_t
s_offset
,
int64_t
ns_offset
)
{
{
__do_close
int
fd
=
-
EBADF
;
__do_close
int
fd
=
-
EBADF
;
...
...
src/lxc/file_utils.h
View file @
a60d8c4e
...
@@ -73,8 +73,10 @@ static inline int fd_to_fd(int from, int to)
...
@@ -73,8 +73,10 @@ static inline int fd_to_fd(int from, int to)
{
{
return
__fd_to_fd
(
from
,
to
)
>=
0
;
return
__fd_to_fd
(
from
,
to
)
>=
0
;
}
}
__hidden
extern
int
fd_cloexec
(
int
fd
,
bool
cloexec
);
__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
*
fdopenat
(
int
dfd
,
const
char
*
path
,
const
char
*
mode
);
__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
);
__hidden
extern
int
timens_offset_write
(
clockid_t
clk_id
,
int64_t
s_offset
,
int64_t
ns_offset
);
__hidden
extern
int
timens_offset_write
(
clockid_t
clk_id
,
int64_t
s_offset
,
int64_t
ns_offset
);
__hidden
extern
bool
exists_dir_at
(
int
dir_fd
,
const
char
*
path
);
__hidden
extern
bool
exists_dir_at
(
int
dir_fd
,
const
char
*
path
);
...
...
src/lxc/utils.c
View file @
a60d8c4e
...
@@ -1779,28 +1779,6 @@ int lxc_set_death_signal(int signal, pid_t parent, int parent_status_fd)
...
@@ -1779,28 +1779,6 @@ int lxc_set_death_signal(int signal, pid_t parent, int parent_status_fd)
return
0
;
return
0
;
}
}
int
fd_cloexec
(
int
fd
,
bool
cloexec
)
{
int
oflags
,
nflags
;
oflags
=
fcntl
(
fd
,
F_GETFD
,
0
);
if
(
oflags
<
0
)
return
-
errno
;
if
(
cloexec
)
nflags
=
oflags
|
FD_CLOEXEC
;
else
nflags
=
oflags
&
~
FD_CLOEXEC
;
if
(
nflags
==
oflags
)
return
0
;
if
(
fcntl
(
fd
,
F_SETFD
,
nflags
)
<
0
)
return
-
errno
;
return
0
;
}
int
lxc_rm_rf
(
const
char
*
dirname
)
int
lxc_rm_rf
(
const
char
*
dirname
)
{
{
__do_closedir
DIR
*
dir
=
NULL
;
__do_closedir
DIR
*
dir
=
NULL
;
...
...
src/lxc/utils.h
View file @
a60d8c4e
...
@@ -223,7 +223,6 @@ __hidden extern uint64_t lxc_find_next_power2(uint64_t n);
...
@@ -223,7 +223,6 @@ __hidden extern uint64_t lxc_find_next_power2(uint64_t n);
/* Set a signal the child process will receive after the parent has died. */
/* Set a signal the child process will receive after the parent has died. */
__hidden
extern
int
lxc_set_death_signal
(
int
signal
,
pid_t
parent
,
int
parent_status_fd
);
__hidden
extern
int
lxc_set_death_signal
(
int
signal
,
pid_t
parent
,
int
parent_status_fd
);
__hidden
extern
int
fd_cloexec
(
int
fd
,
bool
cloexec
);
__hidden
extern
int
lxc_rm_rf
(
const
char
*
dirname
);
__hidden
extern
int
lxc_rm_rf
(
const
char
*
dirname
);
__hidden
extern
bool
lxc_can_use_pidfd
(
int
pidfd
);
__hidden
extern
bool
lxc_can_use_pidfd
(
int
pidfd
);
...
...
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