Received: by 2002:a05:7412:798b:b0:fc:a2b0:25d7 with SMTP id fb11csp559452rdb; Thu, 22 Feb 2024 11:57:06 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCWMQi7IKGh/sR/ocqVRl1l5F/fmcgydUDEoRKyTVpFkBIL/5xieK73dVtFcioTNLiL5gNEsPkk7+rRx9CX5SVVlsDvRLS8xyAUtW/w86Q== X-Google-Smtp-Source: AGHT+IGmCmGTgCYyRxNpjsOKtiN6hq1V5jgJ19gvYRdxUhdv1LhA7nXd44z7fjyLbEmszxDPf1Li X-Received: by 2002:a05:6358:731c:b0:17b:5d25:76a5 with SMTP id d28-20020a056358731c00b0017b5d2576a5mr6766760rwg.3.1708631826189; Thu, 22 Feb 2024 11:57:06 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1708631826; cv=pass; d=google.com; s=arc-20160816; b=ykU4LPT8r2BuUN9lsLt0s2bT7ocOwtK308rYbdQkxJj7KPtUqVAbJ/A6D6L2/DA/jh 4vMv3gUVSFoiOFEgBhea2YHgxfPZnh3owlCFqwiKatIARTLtTyecCJfe0ln1pp+/sr9k aGgcR01VzGUWSQTzSGDMmCPtuvpldYEFEMuWFncAotZWaMNkypv4uFfy7FkEMzIQZnyM UCMPUZ8UaiP69gA/RuNoC1n0wO6gbwqbePU+YJYehs/EhIpQ8A92qYPrXdmd8bZ8JBVA HSOrLk/CH9Jjm7r0hr1YNPnWon8KOmbzqo/ZeP8qiZXKLjBPZVPvDP3tq/JNQ6DboIR/ Oleg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=cc:to:from:subject:message-id:references:mime-version :list-unsubscribe:list-subscribe:list-id:precedence:in-reply-to:date :dkim-signature; bh=vtwP2XS9ou6pEJ1RLzQIqe0uI1z5AHU3SBLD09pMwP4=; fh=ewvLYPHgpgFh7QpkN9S5db8Bp8dqgsLhG1kTmxNaSdA=; b=UZVt+ONpIUvHO5P3p73spBiXvsrEzDSWTfmp05E6UNSmEekqEZTSsf/R4PRmMVonlF 0VOacbNodbhNzhDSAuz56PRw4hpXtnXIbcE0nxwoZXQeeLoyzB6i/9qQDl8nK6+tGuW+ J4zU8bJY6Caq5NHk3+DF50nF3z5la55mkttHlqeFpFTL47eKLrUtMbWAlNY2VcY6Xy8O y8XFcJXCENIrcuLcidBnd5hKlSb0hOk6FumYI+PKTqMdxGF2BKhe2an3kjvt9/Gj8P1h K5YBOuXRq2DmZNSzwbt28P9M8SeseJub13BbVUxPMyjr94DmPBqWUzbrpsq7SjQF+Tuh 9uRw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=SPxMkg3Z; arc=pass (i=1 spf=pass spfdomain=flex--yosryahmed.bounces.google.com dkim=pass dkdomain=google.com dmarc=pass fromdomain=google.com); spf=pass (google.com: domain of linux-kernel+bounces-77194-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-77194-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id k5-20020a632405000000b005dc957fe10bsi10690311pgk.701.2024.02.22.11.57.05 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 22 Feb 2024 11:57:06 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-77194-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=SPxMkg3Z; arc=pass (i=1 spf=pass spfdomain=flex--yosryahmed.bounces.google.com dkim=pass dkdomain=google.com dmarc=pass fromdomain=google.com); spf=pass (google.com: domain of linux-kernel+bounces-77194-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-77194-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 1F38DB29C3A for ; Thu, 22 Feb 2024 18:53:39 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 55883548E5; Thu, 22 Feb 2024 18:43:35 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b="SPxMkg3Z" Received: from mail-yb1-f202.google.com (mail-yb1-f202.google.com [209.85.219.202]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 0ABB814B817 for ; Thu, 22 Feb 2024 18:43:32 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.219.202 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708627414; cv=none; b=ke+jZYTcUU6VrAi1KVTgNqe+nFDlL3LxCSaiqjgugiqp7kmj1FJO1WA+o0ZSvKo0KsKGM3c3tk4rjRaNcFyTG9lVoO3aBFQ6ls6LSN2O76plGUaJ6DmzWwXvF5mLq3G2WhZ4hVvuQasA/hOIoRwPhbPdLE5nZ2k5CIbH33zGc4M= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708627414; c=relaxed/simple; bh=8NLzBUI9VMl4Y6yjlgAyBN2B5MIctTr3P4tBWjtWL8E=; h=Date:In-Reply-To:Mime-Version:References:Message-ID:Subject:From: To:Cc:Content-Type; b=ON5mGw7kWzI9/msFOlOO5z/edMDciKLnO6CCGS7eB0Q+JruGAdaVa1uhShyH9/97tUcXq+yYV0SPQbRJKYArHOanok9xPeB7AnzCXoWD69dCp3q/aFdizednAheVMi60rITjgWcGjbYN3S8gEugPIMP+N0hYrBuC2KffVbhCuIs= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com; spf=pass smtp.mailfrom=flex--yosryahmed.bounces.google.com; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b=SPxMkg3Z; arc=none smtp.client-ip=209.85.219.202 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=flex--yosryahmed.bounces.google.com Received: by mail-yb1-f202.google.com with SMTP id 3f1490d57ef6-dcc05887ee9so1439276.1 for ; Thu, 22 Feb 2024 10:43:32 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1708627412; x=1709232212; darn=vger.kernel.org; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:from:to:cc:subject:date:message-id:reply-to; bh=vtwP2XS9ou6pEJ1RLzQIqe0uI1z5AHU3SBLD09pMwP4=; b=SPxMkg3ZoRu6qf/ymMZFaetJEW9dHNeMKbOs3wPiz3VcPCBdaaptQkiyrmR54E2iin qJcKlHp8bbRbV54cs5boido6xR59E6gYiVZJ5sNkffJiAgPNfvWqX/uojtAoZwMfhvU6 MoauX0DRcutXG6Js4GXhcVsvbrttXICAtS4LGlrir3/eKGHz4gm8sfeoVZZGYGTzI6Vm A5/xvaTEV5GB0uEmjL7D6v0L2az3cR7tAZzy9z0hGtbcK77dEdYORHnqzFTM9bqVbG0/ ENBVZDMTfkfZLO9kPrezglCfgQwojY0lvVbNx/hw2BayV38rd2A0oJAqwKlCtb+yjM3u YPqw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1708627412; x=1709232212; h=cc:to:from:subject:message-id:references:mime-version:in-reply-to :date:x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=vtwP2XS9ou6pEJ1RLzQIqe0uI1z5AHU3SBLD09pMwP4=; b=pU97jzxiSisOlBiKf+6nqqNLTRXaZcb4fFJdkEAIj/ymcDfE6YmkKlUvINDC7VJTNS duWO0jdaOLQe4aPDvmie90VTZFvx+Y1f61MmLsgVNhzFbYX9s6d7YZvJ4Tgz8CjRaq4x cjgcJ1slTTAUBPJBz9Jk52ayeaoJYLLZJ/Lg4er1YRyxt339SryC9caIO74tRP8ATKp3 6M0noXKhAIhFEZXEMqsQ3b5E5w1j3Kv5GZyAbroXIhFBgst/ppzFVgs0POTqnIQRFQOm BrpcVteiCg6RnAFTvVbXkK1aSJ7yhTtPzNYhzBQpZrvgg1yCFrZT8Qk/FeAu6b2CQfoD PH0Q== X-Forwarded-Encrypted: i=1; AJvYcCXtUdAwQcxhRKKPujbx91qrXAn+qDeiA49G8LA0AEHPhFBtnaBDxY/G7R0xAeCi3GFgFn1eR597Wgiy3hwcWvbmsH23xOtYCvdkSk9w X-Gm-Message-State: AOJu0Yy4F7E4BwnaQ4+Ob34zIKWFUyK+WoHJJ6XSaPYhVnrdsS9Nvteb op5bRBswBxUMXxbj89x0A9pdBLZNPnvtW1xacnOfOyVqZEq1HyhgLJkmvjPhQlMz0yZGRsuojs7 7FVsMKtrhwxZm8hr2Hg== X-Received: from yosry.c.googlers.com ([fda3:e722:ac3:cc00:20:ed76:c0a8:29b4]) (user=yosryahmed job=sendgmr) by 2002:a05:6902:1245:b0:dbe:30cd:8fcb with SMTP id t5-20020a056902124500b00dbe30cd8fcbmr219ybu.0.1708627411906; Thu, 22 Feb 2024 10:43:31 -0800 (PST) Date: Thu, 22 Feb 2024 18:43:30 +0000 In-Reply-To: <88cb9996-0e9b-49ec-bc94-f816a5b64870@intel.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: Mime-Version: 1.0 References: <20240126080644.1714297-1-yosryahmed@google.com> <20240126080644.1714297-2-yosryahmed@google.com> <88cb9996-0e9b-49ec-bc94-f816a5b64870@intel.com> Message-ID: Subject: Re: [PATCH 2/2] x86/mm: clarify "prev" usage in switch_mm_irqs_off() From: Yosry Ahmed To: Dave Hansen Cc: Ingo Molnar , Thomas Gleixner , Borislav Petkov , Dave Hansen , Andy Lutomirski , Peter Zijlstra , Andrew Morton , x86@kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org Content-Type: text/plain; charset="us-ascii" On Thu, Feb 22, 2024 at 08:48:17AM -0800, Dave Hansen wrote: > On 1/26/24 00:06, Yosry Ahmed wrote: > > +/* > > + * The "prev" argument passed by the caller does not always match CR3. For > > + * example, the scheduler passes in active_mm when switching from lazy TLB mode > > + * to normal mode, but switch_mm_irqs_off() can be called from x86 code without > > + * updating active_mm. Use cpu_tlbstate.loaded_mm instead. > > + */ > > +void switch_mm_irqs_off(struct mm_struct *unused, struct mm_struct *next, > > struct task_struct *tsk) > > One nit here: It's not obvious that "unused" is 'the "prev" argument'. > > Would something like this be more clear? > > /* > * This optimizes when not actually switching mm's. Some architectures > * use the 'unused' argument for this optimization, but x86 must use > * 'cpu_tlbstate.loaded_mm' instead because it does not always keep > * ->active_mm up to date. > */ Yes, this is more clear, thanks! However, Andrew already merged that patch into mm-stable, so it cannot be amended. I can send a separate patch to rewrite the comment tho if you'd like, WDYT? > > Also, I think it might be useful to have the rule that arch/x86 code > _always_ calls switch_mm_irqs_off() with the first argument (the > newly-named 'unused') set to NULL. I think there's only one site: Agreed. I can also send a separate patch for this. Thanks! > > > void switch_mm(struct mm_struct *prev, struct mm_struct *next, > > struct task_struct *tsk) > > { > > unsigned long flags; > > > > local_irq_save(flags); > > switch_mm_irqs_off(prev, next, tsk); > > local_irq_restore(flags); > > } >