Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp269971pxx; Wed, 28 Oct 2020 04:37:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxDMYqg4UPPCY2xU/AukbfTzZLQjR4XTkZ5OcThPNNHI5vwZhSHk6B+YEsihhV2y1+4FJ/S X-Received: by 2002:aa7:db07:: with SMTP id t7mr7411599eds.161.1603885028824; Wed, 28 Oct 2020 04:37:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603885028; cv=none; d=google.com; s=arc-20160816; b=kYAdCum4c++A5wbD8W1PCYpynUg6TmGNtbpdprMEXjFyh4E2sPs7Gdf8kYRTQj4CxE xoD9qL4MbXukZAKoaH165JtKmJVfT/7AtKEyUuB6tPjfCsYvC68Gte3BsznYXhnfmwQx Qtf2D0WF3FsfB4jNCRKC1mvFqJcvrbxADyNeD/1RzoGFdGRbYRR4qhzZ+m6NvLWaFutO ZwPMVrVU/jhWzqJz6ldVF3KBDYk7fl4MtuHet2KXeOD5dlAvHeW9rR00JshTbdzrk/tm wBoUa0rxdp3ld3dVwwxjh5UcBcf/MYbYlf9D7mSFqGRsF3dwj6N6LEJbL2j853de2PBF vjNg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=wBnUTJ5er8D3FXf4TJWz3x2fRa/j1FBE8k2ToXMNAnQ=; b=Q+thcjtKG9hR2X070hFQYPz8+hYepsSstTcmDds2lXwNc6xQHgMbo6v8z1lVL/1Y86 jRIfkTXaMd/ldMTldrLefLp8sGY6HqSaq665LK3Tip1MRVgHSNdF4R31PDxFEJA1wLLo 4yznKRWiaa8Z00xGTI8xyXSg1P2AKGknwdCMdKf6ehKM0iSG633HPdBQogk5tG2Da7cS VN77MoC7vbUxeEdVUxIsU32Gp7MvOHDhu6MuEKn22uPTo770mhM50VP9iDWtsy0yjYhv PHtVUMPLR+P4ayOgsrHUdGc9sgQHsfsdIWtxAFeTxJA3L3NHkFXQXvH28Md+U/j98fbD 7B0A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=1sWsGlXk; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p90si2749641edd.284.2020.10.28.04.36.47; Wed, 28 Oct 2020 04:37:08 -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=@kernel.org header.s=default header.b=1sWsGlXk; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1793928AbgJ0PJI (ORCPT + 99 others); Tue, 27 Oct 2020 11:09:08 -0400 Received: from mail.kernel.org ([198.145.29.99]:38940 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1790298AbgJ0PEV (ORCPT ); Tue, 27 Oct 2020 11:04:21 -0400 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 6A25D2071A; Tue, 27 Oct 2020 15:04:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1603811061; bh=+PSnB/SCE1pbDMGw8ohIdcK8Qg9MsK6HofmiBQw9XlQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=1sWsGlXkEuRep1VVqTLQLBOTa4lf/wamqb8eLhpENVnGjLrI0s8zslmrfENIztcZY Y1h0/pRurs5zg9pLj2X7+oqsczu6sC96DqiMmpS2k4dLeI8nRYkcYNJyhJoG3VaKkc NIfPwkuFrjCz98lRoTv26QdGMUaZIY5WgB7aUKZ8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Pedro Miraglia Franco de Carvalho , Ravi Bangoria , Michael Ellerman , Sasha Levin Subject: [PATCH 5.8 360/633] powerpc/watchpoint: Fix quadword instruction handling on p10 predecessors Date: Tue, 27 Oct 2020 14:51:43 +0100 Message-Id: <20201027135539.579138265@linuxfoundation.org> X-Mailer: git-send-email 2.29.1 In-Reply-To: <20201027135522.655719020@linuxfoundation.org> References: <20201027135522.655719020@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Ravi Bangoria [ Upstream commit 4759c11ed20454b7b36db4ec15f7d5aa1519af4a ] On p10 predecessors, watchpoint with quadword access is compared at quadword length. If the watch range is doubleword or less than that in a first half of quadword aligned 16 bytes, and if there is any unaligned quadword access which will access only the 2nd half, the handler should consider it as extraneous and emulate/single-step it before continuing. Fixes: 74c6881019b7 ("powerpc/watchpoint: Prepare handler to handle more than one watchpoint") Reported-by: Pedro Miraglia Franco de Carvalho Signed-off-by: Ravi Bangoria Signed-off-by: Michael Ellerman Link: https://lore.kernel.org/r/20200902042945.129369-2-ravi.bangoria@linux.ibm.com Signed-off-by: Sasha Levin --- arch/powerpc/include/asm/hw_breakpoint.h | 1 + arch/powerpc/kernel/hw_breakpoint.c | 12 ++++++++++-- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/arch/powerpc/include/asm/hw_breakpoint.h b/arch/powerpc/include/asm/hw_breakpoint.h index cb424799da0dc..5a00da670a407 100644 --- a/arch/powerpc/include/asm/hw_breakpoint.h +++ b/arch/powerpc/include/asm/hw_breakpoint.h @@ -40,6 +40,7 @@ struct arch_hw_breakpoint { #else #define HW_BREAKPOINT_SIZE 0x8 #endif +#define HW_BREAKPOINT_SIZE_QUADWORD 0x10 #define DABR_MAX_LEN 8 #define DAWR_MAX_LEN 512 diff --git a/arch/powerpc/kernel/hw_breakpoint.c b/arch/powerpc/kernel/hw_breakpoint.c index c55e67bab2710..f39e86d751144 100644 --- a/arch/powerpc/kernel/hw_breakpoint.c +++ b/arch/powerpc/kernel/hw_breakpoint.c @@ -519,9 +519,17 @@ static bool ea_hw_range_overlaps(unsigned long ea, int size, struct arch_hw_breakpoint *info) { unsigned long hw_start_addr, hw_end_addr; + unsigned long align_size = HW_BREAKPOINT_SIZE; - hw_start_addr = ALIGN_DOWN(info->address, HW_BREAKPOINT_SIZE); - hw_end_addr = ALIGN(info->address + info->len, HW_BREAKPOINT_SIZE); + /* + * On p10 predecessors, quadword is handle differently then + * other instructions. + */ + if (!cpu_has_feature(CPU_FTR_ARCH_31) && size == 16) + align_size = HW_BREAKPOINT_SIZE_QUADWORD; + + hw_start_addr = ALIGN_DOWN(info->address, align_size); + hw_end_addr = ALIGN(info->address + info->len, align_size); return ((ea < hw_end_addr) && (ea + size > hw_start_addr)); } -- 2.25.1