Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp174156pxb; Tue, 24 Aug 2021 23:58:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwPDGlhjmACUH7gHVvrY24rXp+FNZp/pTPpmd83q2lovsU05cJqks4cvs4Ucv6Cb6MmhYlX X-Received: by 2002:a17:906:1789:: with SMTP id t9mr44979138eje.61.1629874727936; Tue, 24 Aug 2021 23:58:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629874727; cv=none; d=google.com; s=arc-20160816; b=FQuo2J5tUu0vd5i4PTHPbvqMOCI/VLZ4/bFQdzJiiHCeAjp4kv8Q+mWpLhJLNz5v2w ksnIiu2J5xtFzBoHUA9sVBZvridqcGFuxCf0PQYPxREI/U6PWfK5+ekThFEZ8rrziQ+m FP+eBeeARfeClcLQYddbeocu6X7KBeI0HpIXMi8ICP/kd7lYimydz+FSVAXnxm1Dn8eP 54lOkXchQVqD4OreQ42DlDaoM/irKJeXOGPHe6xmADgdgXABOXTsdifCW/2CYEVu/5BJ uGDRz55YQxsGZXucjhjDPukE8gRkUmW+6ru7SnxcrZHQ9dY6OignQPQFw1q9UNlolaJX 1sTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:references:in-reply-to:subject:cc:to:from :dkim-signature; bh=jSlsrM1HwMJvkNNLTTYatOR6fzYRjXvzYjOwr9yNskQ=; b=UT0UFuecwgN0GJZAXYgwxoBce73SDi8DOjssLMsZ1h08P+5zYy/zhIX5ZhX5gdOgSj pwVLDD6EJSZpzU83R9g/fnoZZdP1ryrwmyKcZTKRndaoa/+WJm1tsSWPK1WzRsYmAYaQ EhRT0odHyZkCuufU8llcCQEHX6iiWKyB4Rd3uHj+npxkDUSbTKjPVn70u6NNoSiWMbJj GpmJL9D69eLN3IFaSVQLqHepxHJ9vzrTVjLp4pQuST+KuQByj1wcVR+tRzc+zzxKGyTd Vb7m8vRKTZih36p6iHnMdyko1+vXf0rrqmM1ayR42d+FwB2lALTT7IfLHzk3k0ecLTHE xnMQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ellerman.id.au header.s=201909 header.b=aCB2aXtl; 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 ky22si18636218ejc.543.2021.08.24.23.58.01; Tue, 24 Aug 2021 23:58:47 -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=aCB2aXtl; 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 S238342AbhHYG4z (ORCPT + 99 others); Wed, 25 Aug 2021 02:56:55 -0400 Received: from ozlabs.org ([203.11.71.1]:54381 "EHLO ozlabs.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232273AbhHYG4v (ORCPT ); Wed, 25 Aug 2021 02:56:51 -0400 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 4GvcFc43ytz9sRf; Wed, 25 Aug 2021 16:56:04 +1000 (AEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ellerman.id.au; s=201909; t=1629874565; bh=jSlsrM1HwMJvkNNLTTYatOR6fzYRjXvzYjOwr9yNskQ=; h=From:To:Cc:Subject:In-Reply-To:References:Date:From; b=aCB2aXtlQfFCgiUkftH6/Do/ODK3fAMwydmKyqU4Qs/jlULSY4ST4uY/SN7FgNRZf D2VriOe51K+kzhkcDehiISDHUD1T3NltEfnSI0gslH8WXsZoimlPZ0/eII3DO/1slt gnbd1P3fZuPKP3dRxX0xEKu4nZYG82nmfaRm8YWXq921tg6+KAacsjqQUM36jT1vaS 9JW8ScwrUy8UUJ1/JPjfmspves05/kq1sDkCXhrCWBmJxHNsTQ1rItG/dis+Yw+5CG Zpa/1JiUMbKQSvIY02jLgn0sxQx1EmZeKh485JNT9peMbi7v8SQnYRxuk8B0+xwCYG phIfScszNAVzw== From: Michael Ellerman To: Christophe Leroy , Benjamin Herrenschmidt , Paul Mackerras , npiggin@gmail.com Cc: linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Subject: Re: [PATCH v3 1/3] powerpc: Remove MSR_PR check in interrupt_exit_{user/kernel}_prepare() In-Reply-To: References: <385ead49ccb66a259b25fee3eebf0bd4094068f3.1629707037.git.christophe.leroy@csgroup.eu> <87zgt6aybp.fsf@mpe.ellerman.id.au> Date: Wed, 25 Aug 2021 16:56:01 +1000 Message-ID: <87wnoaau7y.fsf@mpe.ellerman.id.au> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Christophe Leroy writes: > Le 25/08/2021 =C3=A0 07:27, Michael Ellerman a =C3=A9crit=C2=A0: >> Christophe Leroy writes: >>> In those hot functions that are called at every interrupt, any saved >>> cycle is worth it. >>> >>> interrupt_exit_user_prepare() and interrupt_exit_kernel_prepare() are >>> called from three places: >>> - From entry_32.S >>> - From interrupt_64.S >>> - From interrupt_exit_user_restart() and interrupt_exit_kernel_restart() >>> >>> In entry_32.S, there are inambiguously called based on MSR_PR: >>> >>> interrupt_return: >>> lwz r4,_MSR(r1) >>> addi r3,r1,STACK_FRAME_OVERHEAD >>> andi. r0,r4,MSR_PR >>> beq .Lkernel_interrupt_return >>> bl interrupt_exit_user_prepare >>> ... >>> .Lkernel_interrupt_return: >>> bl interrupt_exit_kernel_prepare >>> >>> In interrupt_64.S, that's similar: >>> >>> interrupt_return_\srr\(): >>> ld r4,_MSR(r1) >>> andi. r0,r4,MSR_PR >>> beq interrupt_return_\srr\()_kernel >>> interrupt_return_\srr\()_user: /* make backtraces match the _kernel va= riant */ >>> addi r3,r1,STACK_FRAME_OVERHEAD >>> bl interrupt_exit_user_prepare >>> ... >>> interrupt_return_\srr\()_kernel: >>> addi r3,r1,STACK_FRAME_OVERHEAD >>> bl interrupt_exit_kernel_prepare >>> >>> In interrupt_exit_user_restart() and interrupt_exit_kernel_restart(), >>> MSR_PR is verified respectively by BUG_ON(!user_mode(regs)) and >>> BUG_ON(user_mode(regs)) prior to calling interrupt_exit_user_prepare() >>> and interrupt_exit_kernel_prepare(). >>> >>> The verification in interrupt_exit_user_prepare() and >>> interrupt_exit_kernel_prepare() are therefore useless and can be remove= d. >>> >>> Signed-off-by: Christophe Leroy >>> Acked-by: Nicholas Piggin >>> --- >>> arch/powerpc/kernel/interrupt.c | 2 -- >>> 1 file changed, 2 deletions(-) >>=20 >> I'll pick this one up independent of the other two patches. > > Second patch should be ok as well, no ? Yeah I guess. I'm not sure if we'll want to keep cpu_has_msr_ri() if we have a CONFIG_PPC_MSR_RI, but that's a pretty minor detail. So yeah I'll take patch 2 as well. cheers