Received: by 2002:a05:7412:f690:b0:e2:908c:2ebd with SMTP id ej16csp889795rdb; Fri, 20 Oct 2023 02:22:29 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGMgW1l0URZL1UsyjJBRoqSbsZoAQE98kxUjak003JupXVztwdOwDp+3cG7eQrappncn/An X-Received: by 2002:a05:6808:20a1:b0:3af:b2bd:daba with SMTP id s33-20020a05680820a100b003afb2bddabamr1164266oiw.56.1697793748744; Fri, 20 Oct 2023 02:22:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1697793748; cv=none; d=google.com; s=arc-20160816; b=HdPhahRWWv3wbzLwyHP7PpilZomNjdH0NEOOjaSHN9idn9fn2J09hIQCNmu9up+wb1 tEBUaD+smP7vTHFQMaw+iD9zTY2eXL5lxfDnTRyukLegihDuodWtfY7IZ9YQnSbtpg3g 6FTh6DgsAJI2bgXaTf3+OpHDEYN3VIG7Y7XstcqnRIOOFNbvxzLnzryhj2GVa+B1WwBp 7eESkjy8yqN8oHvJNZKB7n6BW5q6OAx/F/t7ntq9U5YTrAmCkddCebzML0HKFAidEmVQ WeX0mSXeY5XgCmvWh0wlpvo915OLQZWReQJ0DgEUP7aPeiwvOTDYWK6BdwmPnXfhn5CO MxCA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=AjAaEm8fLfRX59M1csWR9X+KddyfgljM0xGHDo28f78=; fh=xT0fk5oP7GynPGhPPBTvnZU2JufV+z3QxPf9rqHlfVI=; b=OPsnKpDzdLcXjxzYubtbH+MJwBZy5S5FZzzKoq4/dc7kXzs7NDrh247Un7gx3C/oAt oYTV6BwW1kfTc2a5Xmhmfl7tefEvAWgJ9oFq1eHXD5ep+X98+33LVJXdgHhS06vWby3V ygbCwtWkOEIwa4hbzFw26Fud+VGbjNJJ6XY/Am+N9xIeOadxNaye27/Vzcmj39prAguR wgFU9UtshSthW86dW11PjnrPbFEG/YDkEi47N3IH5aAKuxR3QnwfdrOiy6kpkX6QqH1o UWv9zpuqfKHLkYsCAuqI+8Ny3iQY4N6MTN1/ppRWPU27Ns2ZMOFB6GGL3jT3n8FhoiC/ R7YQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=nCLyKBFK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from morse.vger.email (morse.vger.email. [2620:137:e000::3:1]) by mx.google.com with ESMTPS id 132-20020a63008a000000b005646d7e5351si1391416pga.430.2023.10.20.02.22.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 20 Oct 2023 02:22:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) client-ip=2620:137:e000::3:1; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=nCLyKBFK; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by morse.vger.email (Postfix) with ESMTP id 2EA5180FE955; Fri, 20 Oct 2023 02:22:26 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1376757AbjJTJWU (ORCPT + 99 others); Fri, 20 Oct 2023 05:22:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46476 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1376678AbjJTJV6 (ORCPT ); Fri, 20 Oct 2023 05:21:58 -0400 Received: from mgamail.intel.com (mgamail.intel.com [192.55.52.136]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8E8F71728 for ; Fri, 20 Oct 2023 02:21:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1697793679; x=1729329679; h=date:from:to:cc:subject:message-id:references: mime-version:in-reply-to; bh=a++LVpgYV0t0DpSZeHCFw0R4XO+/PCphuhcdSRisZ/4=; b=nCLyKBFKlPQhiWGIUpI0FoBljO9qjq6VEjzfQsU9ygEW4A36QyuI1Qh9 TKobgB1g8xd2vGoQcffqZw/TPapxS2ny+fiZt9Q2L5iWQFypCKfXATvv1 jjMdylG8qywOLlXgn3EDHYEf9t59rN8JPplIylKbl2hYw7G6bcyUmVYjV 4qBeRwz/TH34A5Eo1ZDKQ8BuVZpY8WFfxVqC4WQE/BZUPnaUwQ2pKE2B7 j44cU0LzSQoIPt4CCg1oz15TMPRkYHYevNnHvFW9FX/lQc/pJDoi43fdW mfeVbGc0Kg3g1K8O/CjOj3TpLEjn+EAXEv9HEkFpf2Wao9ikIcsQQlEgg A==; X-IronPort-AV: E=McAfee;i="6600,9927,10868"; a="365802084" X-IronPort-AV: E=Sophos;i="6.03,238,1694761200"; d="scan'208";a="365802084" Received: from fmsmga007.fm.intel.com ([10.253.24.52]) by fmsmga106.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 Oct 2023 02:21:17 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10868"; a="760990089" X-IronPort-AV: E=Sophos;i="6.03,238,1694761200"; d="scan'208";a="760990089" Received: from blavena-mobl2.ger.corp.intel.com (HELO box.shutemov.name) ([10.249.39.237]) by fmsmga007-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 Oct 2023 02:21:13 -0700 Received: by box.shutemov.name (Postfix, from userid 1000) id 2344E109D0A; Fri, 20 Oct 2023 12:21:11 +0300 (+03) Date: Fri, 20 Oct 2023 12:21:11 +0300 From: "Kirill A. Shutemov" To: "Kalra, Ashish" Cc: Thomas Gleixner , Ingo Molnar , Borislav Petkov , Dave Hansen , x86@kernel.org, "Rafael J. Wysocki" , Peter Zijlstra , Adrian Hunter , Kuppuswamy Sathyanarayanan , Elena Reshetova , Jun Nakajima , Rick Edgecombe , Tom Lendacky , kexec@lists.infradead.org, linux-coco@lists.linux.dev, linux-kernel@vger.kernel.org Subject: Re: [PATCH 10/13] x86/tdx: Convert shared memory back to private on kexec Message-ID: <20231020092111.ho2rmhve23kgcxbr@box> References: <20231005131402.14611-1-kirill.shutemov@linux.intel.com> <20231005131402.14611-11-kirill.shutemov@linux.intel.com> <8d0e4e71-0614-618a-0f84-55eeb6d27a6d@amd.com> <20231005212828.veeekxqc7rwvrbig@box> <20231005222839.jt2du72xogg3c5ny@box> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-0.8 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on morse.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (morse.vger.email [0.0.0.0]); Fri, 20 Oct 2023 02:22:26 -0700 (PDT) On Fri, Oct 06, 2023 at 02:24:11PM -0500, Kalra, Ashish wrote: > > On 10/5/2023 5:28 PM, Kirill A. Shutemov wrote: > > On Thu, Oct 05, 2023 at 05:01:23PM -0500, Kalra, Ashish wrote: > > > On 10/5/2023 4:28 PM, Kirill A. Shutemov wrote: > > > > On Thu, Oct 05, 2023 at 01:41:38PM -0500, Kalra, Ashish wrote: > > > > > > +static void unshare_all_memory(bool unmap) > > > > > > +{ > > > > > > + unsigned long addr, end; > > > > > > + long found = 0, shared; > > > > > > + > > > > > > + /* > > > > > > + * Walk direct mapping and convert all shared memory back to private, > > > > > > + */ > > > > > > + > > > > > > + addr = PAGE_OFFSET; > > > > > > + end = PAGE_OFFSET + get_max_mapped(); > > > > > > + > > > > > > + while (addr < end) { > > > > > > + unsigned long size; > > > > > > + unsigned int level; > > > > > > + pte_t *pte; > > > > > > + > > > > > > + pte = lookup_address(addr, &level); > > > > > > > > > > IIRC, you were earlier walking the direct mapping using > > > > > walk_page_range_novma(), any particular reason to use lookup_address() > > > > > instead ? > > > > > > > > walk_page_range_novma() wants mmap lock to be taken, but it is tricky as > > > > we run here from atomic context in case of crash. > > > > > > > > I considered using trylock to bypass the limitation, but it is a hack. > > > > > > > > > > > > > > > + size = page_level_size(level); > > > > > > + > > > > > > + if (pte && pte_decrypted(*pte)) { > > > > > > > > > > Additionally need to add check for pte_none() here to handle physical memory > > > > > holes in direct mapping. > > > > > > > > lookup_address() returns NULL for none entries. > > > > > > > > > > Looking at lookup_address_in_pgd(), at pte level it is simply returning > > > pte_offset_kernel() and there does not seem to be a check for returning NULL > > > if pte_none() ? > > > > Hm. You are right. > > > > I think it yet another quirk in how lookup_address() implemented. We need > > to make it straight too. > > > > There's two options: either make lookup_address() return pointer for entry > > even if it is NULL, or add check for pte_none() after pte_offset_kernel() > > and return NULL if it is true. > > > > I like the first option more as it allows caller to populate the entry if > > it wants. > > Yes, i like the first option. I tried to this, but lookup_address() has to many callers. It gets beyond the scope of the patchset. I will add pte_none() check on unshare side for now. -- Kiryl Shutsemau / Kirill A. Shutemov