]> git.ipfire.org Git - thirdparty/systemd.git/commit - src/basic/socket-util.c
core: rework how we match mount units against each other
authorLennart Poettering <lennart@poettering.net>
Thu, 26 Sep 2013 18:14:24 +0000 (20:14 +0200)
committerLennart Poettering <lennart@poettering.net>
Thu, 26 Sep 2013 18:20:30 +0000 (20:20 +0200)
commita57f7e2c828b852eb32fd810dcea041bb2975501
tree9d088f212995c20b3ba2d2574ca8027fad25a51b
parent6270c1bd8f83e9985458c63688f452be7626766f
core: rework how we match mount units against each other

Previously to automatically create dependencies between mount units we
matched every mount unit agains all others resulting in O(n^2)
complexity. On setups with large amounts of mount units this might make
things slow.

This change replaces the matching code to use a hashtable that is keyed
by a path prefix, and points to a set of units that require that path to
be around. When a new mount unit is installed it is hence sufficient to
simply look up this set of units via its own file system paths to know
which units to order after itself.

This patch also changes all unit types to only create automatic mount
dependencies via the RequiresMountsFor= logic, and this is exposed to
the outside to make things more transparent.

With this change we still have some O(n) complexities in place when
handling mounts, but that's currently unavoidable due to kernel APIs,
and still substantially better than O(n^2) as before.

https://bugs.freedesktop.org/show_bug.cgi?id=69740
17 files changed:
src/core/automount.c
src/core/automount.h
src/core/load-fragment-gperf.gperf.m4
src/core/load-fragment.c
src/core/manager.c
src/core/manager.h
src/core/mount.c
src/core/path.c
src/core/path.h
src/core/socket.c
src/core/socket.h
src/core/swap.c
src/core/swap.h
src/core/unit.c
src/core/unit.h
src/shared/socket-util.c
src/shared/socket-util.h