mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-05 09:17:44 +03:00
Merge pull request #14043 from poettering/shutdown-noswap-fix
shutdown: it's OK if /proc/swaps is missing
This commit is contained in:
commit
addc5f1e25
@ -62,7 +62,7 @@ int mount_points_list_get(const char *mountinfo, MountPoint **head) {
|
|||||||
|
|
||||||
r = libmount_parse(mountinfo, NULL, &table, &iter);
|
r = libmount_parse(mountinfo, NULL, &table, &iter);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_error_errno(r, "Failed to parse %s: %m", mountinfo);
|
return log_error_errno(r, "Failed to parse %s: %m", mountinfo ?: "/proc/self/mountinfo");
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
struct libmnt_fs *fs;
|
struct libmnt_fs *fs;
|
||||||
@ -77,7 +77,7 @@ int mount_points_list_get(const char *mountinfo, MountPoint **head) {
|
|||||||
if (r == 1)
|
if (r == 1)
|
||||||
break;
|
break;
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_error_errno(r, "Failed to get next entry from %s: %m", mountinfo);
|
return log_error_errno(r, "Failed to get next entry from %s: %m", mountinfo ?: "/proc/self/mountinfo");
|
||||||
|
|
||||||
path = mnt_fs_get_target(fs);
|
path = mnt_fs_get_target(fs);
|
||||||
if (!path)
|
if (!path)
|
||||||
@ -184,8 +184,10 @@ int swap_list_get(const char *swaps, MountPoint **head) {
|
|||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
r = mnt_table_parse_swaps(t, swaps);
|
r = mnt_table_parse_swaps(t, swaps);
|
||||||
|
if (r == -ENOENT) /* no /proc/swaps is fine */
|
||||||
|
return 0;
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_error_errno(r, "Failed to parse %s: %m", swaps);
|
return log_error_errno(r, "Failed to parse %s: %m", swaps ?: "/proc/swaps");
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
struct libmnt_fs *fs;
|
struct libmnt_fs *fs;
|
||||||
@ -196,7 +198,7 @@ int swap_list_get(const char *swaps, MountPoint **head) {
|
|||||||
if (r == 1)
|
if (r == 1)
|
||||||
break;
|
break;
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_error_errno(r, "Failed to get next entry from %s: %m", swaps);
|
return log_error_errno(r, "Failed to get next entry from %s: %m", swaps ?: "/proc/swaps");
|
||||||
|
|
||||||
source = mnt_fs_get_source(fs);
|
source = mnt_fs_get_source(fs);
|
||||||
if (!source)
|
if (!source)
|
||||||
@ -204,11 +206,11 @@ int swap_list_get(const char *swaps, MountPoint **head) {
|
|||||||
|
|
||||||
swap = new0(MountPoint, 1);
|
swap = new0(MountPoint, 1);
|
||||||
if (!swap)
|
if (!swap)
|
||||||
return -ENOMEM;
|
return log_oom();
|
||||||
|
|
||||||
swap->path = strdup(source);
|
swap->path = strdup(source);
|
||||||
if (!swap->path)
|
if (!swap->path)
|
||||||
return -ENOMEM;
|
return log_oom();
|
||||||
|
|
||||||
LIST_PREPEND(mount_point, *head, TAKE_PTR(swap));
|
LIST_PREPEND(mount_point, *head, TAKE_PTR(swap));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user