From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from GVXPR05CU001.outbound.protection.outlook.com (mail-swedencentralazon11023109.outbound.protection.outlook.com [52.101.83.109]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 8757B35F19C; Fri, 13 Mar 2026 11:10:34 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.83.109 ARC-Seal:i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773400236; cv=fail; b=B+MZYpCGS6ijcnKUhVGelpkiThnEHfoafWUY7c8vBUQw83p/vn7BQCoD9F6lWGI3uKAdbsHMwAxYQjf9LuY2iHvsJXc6CRmFyE8MjQUuopuUzL2PJirlIKbfnmh8xonYrJZnXQH4JeJ3dbFTw9TL7YpSNwP1k8x+ODVqgWW08Zg= ARC-Message-Signature:i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1773400236; c=relaxed/simple; bh=vLMvZW+G50kBoSXJguOnf3bgIc6JVPexf348C6e2wkY=; h=From:To:Cc:Subject:Date:Message-ID:Content-Type:MIME-Version; b=CXSsqhyoDDojS+dGq60pGWhE5afXkwMSpn+IabOOpb1LUtOJ2PtNmwMWK8zYfQEMQvy6WKcXpiCYb5l4xJuZoaHMmqmVFNT1of3EEFWxDs3DgmF5kJzTPwl+mEDEpT3QRQcckRazFm07ZziBK6hucmE6DmCxO8dIrNhc7CfB8Pw= ARC-Authentication-Results:i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=virtuozzo.com; spf=pass smtp.mailfrom=virtuozzo.com; dkim=pass (2048-bit key) header.d=virtuozzo.com header.i=@virtuozzo.com header.b=G+akWfwU; arc=fail smtp.client-ip=52.101.83.109 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=virtuozzo.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=virtuozzo.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=virtuozzo.com header.i=@virtuozzo.com header.b="G+akWfwU" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=o33WZSmXfYh5m0m5dJ/9KQ8o/K71lpG/px6gAnPYbpShNPRvkdEx9ojN2hIR/L67vuUmMa8ZWZ7c+CA7T5TQAOlHrq/nT3NdyVZiUkeuj2xOWhydHYmtOFuk0308s0NBWzHlCueZFbHO/sL+hPkNax+xZEyJsJI9tBJKnP0Yh2VePZwdyJjnxWOqbW05hVAVQyz/2TlFUrGzIe/S4Uw0JeGBUvHHAIvxIYVJcCje7MKX+lsnuYBVSanAddHoBQEqZYA2QoMYxOFMS77ySRvG4G9pGFR+FS0cLDHX9OTpz9ElVBHwLBwjd8MEL8II0eA/Gh/1tf0LJSg1YyZkqJKhPw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=QeTBsJPMMzqH60iz3ulNrn36n+PzkM6fQa1jMRnjxus=; b=Jy/UE7vVjwlkSaeZuhimc4XS1QIT+68HP6xsej8GHGW92LYjhWkwxrf7Ez89hdj3SvnzOJOuik4k6lSt7v0yB3nHeBYgLpunfD92/x7xiFdaEjzr1QuAoQDL56PQVaZcmfghuWWJGc6RZCmuFKJOrNwdGkxQfocAFOdRtPIWa7m9NRByF/pr8SGLs+owpiA5mylnTCHCIOj5H7kbfNu4Fl4OMrvml4cqJ+u9+6uXLybttu2y5/mh2XN5JCA1UJBZuALs9bjGsLFRR+HqRi/LPU8hhyKVU8Qpt9g8ePSOtmYBCOnPifNqVwD1QTCKJR6FM92Z5kkUthK2/eRf5e5hWg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=virtuozzo.com; dmarc=pass action=none header.from=virtuozzo.com; dkim=pass header.d=virtuozzo.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=virtuozzo.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=QeTBsJPMMzqH60iz3ulNrn36n+PzkM6fQa1jMRnjxus=; b=G+akWfwUctxJ1kUOMwhepOddFkCcL0JnB3+M0gqV9U2priXcsIjI2h5tb33k4+8Gif3xkqDVbgehVsS6BgsuC4r/0dX7b1tdNZaM9OcBl/AbtiGfw/DFKIiuO4D5b0R3W7uuYrphv0UKnl51egUbAFQZlKqT870pEXINT8GRaOmQXHbGzHW2eg99QUIZNkWz2/bsuoguefi3N6Zvcae3Y5+mhm+hNmpccNi3RZ71EH8B55Zbokv1yQICZE93xaIvOcSBLFknilEOdlgvHHV9K4MsZgL/nOVLCzms0aNZVkH7FnJLcOUVnZD/EZEMNu2QCrvnFib2mdahbdLAknxv0Q== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=virtuozzo.com; Received: from PAWPR08MB9008.eurprd08.prod.outlook.com (2603:10a6:102:341::8) by DB9PR08MB11361.eurprd08.prod.outlook.com (2603:10a6:10:60e::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9700.12; Fri, 13 Mar 2026 11:10:31 +0000 Received: from PAWPR08MB9008.eurprd08.prod.outlook.com ([fe80::e9d0:437c:714c:396a]) by PAWPR08MB9008.eurprd08.prod.outlook.com ([fe80::e9d0:437c:714c:396a%5]) with mapi id 15.20.9700.013; Fri, 13 Mar 2026 11:10:31 +0000 From: Pavel Tikhomirov To: Andrew Morton Cc: Christian Brauner , Shuah Khan , Kees Cook , David Hildenbrand , Ingo Molnar , Peter Zijlstra , Juri Lelli , Vincent Guittot , Jan Kara , Oleg Nesterov , Aleksa Sarai , Andrei Vagin , Kirill Tkhai , Alexander Mikhalitsyn , Adrian Reber , Pavel Tikhomirov , linux-kernel@vger.kernel.org, linux-mm@kvack.org, linux-kselftest@vger.kernel.org Subject: [PATCH v5 0/4] pid_namespace: make init creation more flexible Date: Fri, 13 Mar 2026 12:09:38 +0100 Message-ID: <20260313111014.2068913-1-ptikhomirov@virtuozzo.com> X-Mailer: git-send-email 2.53.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-ClientProxiedBy: FR4P281CA0190.DEUP281.PROD.OUTLOOK.COM (2603:10a6:d10:ca::15) To PAWPR08MB9008.eurprd08.prod.outlook.com (2603:10a6:102:341::8) Precedence: bulk X-Mailing-List: linux-kselftest@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PAWPR08MB9008:EE_|DB9PR08MB11361:EE_ X-MS-Office365-Filtering-Correlation-Id: e5343c3a-1e45-4291-34c7-08de80f123c2 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|52116014|7416014|376014|1800799024|10070799003|18002099003|56012099003; X-Microsoft-Antispam-Message-Info: ysqCcnhsP863pQ+wC5j3+zeW72qjzdzbVWDupTRzAmfT49BcYgyS3BFC0c7iQMCYV4v0e4zxd3clBYgwlQviE8tDpx9GVYW9AuaFZFnP4jI4DAuUH4R0XHK0wgpasTvotlLGATPMdybSHoePu9I359wY1gIyTalS72OtErCeHgWElZJNiXtqGE7Mp+g6VDGxZs+4EGx0X7jeuxwBs+CUaqu2tk1YLGsRl8GUsIuc4kfkDUpOsYm3CNPcnODtFmwjKaFD1cnOj60dQmSfaq8I+sbtVzHQGr80G8ja5K1zb/A/S5EdpeS7jFaIJYQw2JIAy51T/l0t8N7S8hTSr7u4wgdqOfm6XxExNbkmmQSd1PDOiqLUC8e7hR+VHi5ZteeJ8loOJcnJn98x97hy6ZIezDMuwPFl2ZDV405q+epFW+pqK2dxMJCo2pI8n1A0aU9L5kRRQlee93868bLr0+wtSW6OzUyHu46KvMpOAdlbNRVwajtiuj9nA95dX56n9vqImmsMasVpNlW3/mr14H/hHYVCpjreHGOvDYOZ045/h6PidjvwNUPrmJ9oSKzNYWYrk3QI9wOrUz4L8uKsJ5wbL8QDREnrmzp7+JYZK8UAszt96Frt2Cy2bLwjwUvOao3XZ+BKaB9GsX+yC5kD+fi5wWxb6f10J7t7xuLsOsND/l1Pwjc+iIDrrzGmRfAbHFGf X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PAWPR08MB9008.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(366016)(52116014)(7416014)(376014)(1800799024)(10070799003)(18002099003)(56012099003);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 2 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?Z2Z2dnY0b1FHbGZKWHhpTUxoZGtUdUgyOW5oUUhaYitITUxveDJOVms5Rmo1?= =?utf-8?B?Y1RiUE5MNFpCeVJFUkRvK2RUUGx1dE9UWmZXT0ZSVFEzWGRFb3dKRDd2QWVK?= =?utf-8?B?RStOUVQrTHlRa1RiSDNLMUtIMHJGUGZBVVZNZXNZSHlGVmg5cnFoaFVHSExR?= =?utf-8?B?WHYyOE1WWkF0SzFnMUtVTHhPTDBXczIwYm1YblYrNjZlYnBrS0k1MzVKRnpR?= =?utf-8?B?b014VGdLQjI3RGgxbkhuSUVVRjNvb0R1cHNvTU5ja1QvcTNxRWlyWDdjRjRU?= =?utf-8?B?WmlDd2FEYUh0aE1IU0gwclZJU2oyeWJaWEtRUDZDWnIzWnZtVS8wQzU0SUdH?= =?utf-8?B?Z2QyM3drYUVwNnNVSnlvbzdScWlETThJUVJjNzhwUlBhNTh5QndzYjE4NGFi?= =?utf-8?B?dDJlcUl1ZEQ4WVAwYkc4WTVFckFUSmNHVFRiZktDVHJYbzNIbndVQU1IQ2xl?= =?utf-8?B?VlhZc2ZnOHkwcGI3YnRGOWRDK09YcFFHWmhDcXZOOWk1WTVETEY2a3FTcHFR?= =?utf-8?B?ZmtHNTgxaDZ6TjV3Q3lMdWxhMWVKTnBFcFV4SU41TWM5bWhnc0xvdmU3U0RR?= =?utf-8?B?RkxKSTdna3o4c1hOcm5US1J0YmZ5bGhFZHFyZzFSQksxZ2k1aUtSZFYxSHJF?= =?utf-8?B?V2syRzFCcEg1aU5IMFRTWUJBeExKVVUxMmpVcGplSzdSTlFlT0dyNUk2SXFF?= =?utf-8?B?b2d5aC84Mzc3N0xnK1JxeU5nSXJibmJQdFVNRGdYK1RWNFUwNXhvTXdkRzMr?= =?utf-8?B?ajNpWldVS01pVVMyZFlWYWUydFpLcnl1TWc4aWJNQUV1dG1VN3l5ODBocmM3?= =?utf-8?B?bG1iY3IydmZBMHN5aFhyeUdyTGFSUFh5M2wrcytQcEh0UHRpZVVBcXZ0VUFh?= =?utf-8?B?WVQ1eDBwVjFpZlRpUC9UTEhrL0RINkxLZXNmRGJnYWE3R2JDdVJhQ0x1ZTJV?= =?utf-8?B?NEhyVUR1b1BIR2ZTOHFsUXozU0JneTluSStxRDFBaDJrWFFTQVB2UzR1TFJ0?= =?utf-8?B?em9aeVRZTm9kTTNRaDNhQ3JYT1FRQTN5OWpmRmJVRk14OSs4ZkIwWFBwYjNN?= =?utf-8?B?OE5WVUswRzZ1ekRWaHFacU85UFBwSkZBWTRlMnZrNzhaL2p6ZDJRK2hBZDUx?= =?utf-8?B?YmFMZzZxZjlWalhyK2NWaDFjc1pmY1VUMlpWamUwREo4ekhrT3UxRGE5cWpq?= =?utf-8?B?UkQ1ZFlTMjlmUTlFS1pER3FtUEo1WEFEa2UvSVFmY1BBTlo2bEt0QlRCY3Bw?= =?utf-8?B?K3J1b2t6OTZjUHRwTnlxbVNXSEx1VkNUUGtwRHhoZytWTWlRRkl2S1lhYjhh?= =?utf-8?B?eHpPTm41b042c1FRQk9pYWN3ZjF4VGtlRlV2a1VKc21lOWRCTzk2ZDV6R0RB?= =?utf-8?B?dHZLd0pVK3RaLy9MMnh3WHNjWkszOGk2M1dXM1hxdEVRQXZoTzJYYlV4WFNI?= =?utf-8?B?L1BuS0FGaGxxZTl1OVJCQW5DM2toSkJnVks2d2xObXRkbEJBTDRzZk14YlpB?= =?utf-8?B?bWZ0aTIxUWVPenk2ay9hK2RZRGNoM0tQd3ZHSjJpZ2RjdjJQNW9YSnZqSlZx?= =?utf-8?B?SGZNUGp2dXFiM2ZwandQaTROc2VrOHFjT0hFR1pQb01TNDVxQjUreTRwbmZQ?= =?utf-8?B?c2xpMlVMWXpPK3lhRkhVVWtrcmcvRVhRSWEyRzJHcHhpeWt0TnN0bEVaaTNV?= =?utf-8?B?V1NxdUNSWTQ2WVpNaWFBa2ZQaVVwbURtRmdqN1dHMStyUWlKUFNveWFiSHdJ?= =?utf-8?B?ckViMEZkRmgwQWp1RHlUaU5ONFFpVjVEZ08ycmI2NUI3NmJ0bDgxYmc0Q1dR?= =?utf-8?B?dm9keCtQVkluRTB0VEZqNC9MTTFuU2dCbGF0MTI0RzAwZ2JsMWpUdzBhOGNn?= =?utf-8?B?czZsM1F2UWRRYzUwTkRSY0dIUVVpVVpuK0R4RDgrcUdxZnhqb3hUaWltNVM2?= =?utf-8?B?VHE2SGkzZTVjNkNwQ09qTjJYM0NmRG5qeU0vdHFCbnhwVmxKbnRnczNWTU5N?= =?utf-8?B?eXg3akhuZW0rTVdrTCtVRkJWTllqREJiNUp3YWVHOFZraVVORUFwNGxnMDJT?= =?utf-8?B?NHFyV3dscDRWSThhL2k1dWJWZml5VElxWHVTRHhVbXRkWHVzbHFjMitqK2w1?= =?utf-8?B?c2ZZZyt3dHRjVENqdTN3bGFMT0kyZzNPVDUvd08zb2M2VFFuR1p6SXhCdkcv?= =?utf-8?B?cE9adWtuZEdibW1Kcjg5amdlWkhTSTBJbEVMWEtSWlhoNHVlSjI5UC9ZK2hY?= =?utf-8?B?RUhCdGI1Mi8zZjlXd2p0M2FvZTBuQkhiSy9oOG9KWXZDUUhrZGd6cFNrd3NR?= =?utf-8?B?TTRhazRPY1NweGJrVzVOV0ppZHIwT3ZyMjhlMWE2SjJGTGtpK1l1cUxWZmJh?= =?utf-8?Q?aXvH8F0uDcIFRnkFKxOoItyeiY6TlUnc222dUh7G/GaEL?= X-MS-Exchange-AntiSpam-MessageData-1: DM01IBMDruPpYpw/EhVINTEAtOgS63nqZ2M= X-OriginatorOrg: virtuozzo.com X-MS-Exchange-CrossTenant-Network-Message-Id: e5343c3a-1e45-4291-34c7-08de80f123c2 X-MS-Exchange-CrossTenant-AuthSource: PAWPR08MB9008.eurprd08.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 13 Mar 2026 11:10:31.0310 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 0bc7f26d-0264-416e-a6fc-8352af79c58f X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 6DU9OXGA5GCxUfR45Ro7nTNxaDEvpFNTMGb2sU/17jSEiJVdJfNvnPJf0ot+V2zq04np7Pxcqoxuo3kyeiRsEnQVNpGLUxZeBk6TPVr05ls= X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB9PR08MB11361 The first patch properly annotates accesses to ->child_reaper with _ONCE macroses, to protect unlocked accesses from possible cpu/compiler optimization problems. The second patch makes sure that the init is always a first process in the pid namespace, previously this was only checked for set_tid case. The third patch allows to join pid namespace before pid namespace init is created, that allows to create pid namespace by one process and then create pid namespace init from another process after setns(). Please see the detailed description in the patch commit message. It depends on the second patch. The forth and the final patch is a comprehansive test, that tests both basic usecase of creating pid namespace and init separately, and a more specific usecase which shows how we can improve clone3(set_tid) usability after this change. This change is generally useful as it makes clone3(set_tid) more universal, and let's it work in all the cases evenly. Also it is highly useful to CRIU to handle nested containers. v2: Use *_ONCE for ->child_reaper accesses atomicity, and avoid taking task_list lock for reading it. Rebase to master. v3: Separate *_ONCE change and "init is first" checks into separate commits. v4: Update second patch commit message. Include Oleg's review tags. v5: Handle one more READ_ONCE case. Include Andrei's review tags. Base on top of mm tree. This series is also available here: https://github.com/Snorch/linux/commits/allow-creating-pid-namespace-init-after-setns-v5-mm-tree/ Signed-off-by: Pavel Tikhomirov Pavel Tikhomirov (4): pid_namespace: avoid optimization of accesses to ->child_reaper pid: check init is created first after idr alloc pid_namespace: allow opening pid_for_children before init was created selftests: Add tests for creating pidns init via setns kernel/exit.c | 3 +- kernel/fork.c | 5 +- kernel/pid.c | 19 +- kernel/pid_namespace.c | 9 - .../selftests/pid_namespace/.gitignore | 1 + .../testing/selftests/pid_namespace/Makefile | 2 +- .../pid_namespace/pidns_init_via_setns.c | 238 ++++++++++++++++++ 7 files changed, 257 insertions(+), 20 deletions(-) create mode 100644 tools/testing/selftests/pid_namespace/pidns_init_via_setns.c base-commit: d1b4433308592363d133a788f0443d5d63872bdd -- 2.53.0