From ab5e770c4b2bd0933f7a965e7b455ea0a7cdbfa3 Mon Sep 17 00:00:00 2001 From: Paul Holzinger Date: Tue, 22 Jun 2021 16:06:25 +0200 Subject: [PATCH] getContainerNetworkInfo: lock netNsCtr before sync `syncContainer()` requires the container to be locked, otherwise we can end up with undefined behavior. [NO TESTS NEEDED] Signed-off-by: Paul Holzinger --- libpod/networking_linux.go | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/libpod/networking_linux.go b/libpod/networking_linux.go index eb515c000b..fc1d7df502 100644 --- a/libpod/networking_linux.go +++ b/libpod/networking_linux.go @@ -866,6 +866,10 @@ func (c *Container) getContainerNetworkInfo() (*define.InspectNetworkSettings, e if err != nil { return nil, err } + // see https://github.com/containers/podman/issues/10090 + // the container has to be locked for syncContainer() + netNsCtr.lock.Lock() + defer netNsCtr.lock.Unlock() // Have to sync to ensure that state is populated if err := netNsCtr.syncContainer(); err != nil { return nil, err