Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp597356img; Fri, 22 Mar 2019 04:51:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqzKpkjuKoV0qohyq/CZATyzjzIVxgbJrx+YFM/qkdg6v0IA1c111s54fFRH92Stn3/S/EJC X-Received: by 2002:a63:360e:: with SMTP id d14mr8618285pga.179.1553255514009; Fri, 22 Mar 2019 04:51:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553255514; cv=none; d=google.com; s=arc-20160816; b=dR1ahcqn+8X5EUlGzNTE6C64UtnX4sI0krlT04RwLTBEYnbmfdSsDvM/2pdx/Sv2Mo 6Ve7+0qCAFmQqpSisxBygs0t+kUTkxxRzD8y1RnPoyiwyuOasEORJc1GeIXhQtx6PHvQ ePTtK5eLWRDGThtUCL20A8joJwC5nFbgOMruo6jsdr7G8mv2ihoJgaUeh9zBhoklAt4c t1IgcAXOHrq45SBg+0HjfbY/FEUruT6uFfKFpVd66iW2wSnJzGOA6YsfYrikDGjtCvQB RrLdP2p6MFcIZbKgBQnag6NtKZCPe5N+qQsRmDgLLRLa7zxW0c6ZgTnhR5VRIbuL9bzK mjDw== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=mwLo2B2ePijagIfgr8+PVACEvp493/umscgsbTTU3ic=; b=LjQXgoMUbDDZNepXraabA+eoqbcKKjiDQDej3YTOoEFnlF62qfCWSk3Pv3WPAsJbQq EDXVw36m3SEQdWajMpAomTv/PZF/wr2Qg8BRLP/s28sbvJ7vmmcpmjtPgQGqbtxZpYxl +AvUaR5TBlf0najchyFtukuvA/CSoSASRhWPmnaZCGGjKv1xzrxstPvqXwrkxs7hCpcz /g+xZPM4Vt+ro9T5GPRznFtKsPcFKxrhaceFiA2MG4U6N/fbK9QU+uTEG8DiznEhprcI 3Tjjc/NBeCBrDGr7Ofloke0RCIA6f2Gs9Df8fxTeELD+5lOpJLBJLfYKNjOcz0TSlhkb d1MA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=BjjshN4V; 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 n6si6275100pgp.108.2019.03.22.04.51.38; Fri, 22 Mar 2019 04:51:53 -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=@kernel.org header.s=default header.b=BjjshN4V; 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 S1732322AbfCVLtt (ORCPT + 99 others); Fri, 22 Mar 2019 07:49:49 -0400 Received: from mail.kernel.org ([198.145.29.99]:53446 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732506AbfCVLto (ORCPT ); Fri, 22 Mar 2019 07:49:44 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 B6987218B0; Fri, 22 Mar 2019 11:49:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1553255383; bh=afC0erqlbkIAMySXl3wi4XNVwF1DXlUCjBH0B2Hd8Pg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=BjjshN4VJkxoyFHjGvq9wQ/mXT6nW9rkG6St355tC1Vkan/M/n9ioUxXm92A6N3t0 W1NZVmJcANfC16F99B0vWM+BdjsZYcavMSfUv3KhA/c4IT0MFxgygtk8+2e2YmDZrK mhwy8e4qGqVLCmNMSJllbVD9tmFzqyJ0GA2m9ic8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Eugeniy Paltsev , Vineet Gupta , Sasha Levin Subject: [PATCH 4.14 056/183] ARCv2: lib: memcpy: fix doing prefetchw outside of buffer Date: Fri, 22 Mar 2019 12:14:44 +0100 Message-Id: <20190322111245.776728420@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190322111241.819468003@linuxfoundation.org> References: <20190322111241.819468003@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit f8a15f97664178f27dfbf86a38f780a532cb6df0 ] ARCv2 optimized memcpy uses PREFETCHW instruction for prefetching the next cache line but doesn't ensure that the line is not past the end of the buffer. PRETECHW changes the line ownership and marks it dirty, which can cause data corruption if this area is used for DMA IO. Fix the issue by avoiding the PREFETCHW. This leads to performance degradation but it is OK as we'll introduce new memcpy implementation optimized for unaligned memory access using. We also cut off all PREFETCH instructions at they are quite useless here: * we call PREFETCH right before LOAD instruction call. * we copy 16 or 32 bytes of data (depending on CONFIG_ARC_HAS_LL64) in a main logical loop. so we call PREFETCH 4 times (or 2 times) for each L1 cache line (in case of 64B L1 cache Line which is default case). Obviously this is not optimal. Signed-off-by: Eugeniy Paltsev Signed-off-by: Vineet Gupta Signed-off-by: Sasha Levin --- arch/arc/lib/memcpy-archs.S | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/arch/arc/lib/memcpy-archs.S b/arch/arc/lib/memcpy-archs.S index d61044dd8b58..ea14b0bf3116 100644 --- a/arch/arc/lib/memcpy-archs.S +++ b/arch/arc/lib/memcpy-archs.S @@ -25,15 +25,11 @@ #endif #ifdef CONFIG_ARC_HAS_LL64 -# define PREFETCH_READ(RX) prefetch [RX, 56] -# define PREFETCH_WRITE(RX) prefetchw [RX, 64] # define LOADX(DST,RX) ldd.ab DST, [RX, 8] # define STOREX(SRC,RX) std.ab SRC, [RX, 8] # define ZOLSHFT 5 # define ZOLAND 0x1F #else -# define PREFETCH_READ(RX) prefetch [RX, 28] -# define PREFETCH_WRITE(RX) prefetchw [RX, 32] # define LOADX(DST,RX) ld.ab DST, [RX, 4] # define STOREX(SRC,RX) st.ab SRC, [RX, 4] # define ZOLSHFT 4 @@ -41,8 +37,6 @@ #endif ENTRY_CFI(memcpy) - prefetch [r1] ; Prefetch the read location - prefetchw [r0] ; Prefetch the write location mov.f 0, r2 ;;; if size is zero jz.d [blink] @@ -72,8 +66,6 @@ ENTRY_CFI(memcpy) lpnz @.Lcopy32_64bytes ;; LOOP START LOADX (r6, r1) - PREFETCH_READ (r1) - PREFETCH_WRITE (r3) LOADX (r8, r1) LOADX (r10, r1) LOADX (r4, r1) @@ -117,9 +109,7 @@ ENTRY_CFI(memcpy) lpnz @.Lcopy8bytes_1 ;; LOOP START ld.ab r6, [r1, 4] - prefetch [r1, 28] ;Prefetch the next read location ld.ab r8, [r1,4] - prefetchw [r3, 32] ;Prefetch the next write location SHIFT_1 (r7, r6, 24) or r7, r7, r5 @@ -162,9 +152,7 @@ ENTRY_CFI(memcpy) lpnz @.Lcopy8bytes_2 ;; LOOP START ld.ab r6, [r1, 4] - prefetch [r1, 28] ;Prefetch the next read location ld.ab r8, [r1,4] - prefetchw [r3, 32] ;Prefetch the next write location SHIFT_1 (r7, r6, 16) or r7, r7, r5 @@ -204,9 +192,7 @@ ENTRY_CFI(memcpy) lpnz @.Lcopy8bytes_3 ;; LOOP START ld.ab r6, [r1, 4] - prefetch [r1, 28] ;Prefetch the next read location ld.ab r8, [r1,4] - prefetchw [r3, 32] ;Prefetch the next write location SHIFT_1 (r7, r6, 8) or r7, r7, r5 -- 2.19.1