1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-20 14:03:39 +03:00

machine-image: openat() doesn't operate on the cwd if the first argument is specified

A fix-up for bcb846f30f9ca8f42e79d109706aee9f2032261b.
This commit is contained in:
Lennart Poettering 2019-05-24 10:54:09 +02:00 committed by Zbigniew Jędrzejewski-Szmek
parent de26d715e3
commit 2570578d90

View File

@ -200,8 +200,7 @@ static int image_make(
const struct stat *st, const struct stat *st,
Image **ret) { Image **ret) {
_cleanup_free_ char *pretty_buffer = NULL; _cleanup_free_ char *pretty_buffer = NULL, *parent = NULL;
_cleanup_free_ char *cwd = NULL;
struct stat stbuf; struct stat stbuf;
bool read_only; bool read_only;
int r; int r;
@ -223,8 +222,12 @@ static int image_make(
st = &stbuf; st = &stbuf;
} }
if (!path) if (!path) {
safe_getcwd(&cwd); if (dfd == AT_FDCWD)
(void) safe_getcwd(&parent);
else
(void) fd_get_path(dfd, &parent);
}
read_only = read_only =
(path && path_startswith(path, "/usr")) || (path && path_startswith(path, "/usr")) ||
@ -364,7 +367,7 @@ static int image_make(
block_fd = openat(dfd, filename, O_RDONLY|O_NONBLOCK|O_CLOEXEC|O_NOCTTY); block_fd = openat(dfd, filename, O_RDONLY|O_NONBLOCK|O_CLOEXEC|O_NOCTTY);
if (block_fd < 0) if (block_fd < 0)
log_debug_errno(errno, "Failed to open block device %s/%s, ignoring: %m", path ?: strnull(cwd), filename); log_debug_errno(errno, "Failed to open block device %s/%s, ignoring: %m", path ?: strnull(parent), filename);
else { else {
/* Refresh stat data after opening the node */ /* Refresh stat data after opening the node */
if (fstat(block_fd, &stbuf) < 0) if (fstat(block_fd, &stbuf) < 0)
@ -378,13 +381,13 @@ static int image_make(
int state = 0; int state = 0;
if (ioctl(block_fd, BLKROGET, &state) < 0) if (ioctl(block_fd, BLKROGET, &state) < 0)
log_debug_errno(errno, "Failed to issue BLKROGET on device %s/%s, ignoring: %m", path ?: strnull(cwd), filename); log_debug_errno(errno, "Failed to issue BLKROGET on device %s/%s, ignoring: %m", path ?: strnull(parent), filename);
else if (state) else if (state)
read_only = true; read_only = true;
} }
if (ioctl(block_fd, BLKGETSIZE64, &size) < 0) if (ioctl(block_fd, BLKGETSIZE64, &size) < 0)
log_debug_errno(errno, "Failed to issue BLKGETSIZE64 on device %s/%s, ignoring: %m", path ?: strnull(cwd), filename); log_debug_errno(errno, "Failed to issue BLKGETSIZE64 on device %s/%s, ignoring: %m", path ?: strnull(parent), filename);
block_fd = safe_close(block_fd); block_fd = safe_close(block_fd);
} }