Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp208143pxb; Mon, 16 Aug 2021 03:45:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw+Ob99xnFwMHO+D2OBUwsJy6SONORfONAR/659Z5Gf1BdfG4wBdy/4gWescC0Z3i0rF9As X-Received: by 2002:a05:6402:1d1c:: with SMTP id dg28mr17604596edb.234.1629110749079; Mon, 16 Aug 2021 03:45:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629110749; cv=none; d=google.com; s=arc-20160816; b=nqWy+wrDhWZxoCG7uX2USICmKuD8LARPMYbvG7A95UuNlstLLTdP6u0CrVKp6QHpIK NyvrxiZcpNwU93KRk+SakLe8spKmM/YYwQDzyyuhjDHhb8FW3Pclbsl/PtkrbMzcbBbc /XiUsxdOAMeRwb7Af+4Ilrg8yFsUuh/tyWliGPiKjv9UxUaAEyiuYAOPE4BYRl/4Vg21 F8933z6kDd+93moy/vOhc8Y/cQIEVRdhLBg6pPmhdlenjgZJsYncduJtGIEG9axjN+dT HxG/6BnItCIBJqGyqGo5J9EzKmKL80fh5kf3WLdhLT8gNnFAE7qBgdnFI2oRJtzcouUe cYJw== 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=KJr3PLH9kdh7sq6ftHE42Mk4Hk9JcVNuZWU5FfzNhng=; b=S+J5OJRPhccDGm+aDEPjS4XCW/2HDc3q/kwmHHzORt6+p0Ocyf3eY1K9gsBmL5NJOD iY5CuH+ePG4PM8J6F2hJHxXrRyCuJMdzPcG+Q/VtAU7p9ipqXAcZiHFKT1dScM/yHBev 9aHWsbT1YUiZPfYgNRncJ6u1EqHW1Pb89anUKksJ3Xg5xH7Tiec0bLRbebO4wpN4E3Cf lLplDKetidQikQREHmEOJTmd4xlBfmvud0LOgeMeO6Pl728jriljpbD/CTLCkPj9PqjM mNaWqOE8sFRg5w8vPkilWTJUXhHXK0nKgcVU9LVZmcsZ15t36iSDPn7Eq0nadwXy44Tm av6Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@alien8.de header.s=dkim header.b=EdTJv86x; 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=alien8.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id gc22si3086105ejc.181.2021.08.16.03.45.25; Mon, 16 Aug 2021 03:45:49 -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=@alien8.de header.s=dkim header.b=EdTJv86x; 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=alien8.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235774AbhHPKnh (ORCPT + 99 others); Mon, 16 Aug 2021 06:43:37 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40172 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230250AbhHPKng (ORCPT ); Mon, 16 Aug 2021 06:43:36 -0400 Received: from mail.skyhub.de (mail.skyhub.de [IPv6:2a01:4f8:190:11c2::b:1457]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 81757C061764; Mon, 16 Aug 2021 03:43:05 -0700 (PDT) Received: from zn.tnic (p200300ec2f08b5004455011f3e43b910.dip0.t-ipconnect.de [IPv6:2003:ec:2f08:b500:4455:11f:3e43:b910]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.skyhub.de (SuperMail on ZX Spectrum 128k) with ESMTPSA id 050AD1EC04FB; Mon, 16 Aug 2021 12:42:58 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=alien8.de; s=dkim; t=1629110579; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:in-reply-to:in-reply-to: references:references; bh=KJr3PLH9kdh7sq6ftHE42Mk4Hk9JcVNuZWU5FfzNhng=; b=EdTJv86x/KgsZfUTho7nmU2tWDU7gWlJWwEPgv85zH6gBUrThHi9fC1iX5VEY4vmFQ3Wat 4L7CZpxMtqUnumgeTAAvIdt+GZJGAVni8JOdP7ssdtvST2BWMH3jSXeGJW+5iIwTMEZB+b GdsXFMbpKbQbyECkWOQbzWkuxXgeI58= Date: Mon, 16 Aug 2021 12:43:34 +0200 From: Borislav Petkov To: Yu-cheng Yu Cc: x86@kernel.org, "H. Peter Anvin" , Thomas Gleixner , Ingo Molnar , linux-kernel@vger.kernel.org, linux-doc@vger.kernel.org, linux-mm@kvack.org, linux-arch@vger.kernel.org, linux-api@vger.kernel.org, Arnd Bergmann , Andy Lutomirski , Balbir Singh , Cyrill Gorcunov , Dave Hansen , Eugene Syromiatnikov , Florian Weimer , "H.J. Lu" , Jann Horn , Jonathan Corbet , Kees Cook , Mike Kravetz , Nadav Amit , Oleg Nesterov , Pavel Machek , Peter Zijlstra , Randy Dunlap , "Ravi V. Shankar" , Vedvyas Shanbhogue , Dave Martin , Weijiang Yang , Pengfei Xu , Haitao Huang , Rick P Edgecombe , "Kirill A . Shutemov" Subject: Re: [PATCH v28 09/32] x86/mm: Introduce _PAGE_COW Message-ID: References: <20210722205219.7934-1-yu-cheng.yu@intel.com> <20210722205219.7934-10-yu-cheng.yu@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20210722205219.7934-10-yu-cheng.yu@intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jul 22, 2021 at 01:51:56PM -0700, Yu-cheng Yu wrote: > @@ -153,13 +178,23 @@ static inline int pud_young(pud_t pud) > > static inline int pte_write(pte_t pte) > { > - return pte_flags(pte) & _PAGE_RW; > + /* > + * Shadow stack pages are always writable - but not by normal > + * instructions, and only by shadow stack operations. Therefore, > + * the W=0,D=1 test with pte_shstk(). > + */ > + return (pte_flags(pte) & _PAGE_RW) || pte_shstk(pte); Well, this is weird: if some kernel code queries a shstk page and this here function says it is writable but then goes and tries to write into it and that write fails, then it'll confuse the user. IOW, from where I'm standing, that should be: return (pte_flags(pte) & _PAGE_RW) && !pte_shstk(pte); as in, a writable page is one which has _PAGE_RW and it is *not* a shadow stack page because latter is special and not really writable. Hmmm? -- Regards/Gruss, Boris. https://people.kernel.org/tglx/notes-about-netiquette