Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp365512pxb; Sat, 18 Sep 2021 05:12:42 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzerCtQU3C4aOM1aSnXMUqv7M9jRe4i+53qTFrYJUS0REAm33tDlhH0m1JGrs4KQCNMvn7H X-Received: by 2002:a6b:670f:: with SMTP id b15mr9053375ioc.15.1631967162144; Sat, 18 Sep 2021 05:12:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631967162; cv=none; d=google.com; s=arc-20160816; b=f9YzWQVR+uN3MEwErguXu4y2hiZwmPVsQWjbXGqeUyUh1IoIuwX0PYsAFB8WlyocsM CcG89t7wc8rJsiqGPQD25rXWKkGLeoYrpQKNvs0NQH3Jkt45Hw8dsbTnMFIvsDl8pnxc wcBn8KcirGPnF8mPvf1eJsn3K84xmGR7DKfaAEtWSfFaX4qMQRxBiFPNTWVa+LntluAy DAaSlVgPqYxSqE+HoPeLA3k+XCiD0UwMEVKdLhfdr3eMAMdtmDfjeOtPsovtIqva6VA5 2Ye66y/mCX3OrzKW/JzFf5Vh+QSafW8EF7aUsOaHACCOv4IOALzl80x79rjZY6f7+YjO pjCA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:references :in-reply-to:subject:cc:to:from:dkim-signature; bh=2bTe2HFevLjQ4dA9TYlB4P8vEbsjdrVvlgNzwhq0U2o=; b=bVsS5m668jMXGWgKgmS6w8RELUcDE9aCYdR8a/REhErocy3N0Tipr+ad5uwZ+5w4hj HnVbYtAK0GsVC3i5Tx2CE2XtMfMIZVHZOZGcNudQ1NB/l9e4RKp1BIrpdYDGGfPyd2k+ klWhodsmVVD8oz526tZAHzkGwOw1mUNGF2dkBaTrpGn8AZzaFAtnD5AgEFdrO/7cSEIn AZTQMTOo0NcMObCep0YUYpE1RJy7U6Cyw8k1LKESz4OF5tAJQL+Oq0AqRZ2B3awhqb1q Cyd03Qc01T4UwcgPZlpSRUVsEYnB8Vb8dzYLxcydK2GiNDP09YQDnVAJBaX7Jno8c/QK 5XQA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ellerman.id.au header.s=201909 header.b=EEb72HSn; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f5si8987999ils.120.2021.09.18.05.12.31; Sat, 18 Sep 2021 05:12:42 -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=@ellerman.id.au header.s=201909 header.b=EEb72HSn; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241519AbhIRD2d (ORCPT + 99 others); Fri, 17 Sep 2021 23:28:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41328 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234698AbhIRD2b (ORCPT ); Fri, 17 Sep 2021 23:28:31 -0400 Received: from ozlabs.org (bilbo.ozlabs.org [IPv6:2401:3900:2:1::2]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DFCB3C061574 for ; Fri, 17 Sep 2021 20:27:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ellerman.id.au; s=201909; t=1631935624; bh=2bTe2HFevLjQ4dA9TYlB4P8vEbsjdrVvlgNzwhq0U2o=; h=From:To:Cc:Subject:In-Reply-To:References:Date:From; b=EEb72HSnmYCo67/e0LfInIJ/C4NiLLB7KZU2pH2tGZO4ZKcHuIBxAWl3sNanpAGCA QJYJ9fQ32GPB884/xjz+H8mOEI4O1E+JGKGRxV+6HQnyDR+RXy7YxI2qNt6ZylDA46 b1ii0NIq7q5uVui6xRsHUG1Lj4IzzwEmlIgRJHExN3YO2l5es7UCmGFvzmVLAJ27aH JASdHLOJrQlJq3l/K2XlhH13a6Kus+FmsdEs0bzUHydgvt6nBBM3J5SRDSkLyqYGX+ nltVfESCe0ixpxyvzBJ5wNuMn2XRFmRND/CLsEiuCXoFMQG+WvPqpzmu/CKsa7Th3m R9pQj0Xirak8g== Received: from authenticated.ozlabs.org (localhost [127.0.0.1]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-256) server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by mail.ozlabs.org (Postfix) with ESMTPSA id 4HBGTN2KPCz9sW4; Sat, 18 Sep 2021 13:27:03 +1000 (AEST) From: Michael Ellerman To: Christophe Leroy , Benjamin Herrenschmidt , Paul Mackerras Cc: Christophe Leroy , linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Subject: Re: [PATCH v2] powerpc/32: Don't use a struct based type for pte_t In-Reply-To: References: Date: Sat, 18 Sep 2021 13:26:57 +1000 Message-ID: <87tuiiimwu.fsf@mpe.ellerman.id.au> MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Christophe Leroy writes: > Long time ago we had a config item called STRICT_MM_TYPECHECKS > to build the kernel with pte_t defined as a structure in order > to perform additional build checks or build it with pte_t > defined as a simple type in order to get simpler generated code. > > Commit 670eea924198 ("powerpc/mm: Always use STRICT_MM_TYPECHECKS") > made the struct based definition the only one, considering that the > generated code was similar in both cases. > > That's right on ppc64 because the ABI is such that the content of a > struct having a single simple type element is passed as register, > but on ppc32 such a structure is passed via the stack like any > structure. > > Simple test function: > > pte_t test(pte_t pte) > { > return pte; > } > > Before this patch we get > > c00108ec : > c00108ec: 81 24 00 00 lwz r9,0(r4) > c00108f0: 91 23 00 00 stw r9,0(r3) > c00108f4: 4e 80 00 20 blr > > So, for PPC32, restore the simple type behaviour we got before > commit 670eea924198, but instead of adding a config option to > activate type check, do it when __CHECKER__ is set so that type > checking is performed by 'sparse' and provides feedback like: > > arch/powerpc/mm/pgtable.c:466:16: warning: incorrect type in return expression (different base types) > arch/powerpc/mm/pgtable.c:466:16: expected unsigned long > arch/powerpc/mm/pgtable.c:466:16: got struct pte_t [usertype] x OK that's a good trade off. One question below ... > diff --git a/arch/powerpc/include/asm/pgtable-types.h b/arch/powerpc/include/asm/pgtable-types.h > index d11b4c61d686..c60199fc6fa6 100644 > --- a/arch/powerpc/include/asm/pgtable-types.h > +++ b/arch/powerpc/include/asm/pgtable-types.h > @@ -5,14 +5,26 @@ > /* PTE level */ > #if defined(CONFIG_PPC_8xx) && defined(CONFIG_PPC_16K_PAGES) > typedef struct { pte_basic_t pte, pte1, pte2, pte3; } pte_t; > -#else > +#elif defined(__CHECKER__) || !defined(CONFIG_PPC32) It would be nicer if this logic was in Kconfig. eg. restore config STRICT_MM_TYPECHECKS but make it always enabled for 64-bit, and depend on CHECKER for 32-bit. The only thing is I'm not sure if we can test __CHECKER__ in Kconfig? cheers