Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp2954921pxb; Tue, 13 Apr 2021 14:41:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxx69b9gIyanGMHhH5OCbqObVFIJfGxmoYA25aBF/C62sSGOjNTbZXKdCWYvmzDTwYA1iad X-Received: by 2002:aa7:dc0b:: with SMTP id b11mr37749142edu.124.1618350096880; Tue, 13 Apr 2021 14:41:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618350096; cv=none; d=google.com; s=arc-20160816; b=i0HN06TWUIIjciP9XJ52GaLMLiQuLtpdkHZMKbdgFQuCs1Muv252ZDsBycJLYwUc5b 6+5HQ0DizUhwtxKxvQDJevOoPlX5xHoM6ZnLkjop5+QXF7UkRyzlkkheiPQKwdWLU+ql 8B1x8mKnltlYK17Qv+TJbU86Nd+vi/Eaxr5MKzi4v3ti72vLskdi33LJlkWgfJuNNG91 hDEC3d4dkzTW+7MQkHaXqcKj37BXVo37ZPz8xD/IDb5h5J14QrOq3SXzgzlY+rYvsJ/M qD3EczweKg9TMGQBXVjzKQp+uZ0eFvVvmKVjX1aN+B2Hkem6bDGm2c0FArlm7fHSZ+FJ XT1A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=GC4JVsteaMDUHVA3zJIea1v51FeWj+ToTw7EGNImyrY=; b=xsg1Xd45QV7Yq7oqqNOTnEGIo3EUZKoE2hPPmJYzcp3NWJyHN6T7TAqmPKy1pXK0zX MLtleAZ+y4o73gjm54i2pCFzKT1F5ejgorRhujx/hxqA150iFDVwzK1mNH2PQ/oa04sE I66G2PeCY/AwV0RYkdincIUNBCJV9UB0M+a1sPOQoijmMRDa6wfzcB4QNlk6USA33OYO 5U5BKQeXSqDyrbc5P5/NWEhSEaT3q0kaWS5EMiAM53usw+S+PEEiUokHmW67oN/ULat4 Fv25zYq4TbDrUwrtmOO5C53sduuWFHai+4RAL+TppJ81mDBe7Ejh0ps/+CXnSVTJf0UP VSVg== ARC-Authentication-Results: i=1; mx.google.com; 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 g16si3169964ejm.310.2021.04.13.14.41.13; Tue, 13 Apr 2021 14:41:36 -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; 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 S1345973AbhDMQhF (ORCPT + 99 others); Tue, 13 Apr 2021 12:37:05 -0400 Received: from pegase1.c-s.fr ([93.17.236.30]:8358 "EHLO pegase1.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345371AbhDMQhB (ORCPT ); Tue, 13 Apr 2021 12:37:01 -0400 Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 4FKWTL3l94z9v4hC; Tue, 13 Apr 2021 18:36:38 +0200 (CEST) X-Virus-Scanned: Debian amavisd-new at c-s.fr Received: from pegase1.c-s.fr ([192.168.12.234]) by localhost (pegase1.c-s.fr [192.168.12.234]) (amavisd-new, port 10024) with ESMTP id DydKvha3r-0P; Tue, 13 Apr 2021 18:36:38 +0200 (CEST) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase1.c-s.fr (Postfix) with ESMTP id 4FKWTL1dSsz9v4h8; Tue, 13 Apr 2021 18:36:38 +0200 (CEST) Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id B63518B7AA; Tue, 13 Apr 2021 18:36:39 +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 l6EiQIyyQ9dS; Tue, 13 Apr 2021 18:36:39 +0200 (CEST) Received: from [192.168.4.90] (unknown [192.168.4.90]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 5627A8B75F; Tue, 13 Apr 2021 18:36:39 +0200 (CEST) Subject: Re: [PATCH v1 2/2] powerpc/atomics: Use immediate operand when possible To: Segher Boessenkool Cc: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman , linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org References: <09da6fec57792d6559d1ea64e00be9870b02dab4.1617896018.git.christophe.leroy@csgroup.eu> <9f50b5fadeb090553e5c2fae025052d04d52f3c7.1617896018.git.christophe.leroy@csgroup.eu> <20210412220821.GN26583@gate.crashing.org> From: Christophe Leroy Message-ID: <063ca819-1276-8deb-0d9b-ea6ec33f9a98@csgroup.eu> Date: Tue, 13 Apr 2021 18:36:04 +0200 User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.9.1 MIME-Version: 1.0 In-Reply-To: <20210412220821.GN26583@gate.crashing.org> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: fr Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Le 13/04/2021 à 00:08, Segher Boessenkool a écrit : > Hi! > > On Thu, Apr 08, 2021 at 03:33:45PM +0000, Christophe Leroy wrote: >> +#define ATOMIC_OP(op, asm_op, dot, sign) \ >> static __inline__ void atomic_##op(int a, atomic_t *v) \ >> { \ >> int t; \ >> \ >> __asm__ __volatile__( \ >> "1: lwarx %0,0,%3 # atomic_" #op "\n" \ >> - #asm_op " %0,%2,%0\n" \ >> + #asm_op "%I2" dot " %0,%0,%2\n" \ >> " stwcx. %0,0,%3 \n" \ >> " bne- 1b\n" \ >> - : "=&r" (t), "+m" (v->counter) \ >> - : "r" (a), "r" (&v->counter) \ >> + : "=&b" (t), "+m" (v->counter) \ >> + : "r"#sign (a), "r" (&v->counter) \ >> : "cc"); \ >> } \ > > You need "b" (instead of "r") only for "addi". You can use "addic" > instead, which clobbers XER[CA], but *all* inline asm does, so that is > not a downside here (it is also not slower on any CPU that matters). > >> @@ -238,14 +238,14 @@ static __inline__ int atomic_fetch_add_unless(atomic_t *v, int a, int u) >> "1: lwarx %0,0,%1 # atomic_fetch_add_unless\n\ >> cmpw 0,%0,%3 \n\ >> beq 2f \n\ >> - add %0,%2,%0 \n" >> + add%I2 %0,%0,%2 \n" >> " stwcx. %0,0,%1 \n\ >> bne- 1b \n" >> PPC_ATOMIC_EXIT_BARRIER >> -" subf %0,%2,%0 \n\ >> +" sub%I2 %0,%0,%2 \n\ >> 2:" >> - : "=&r" (t) >> - : "r" (&v->counter), "r" (a), "r" (u) >> + : "=&b" (t) >> + : "r" (&v->counter), "rI" (a), "r" (u) >> : "cc", "memory"); > > Same here. Yes, I thought about addic, I didn't find an early solution because I forgot the matching 'addc'. Now with the couple addc/addic it works well. Thanks > > Nice patches! > > Acked-by: Segher Boessenkool > Christophe