[systemd-devel] [RFC 4/4] add remote-fs dependencies if needed after change

Andrei Borzenkov arvidjaar at gmail.com
Sat Nov 8 21:32:05 PST 2014


В Thu,  6 Nov 2014 21:11:03 -0800
Chris Leech <cleech at redhat.com> пишет:

> This is an attempt to add it the remote-fs dependencies to a mount unit
> if the options change, like when the utab options are picked up after
> mountinfo has already been processed.  It just adds the remote-fs
> dependencies, leaving the local-fs ones in place.
> 
> With this change I always get mount units with proper remote-fs
> dependencies when mounted with the _netdev option.
> 
> It it not working for -o remount,_netdev.  But that looks like a
> libmount issue in that the ROOT field is not being set in utab on a
> remount, so if the initial mount did not require a utab entry then
> remount options never get merge in properly in mnt_table_parse_mtab
> ---
>  src/core/mount.c | 13 +++++++++++++
>  1 file changed, 13 insertions(+)
> 
> diff --git a/src/core/mount.c b/src/core/mount.c
> index 7d77021..092a720 100644
> --- a/src/core/mount.c
> +++ b/src/core/mount.c
> @@ -1436,6 +1436,19 @@ static int mount_add_one(
>                          }
>                  }
>  
> +                if (m->running_as == SYSTEMD_SYSTEM) {
> +                        const char* target;
> +
> +                        target = mount_needs_network(options, fstype) ?  SPECIAL_REMOTE_FS_TARGET : NULL;
> +                        /* _netdev option may have shown up late, or on a
> +                         * remount. Add remote-fs dependencies, even though
> +                         * local-fs ones may already be there */
> +                        if (target) {
> +                                unit_add_dependency_by_name(u, UNIT_BEFORE, target, NULL, true);

Should not it also add After on network.target to ensure it is
unmounted before network is down on shutdown? May be simply calling
mount_add_default_dependencies() would be appropriate here.

> +                                load_extras = true;
> +                        }
> +                }
> +
>                  if (u->load_state == UNIT_NOT_FOUND) {
>                          u->load_state = UNIT_LOADED;
>                          u->load_error = 0;



More information about the systemd-devel mailing list