Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp710976pxv; Thu, 15 Jul 2021 14:08:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzAMc2ELJ9PUR82MlHZuvpCCMfimU83ekhTFKYl0yetz9jpd9cpJ0OzfY3KDklRSdlGUelJ X-Received: by 2002:a50:ed91:: with SMTP id h17mr9553686edr.133.1626383317290; Thu, 15 Jul 2021 14:08:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626383317; cv=none; d=google.com; s=arc-20160816; b=NdJ09UMdr9/mpkT75+9ib+SPu5/7IT2+NsoozqB+lIDMIKtolAP9BCxRpDNrqwhp9R xOsQd8Xi4aVLshhWqLz9Pd6SywTUZC0yzFavHiK/npnnCGGLVPThbBbuOPwxM2R6PdUC Yg3knx5OaRgJ1tUkOXHNkdRI3FbLQvFln2Dguau2EJmc+AyCrtcALl2CYBgKNUZ6woRv RBjVCKkxmLnMBNTxDEYyG5XXODSrIWapw2xTe5mc4e2tmXgp/QTUilNux0A0luD0Mp1u RfAeUXSoQ7CDjCKyHboEmmy+bFQX5SI5PRnxoQZBUkhNjotEndgsZ5J3hqs6G1WTtjOU cZjw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=ZcNNW4KW0/ExbxufjUdJMlu9eAXeTgVoZbnJjZib7EY=; b=xaCpP1pWqKOCYUeqpjj7CHVndZbz52dshfoyjAeaA8+jLKbFqf7DhwGirltjKWuAmd omHbQ+Y1T+oAu5MOLwKlTHRVAMtBzkvYh8BPb9L8X6mKp7jk85Qvm5l5X9Diop51Ck5a 2iOEYyjQcF616k6CRcMtQcxd28PdeyIk/9AzaRFsNgqbk2QYC5UZ5C3DZlsyOdTZCQb3 L754J7Gy73YG/OWRoLfLuLvVsv3mjS2jBqsKXlSBgT8LQNXflwduHLXkEGkyckzLKKP3 3qg2KZ4rpkjLPKlGpeX/RrvLa7YySjZCumfoMc/8vMU/62QuCzjonL1lpBZAAzFOqDft U/KQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=kiuEluO3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cb17si8645885edb.276.2021.07.15.14.08.14; Thu, 15 Jul 2021 14:08:37 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=kiuEluO3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243810AbhGOTSV (ORCPT + 99 others); Thu, 15 Jul 2021 15:18:21 -0400 Received: from mail.kernel.org ([198.145.29.99]:38802 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240660AbhGOTCz (ORCPT ); Thu, 15 Jul 2021 15:02:55 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 52D62613CF; Thu, 15 Jul 2021 18:59:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626375543; bh=KSZ7rKJwOjkrmzpOVQugWhLbgtTy/OWflm3K4vutGBM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=kiuEluO31vpQLGXBNnTBrSbNH+6wGmMP1RF/4yfiPeBojmOx1DmrjtigcT2hlsP1W 1fM3yMLX4GV6nEX3HmyJIHu46EVA+ZDp8Kv0EsqqFDkjQERBa16aFBb5zYZEX1pwVz /6XbnJnsdOKl1n2XaoIZiNoeSWjO/JYOSVbaivOY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lorenz Bauer , Martynas Pumputis , Eric Dumazet , "David S. Miller" , Sasha Levin Subject: [PATCH 5.12 132/242] net: retrieve netns cookie via getsocketopt Date: Thu, 15 Jul 2021 20:38:14 +0200 Message-Id: <20210715182616.262612399@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210715182551.731989182@linuxfoundation.org> References: <20210715182551.731989182@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Martynas Pumputis [ Upstream commit e8b9eab99232c4e62ada9d7976c80fd5e8118289 ] It's getting more common to run nested container environments for testing cloud software. One of such examples is Kind [1] which runs a Kubernetes cluster in Docker containers on a single host. Each container acts as a Kubernetes node, and thus can run any Pod (aka container) inside the former. This approach simplifies testing a lot, as it eliminates complicated VM setups. Unfortunately, such a setup breaks some functionality when cgroupv2 BPF programs are used for load-balancing. The load-balancer BPF program needs to detect whether a request originates from the host netns or a container netns in order to allow some access, e.g. to a service via a loopback IP address. Typically, the programs detect this by comparing netns cookies with the one of the init ns via a call to bpf_get_netns_cookie(NULL). However, in nested environments the latter cannot be used given the Kubernetes node's netns is outside the init ns. To fix this, we need to pass the Kubernetes node netns cookie to the program in a different way: by extending getsockopt() with a SO_NETNS_COOKIE option, the orchestrator which runs in the Kubernetes node netns can retrieve the cookie and pass it to the program instead. Thus, this is following up on Eric's commit 3d368ab87cf6 ("net: initialize net->net_cookie at netns setup") to allow retrieval via SO_NETNS_COOKIE. This is also in line in how we retrieve socket cookie via SO_COOKIE. [1] https://kind.sigs.k8s.io/ Signed-off-by: Lorenz Bauer Signed-off-by: Martynas Pumputis Cc: Eric Dumazet Reviewed-by: Eric Dumazet Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- arch/alpha/include/uapi/asm/socket.h | 2 ++ arch/mips/include/uapi/asm/socket.h | 2 ++ arch/parisc/include/uapi/asm/socket.h | 2 ++ arch/sparc/include/uapi/asm/socket.h | 2 ++ include/uapi/asm-generic/socket.h | 2 ++ net/core/sock.c | 7 +++++++ 6 files changed, 17 insertions(+) diff --git a/arch/alpha/include/uapi/asm/socket.h b/arch/alpha/include/uapi/asm/socket.h index 57420356ce4c..6b3daba60987 100644 --- a/arch/alpha/include/uapi/asm/socket.h +++ b/arch/alpha/include/uapi/asm/socket.h @@ -127,6 +127,8 @@ #define SO_PREFER_BUSY_POLL 69 #define SO_BUSY_POLL_BUDGET 70 +#define SO_NETNS_COOKIE 71 + #if !defined(__KERNEL__) #if __BITS_PER_LONG == 64 diff --git a/arch/mips/include/uapi/asm/socket.h b/arch/mips/include/uapi/asm/socket.h index 2d949969313b..cdf404a831b2 100644 --- a/arch/mips/include/uapi/asm/socket.h +++ b/arch/mips/include/uapi/asm/socket.h @@ -138,6 +138,8 @@ #define SO_PREFER_BUSY_POLL 69 #define SO_BUSY_POLL_BUDGET 70 +#define SO_NETNS_COOKIE 71 + #if !defined(__KERNEL__) #if __BITS_PER_LONG == 64 diff --git a/arch/parisc/include/uapi/asm/socket.h b/arch/parisc/include/uapi/asm/socket.h index f60904329bbc..5b5351cdcb33 100644 --- a/arch/parisc/include/uapi/asm/socket.h +++ b/arch/parisc/include/uapi/asm/socket.h @@ -119,6 +119,8 @@ #define SO_PREFER_BUSY_POLL 0x4043 #define SO_BUSY_POLL_BUDGET 0x4044 +#define SO_NETNS_COOKIE 0x4045 + #if !defined(__KERNEL__) #if __BITS_PER_LONG == 64 diff --git a/arch/sparc/include/uapi/asm/socket.h b/arch/sparc/include/uapi/asm/socket.h index 848a22fbac20..92675dc380fa 100644 --- a/arch/sparc/include/uapi/asm/socket.h +++ b/arch/sparc/include/uapi/asm/socket.h @@ -120,6 +120,8 @@ #define SO_PREFER_BUSY_POLL 0x0048 #define SO_BUSY_POLL_BUDGET 0x0049 +#define SO_NETNS_COOKIE 0x0050 + #if !defined(__KERNEL__) diff --git a/include/uapi/asm-generic/socket.h b/include/uapi/asm-generic/socket.h index 4dcd13d097a9..d588c244ec2f 100644 --- a/include/uapi/asm-generic/socket.h +++ b/include/uapi/asm-generic/socket.h @@ -122,6 +122,8 @@ #define SO_PREFER_BUSY_POLL 69 #define SO_BUSY_POLL_BUDGET 70 +#define SO_NETNS_COOKIE 71 + #if !defined(__KERNEL__) #if __BITS_PER_LONG == 64 || (defined(__x86_64__) && defined(__ILP32__)) diff --git a/net/core/sock.c b/net/core/sock.c index a266760cd65e..60750f9ae32d 100644 --- a/net/core/sock.c +++ b/net/core/sock.c @@ -1622,6 +1622,13 @@ int sock_getsockopt(struct socket *sock, int level, int optname, v.val = sk->sk_bound_dev_if; break; + case SO_NETNS_COOKIE: + lv = sizeof(u64); + if (len != lv) + return -EINVAL; + v.val64 = sock_net(sk)->net_cookie; + break; + default: /* We implement the SO_SNDLOWAT etc to not be settable * (1003.1g 7). -- 2.30.2