Received: by 10.213.65.68 with SMTP id h4csp120358imn; Tue, 27 Mar 2018 18:10:15 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/pmmQ2GMvrGAxTRWgqz5kBjr89ZHalcsm6bJvdb56c+faqfp+bl3rKulPa/zix2RuI6pl6 X-Received: by 2002:a17:902:9a44:: with SMTP id x4-v6mr1594458plv.332.1522199415210; Tue, 27 Mar 2018 18:10:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522199415; cv=none; d=google.com; s=arc-20160816; b=CmHHU8jNJp2e6bjcHp2OkaZNRCS91hAl813kd+t1X3D98hgEOFNiHkTltf2/tFd3b6 ONpTJr+ccJCzXiCzQ1NWLZMOpTgvs/xE2syTK/587Qty+sF9uSIO/GQzbjKC/sS6sBkH w70TsdlzAO5ehNDlW9xAm5l/KfPGHaAv1mvAWPQ+x7dG2Z7LVQ6gpsErv1ZYjmJ6o4Hk 4a7tpUKmmfRSAwG4IobDuARXVQnhlFPV8zuqP1SEcsghzE9wJ2bY6ec/bGdOvBcrBaMV FlbOHzQJnl5Q1c/Rv4Ns21JrJNUNYQuFgSJXchpkS7NclhgWYKVFANVWa9B8/hxbrGVV Ql4w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dmarc-filter :dkim-signature:dkim-signature:arc-authentication-results; bh=icO2cmu0t4eVDOw4UHe3fPzQ18dWRG1WAtNrPdkjt6I=; b=ssMehegoXifBPimnUCF0mQ8jduPR1JYjZnawCuNqMaadxroe0sY5W5jtg5OIXcfbjC 3FBOaFGHU+Iv0kDPazWYqe84jsLotoKb5QJPXKjAYkgeEhI73B/JtuMi/54+6WQvIJ0u o9+I2Dg4YA9z0GaopQS5rU+lBL0aMm6KX+on9P1nd+bNBmKlHU+l28Wn69Q7Dp3nJYZQ XoJqmuM4Xn0nipHSphBE0FuhuXxNV1GH93Hsq4kEeLfgEtum0owYF45Txmqs+q6gpZEY m6OrH8VctAPPKA/zQynisou8tqcxiEI9VMIfAWnbAz1kP2Tffbe22bJAehhbixUykjAH 66xA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=GcSXUXmb; dkim=pass header.i=@codeaurora.org header.s=default header.b=Yf+w0nMS; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n1-v6si2423456pld.87.2018.03.27.18.10.00; Tue, 27 Mar 2018 18:10:15 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=GcSXUXmb; dkim=pass header.i=@codeaurora.org header.s=default header.b=Yf+w0nMS; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752782AbeC1BJF (ORCPT + 99 others); Tue, 27 Mar 2018 21:09:05 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:47396 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752704AbeC1BJD (ORCPT ); Tue, 27 Mar 2018 21:09:03 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 6C048606DB; Wed, 28 Mar 2018 01:09:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1522199343; bh=XFddJ2iAPtArIEBfjPOwcZgj5caJ2q1nH+RgYRvp6V8=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=GcSXUXmbp3wA5XtPIl9I6yFPdNmn4HFVRkDr+T07ZbRCMGF6MjAAZJm4tG6YTVSha 62w3/uZOqQfaKoHElWvwqzaylU0HBv037mv77yykNiLW7iwJQrKkA/UuWSVCqDWWSL QFdN8vcjn+INwmeUQKlo/cQ7qg2hdCbRP9yyq8k4= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from [192.168.86.172] (unknown [75.165.166.104]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: pelcan@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 7A52F601D3; Wed, 28 Mar 2018 01:09:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1522199342; bh=XFddJ2iAPtArIEBfjPOwcZgj5caJ2q1nH+RgYRvp6V8=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=Yf+w0nMSAcm7r3uMrNDJ0qG6xOnsYtqhFr8P2pRAAo/dqSsuKi3OLjhHnpEYnM1Tu oQvahuwFXcgAewpJ0vh0tFtJV1Xaj/2MyK3VoUFAhCqgrXCqUIZXTReEcjfXB5kHp1 ziWEnwtFKz71vv6aU5ca9UPkyiZDoC/DUrkbG+wE= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 7A52F601D3 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=pelcan@codeaurora.org Subject: Re: [PATCH V2] arm64: tlbflush: avoid writing RES0 bits To: shankerd@codeaurora.org, Will Deacon Cc: Mark Rutland , Catalin Marinas , linux-kernel@vger.kernel.org, Thomas Speier , Robin Murphy , linux-arm-kernel@lists.infradead.org References: <1522120877-9136-1-git-send-email-pelcan@codeaurora.org> <985a0edd-e388-dade-8824-30cc58a236f3@arm.com> <56b560a5-6e57-8e01-32ca-9d3c95ccd2e5@codeaurora.org> <20180327173613.GI18435@arm.com> <96f894bb-4855-a77f-3fd1-c8a2878faabb@codeaurora.org> From: Philip Elcan Message-ID: Date: Tue, 27 Mar 2018 21:08:58 -0400 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <96f894bb-4855-a77f-3fd1-c8a2878faabb@codeaurora.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 3/27/2018 9:03 PM, Shanker Donthineni wrote: > Hi Will, > > On 03/27/2018 12:36 PM, Will Deacon wrote: >> Hi Shanker, >> >> On Tue, Mar 27, 2018 at 09:53:16AM -0500, Shanker Donthineni wrote: >>> On 03/27/2018 06:34 AM, Robin Murphy wrote: >>>> On 27/03/18 04:21, Philip Elcan wrote: >>>>> Several of the bits of the TLBI register operand are RES0 per the ARM >>>>> ARM, so TLBI operations should avoid writing non-zero values to these >>>>> bits. >>>>> >>>>> This patch adds a macro __TLBI_VADDR(addr, asid) that creates the >>>>> operand register in the correct format and honors the RES0 bits. >>>>> >>>>> Signed-off-by: Philip Elcan >>>>> --- >>>>>   arch/arm64/include/asm/tlbflush.h | 23 ++++++++++++++++------- >>>>>   1 file changed, 16 insertions(+), 7 deletions(-) >>>>> >>>>> diff --git a/arch/arm64/include/asm/tlbflush.h b/arch/arm64/include/asm/tlbflush.h >>>>> index 9e82dd7..b1205e9 100644 >>>>> --- a/arch/arm64/include/asm/tlbflush.h >>>>> +++ b/arch/arm64/include/asm/tlbflush.h >>>>> @@ -60,6 +60,15 @@ >>>>>           __tlbi(op, (arg) | USER_ASID_FLAG);                \ >>>>>   } while (0) >>>>>   +/* This macro creates a properly formatted VA operand for the TLBI */ >>>>> +#define __TLBI_VADDR(addr, asid)                \ >>>>> +    ({                            \ >>>>> +        unsigned long __ta = (addr) >> 12;        \ >>>>> +        __ta &= GENMASK_ULL(43, 0);            \ >>>>> +        __ta |= (unsigned long)(asid) << 48;        \ >>>>> +        __ta;                        \ >>>>> +    }) >>>> >>>> I'd be inclined to make this a static inline function rather than a >>>> macro, since it doesn't need to do any wacky type-dodging, but either >>>> way the overall change now looks appropriate; >>>> >>>> Acked-by: Robin Murphy >>>> >>> >>> Tested-by: Shanker Donthineni >> >> [...] >> >>>>> @@ -154,8 +163,8 @@ static inline void __flush_tlb_range(struct vm_area_struct *vma, >>>>>           return; >>>>>       } >>>>>   -    start = asid | (start >> 12); >>>>> -    end = asid | (end >> 12); >>>>> +    start = __TLBI_VADDR(start, asid); >>>>> +    end = __TLBI_VADDR(end, asid); >> >> Can you test this bit too, please? ;) >> > > I've verified the basic boot functionality on QDF2400 platform. But I can see now > after your comments, it leads to TLB conflicts because of ASID is truncated to zero > due to two times 48bit shift. > > Thanks for catching this one. > > @@ -146,7 +155,7 @@ static inline void __flush_tlb_range(structvm_area_struct * > unsigned long start, unsigned long end, > bool last_level) > { > - unsigned long asid = ASID(vma->vm_mm) << 48; > + unsigned long asid = ASID(vma->vm_mm); > unsigned long addr; > > if ((end - start) > MAX_TLB_RANGE) { > @@ -154,8 +163,8 @@ static inline void __flush_tlb_range(struct > vm_area_struct * > return; > } > > - start = asid | (start >> 12); > - end = asid | (end >> 12); > + start = __TLBI_VADDR(start, asid); > + end = __TLBI_VADDR(end, asid); > > >> Will >> >> _______________________________________________ >> linux-arm-kernel mailing list >> linux-arm-kernel@lists.infradead.org >> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel >> > Thanks for catching that. I'll address with a v3 patch. Philip -- Qualcomm Datacenter Technologies as an affiliate of Qualcomm Technologies, Inc. Qualcomm Technologies, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project.