Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp266781iob; Wed, 18 May 2022 01:35:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy596DJCtq4w+1xnkQ3o4U0o/mVh6aQGj/rzq6zX7huxGllKyO3ZHMeS4fgqPxP+Y5JXdUv X-Received: by 2002:a17:902:d2c9:b0:15e:a266:6472 with SMTP id n9-20020a170902d2c900b0015ea2666472mr25602049plc.45.1652862899850; Wed, 18 May 2022 01:34:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652862899; cv=none; d=google.com; s=arc-20160816; b=tCqQHxk91ybJ7wx0AMYCwgP4pdVdbxiRQ9TGKFwIB2+3wvKFaMUoWeGTsMT0WMJzpq GBNKvfciA2vR+3F8lpsLDElpVooEa51OE+g4MvGMGADevesJRQPt4IRXcL1/do74Cm5M WFbLKAEKyT3LTm8aCUL9YrCTK90ucaLqUKpu+Vyq2gs+L1gG7f5YENCO7FFAGXzArhQ8 YwqnlFSYdx46+OZ30cFiRi+8T/QfBE1CjVSAC+Gwxy4WgJ0kbJWPicRO4sukNWpwA13/ parhWp+9ri8vh4MVqaAlwMrBCuc98jZUbOntzP+inF2xLJon6KRXZXd3HfgLsxRV6i2R WV3Q== 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:subject:cc:to:from; bh=t4cCRVtwmQ4Pfoc0TXgRK8XE4HQJQy/hLnVdHjDSw1E=; b=aNAJ8SRgA7WvhFxF3j2wyjffm98k8+yvKP7wad+WOUz7pAgvE7JlUdi4FaM+1vFoho 1IcR/atfJ17S+rHP/ku1j9vN561gjB5SRFPLEfQs+MMqMDrBx2FCyy/p69UiplHzyk0C ZGDLS5W+kQFd9imOWuWCEResm+o/QSpMLHEIgm6AwUc0IcHvrkwrNKZ8O7ty76bHQfhk TKqHiAqA273AqaCIXqPYn17Dkq3j/rZZ3a/Vl340hWfMqkSW/kx/XP64kEUhrT5ySU9Q ur0bwJnXq+L2orn/IKAPiQ3+lkUJ4/BzH4QbeA2nnseyH0nMkODnT5r4nI2+A6hX7AD3 PXQw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id e18-20020a635012000000b003c1f7890c2asi1690697pgb.765.2022.05.18.01.34.58 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 18 May 2022 01:34:59 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 891434ECEE; Wed, 18 May 2022 01:33:18 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233285AbiERIcq (ORCPT + 99 others); Wed, 18 May 2022 04:32:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47704 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233209AbiERIcn (ORCPT ); Wed, 18 May 2022 04:32:43 -0400 Received: from pegase2.c-s.fr (pegase2.c-s.fr [93.17.235.10]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2021B4ECDD for ; Wed, 18 May 2022 01:32:41 -0700 (PDT) Received: from localhost (mailhub3.si.c-s.fr [172.26.127.67]) by localhost (Postfix) with ESMTP id 4L35pH42jSz9srH; Wed, 18 May 2022 10:32:39 +0200 (CEST) X-Virus-Scanned: amavisd-new at c-s.fr Received: from pegase2.c-s.fr ([172.26.127.65]) by localhost (pegase2.c-s.fr [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id HMCf16Pr1Z1M; Wed, 18 May 2022 10:32:39 +0200 (CEST) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase2.c-s.fr (Postfix) with ESMTP id 4L35pG56pWz9srY; Wed, 18 May 2022 10:32:38 +0200 (CEST) Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 9C71E8B77C; Wed, 18 May 2022 10:32:38 +0200 (CEST) X-Virus-Scanned: amavisd-new at c-s.fr Received: from messagerie.si.c-s.fr ([127.0.0.1]) by localhost (messagerie.si.c-s.fr [127.0.0.1]) (amavisd-new, port 10023) with ESMTP id E3jlTJhOfF0Y; Wed, 18 May 2022 10:32:38 +0200 (CEST) Received: from PO20335.IDSI0.si.c-s.fr (unknown [172.25.230.108]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 854168B763; Wed, 18 May 2022 10:32:38 +0200 (CEST) Received: from PO20335.IDSI0.si.c-s.fr (localhost [127.0.0.1]) by PO20335.IDSI0.si.c-s.fr (8.17.1/8.16.1) with ESMTPS id 24I8WTkO2962120 (version=TLSv1.3 cipher=TLS_AES_256_GCM_SHA384 bits=256 verify=NOT); Wed, 18 May 2022 10:32:29 +0200 Received: (from chleroy@localhost) by PO20335.IDSI0.si.c-s.fr (8.17.1/8.17.1/Submit) id 24I8WTXa2962119; Wed, 18 May 2022 10:32:29 +0200 X-Authentication-Warning: PO20335.IDSI0.si.c-s.fr: chleroy set sender to christophe.leroy@csgroup.eu using -f From: Christophe Leroy To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman Cc: Christophe Leroy , linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Subject: [PATCH 1/2] powerpc/irq: Don't open code irq_soft_mask helpers Date: Wed, 18 May 2022 10:32:27 +0200 Message-Id: X-Mailer: git-send-email 2.35.3 MIME-Version: 1.0 X-Developer-Signature: v=1; a=ed25519-sha256; t=1652862747; l=2320; s=20211009; h=from:subject:message-id; bh=X8ypGLidc9Ld56ViHNF6ENtra1vjlh8aweG5rIJZaw4=; b=/9IqEfZeKBHtjVq5+XohFVjap2G23Hxm274hZ5E0E3ahyR6OmW/ES/4Bij1BSY8St+QldzRW7FM/ +ovtTNP4BxJkQ3+Bbi21G11TqdckONqOReIf2LneOX3El67t9hDS X-Developer-Key: i=christophe.leroy@csgroup.eu; a=ed25519; pk=HIzTzUj91asvincQGOFx6+ZF5AoUuP9GdOtQChs7Mm0= Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use READ_ONCE() and WRITE_ONCE() instead of open coding read and write of local PACA irq_soft_mask. For the write, add a barrier to keep the memory clobber that was there previously. Signed-off-by: Christophe Leroy --- arch/powerpc/include/asm/hw_irq.h | 43 +++++-------------------------- 1 file changed, 7 insertions(+), 36 deletions(-) diff --git a/arch/powerpc/include/asm/hw_irq.h b/arch/powerpc/include/asm/hw_irq.h index 674e5aaafcbd..edc569481faf 100644 --- a/arch/powerpc/include/asm/hw_irq.h +++ b/arch/powerpc/include/asm/hw_irq.h @@ -113,14 +113,7 @@ static inline void __hard_RI_enable(void) static inline notrace unsigned long irq_soft_mask_return(void) { - unsigned long flags; - - asm volatile( - "lbz %0,%1(13)" - : "=r" (flags) - : "i" (offsetof(struct paca_struct, irq_soft_mask))); - - return flags; + return READ_ONCE(local_paca->irq_soft_mask); } /* @@ -148,46 +141,24 @@ static inline notrace void irq_soft_mask_set(unsigned long mask) WARN_ON(mask && !(mask & IRQS_DISABLED)); #endif - asm volatile( - "stb %0,%1(13)" - : - : "r" (mask), - "i" (offsetof(struct paca_struct, irq_soft_mask)) - : "memory"); + WRITE_ONCE(local_paca->irq_soft_mask, mask); + barrier(); } static inline notrace unsigned long irq_soft_mask_set_return(unsigned long mask) { - unsigned long flags; - -#ifdef CONFIG_PPC_IRQ_SOFT_MASK_DEBUG - WARN_ON(mask && !(mask & IRQS_DISABLED)); -#endif + unsigned long flags = irq_soft_mask_return(); - asm volatile( - "lbz %0,%1(13); stb %2,%1(13)" - : "=&r" (flags) - : "i" (offsetof(struct paca_struct, irq_soft_mask)), - "r" (mask) - : "memory"); + irq_soft_mask_set(mask); return flags; } static inline notrace unsigned long irq_soft_mask_or_return(unsigned long mask) { - unsigned long flags, tmp; - - asm volatile( - "lbz %0,%2(13); or %1,%0,%3; stb %1,%2(13)" - : "=&r" (flags), "=r" (tmp) - : "i" (offsetof(struct paca_struct, irq_soft_mask)), - "r" (mask) - : "memory"); + unsigned long flags = irq_soft_mask_return(); -#ifdef CONFIG_PPC_IRQ_SOFT_MASK_DEBUG - WARN_ON((mask | flags) && !((mask | flags) & IRQS_DISABLED)); -#endif + irq_soft_mask_set(flags | mask); return flags; } -- 2.35.3