mirror of
https://github.com/containers/podman.git
synced 2025-07-02 00:30:00 +08:00
libpod: Factor out usage of unix.MNT_DETACH from (*Volume).unmount
There is an existing wrapper for unix.Unmount(..., MNT_DETACH) in util_linux.go but that filters all errors and for volumes, we only want to filter EINVAL. The existing libpod.Unmount seems to only have one call site so perhaps these can be merged. [NO NEW TESTS NEEDED] Signed-off-by: Doug Rabson <dfr@rabson.org>
This commit is contained in:
@ -180,7 +180,7 @@ func (v *Volume) unmount(force bool) error {
|
||||
}
|
||||
|
||||
// Unmount the volume
|
||||
if err := unix.Unmount(v.config.MountPoint, unix.MNT_DETACH); err != nil {
|
||||
if err := detachUnmount(v.config.MountPoint); err != nil {
|
||||
if err == unix.EINVAL {
|
||||
// Ignore EINVAL - the mount no longer exists.
|
||||
return nil
|
||||
|
9
libpod/volume_internal_linux.go
Normal file
9
libpod/volume_internal_linux.go
Normal file
@ -0,0 +1,9 @@
|
||||
package libpod
|
||||
|
||||
import (
|
||||
"golang.org/x/sys/unix"
|
||||
)
|
||||
|
||||
func detachUnmount(mountPoint string) error {
|
||||
return unix.Unmount(mountPoint, unix.MNT_DETACH)
|
||||
}
|
Reference in New Issue
Block a user