Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1324890pxk; Fri, 4 Sep 2020 06:47:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwcOPL8cRDzYtaRN1fd1Q4RRCC4H+GL4U+uw/ewhPa8FZeQLR4gOBE1NDLZG3vlJPKWtbvB X-Received: by 2002:aa7:c504:: with SMTP id o4mr8863486edq.82.1599227278838; Fri, 04 Sep 2020 06:47:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1599227278; cv=none; d=google.com; s=arc-20160816; b=rRHPRZpL9Dsa9yfPRNIlSki8emXS/mDCeD/z4iURcg8CVI3c6G3VHmIviWir+nQska OCj+88sOdhoaf6dysq8Fb5+a7CGn5qD95YdEN5uuKfNmK7rZQVLK7WOHJ4o+7dkdL5hC 84JyuyHJYj+E+7Qa7OUIS88PNxsW9Dd1UIxU+UxfHANK92+hzWZEEBBiBrsPfQsoidKz B+2J+PoZmdzjHZ0viNomJol5sn9QMxNnHD3SjXrhKPYuQmZyWvXlKdGjAXkvuyb7rFpr I+3GvWSLn/9CtP6kQWKDLPCWctRB9FAKfApQNHBUftPhtuz7ZK8+UjO2dS8fGMoLLxng JFyQ== 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=yE7raTOPXNzHY81r1h/u2AKBYzMzGWDzQt5FmHt+umA=; b=EQZp42wNL0hBrMiMDRZK0teCZe6kjkmR2G2ccPLnrW+tD11RWtg19vuTzVK/wg0Rdv 5t04hpyXGrT5AwpY/sNYVbtqP3+Z1+mWwCGlQUqCS0wfhrPct0npZ0Cdi7ZsZk0r+9Oe QLsNP2KZMSDU9X3eIhsnV3YeGht7uQYbdfMfC7Iu1Qo8I2pZfXtJ/+uix+2qjU2zAMzz y8sQgjEfB1Q2ogDvRASItXWuqwODfeywJSHPf66X7Zt/Vz4CRUOZnr1YuULdpjEpo+mJ Earfpjg3Lckmvbw2upSvL2y3e1g1Qh7rpDhjON9TkTnErSkMV8l2QUkjxw0xWMn+vl6f YbKA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cVZfIWAQ; 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 v4si3945546edi.28.2020.09.04.06.47.34; Fri, 04 Sep 2020 06:47:58 -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=cVZfIWAQ; 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 S1730548AbgIDNns (ORCPT + 99 others); Fri, 4 Sep 2020 09:43:48 -0400 Received: from mail.kernel.org ([198.145.29.99]:37300 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730424AbgIDNeX (ORCPT ); Fri, 4 Sep 2020 09:34:23 -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 1F9C7204FD; Fri, 4 Sep 2020 13:30:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1599226229; bh=5IwSshPpgozIPZMjbeg/fb3EXkle70zb11w810FYpW0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=cVZfIWAQDKDMkLwFUNC7DLbxdgDjZCgf0WMwluRr3DbyQiVQrCokt6nbvBzskyOPT CXZ1lygZNBoqeeeG7fQxnJRDuFfqp54xI36RxSppfTNG/3lXmRuky6jHZy5NdcoQp0 fRukoyjlQl4ON8eUH1RrXligI5yo1LSxK1W059ow= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, JiangYu , Daniel Meyerholt , Mike Christie , Bodo Stroesser , "Martin K. Petersen" Subject: [PATCH 5.4 16/16] scsi: target: tcmu: Optimize use of flush_dcache_page Date: Fri, 4 Sep 2020 15:30:09 +0200 Message-Id: <20200904120257.987739598@linuxfoundation.org> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200904120257.203708503@linuxfoundation.org> References: <20200904120257.203708503@linuxfoundation.org> User-Agent: quilt/0.66 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 From: Bodo Stroesser commit 3c58f737231e2c8cbf543a09d84d8c8e80e05e43 upstream. (scatter|gather)_data_area() need to flush dcache after writing data to or before reading data from a page in uio data area. The two routines are able to handle data transfer to/from such a page in fragments and flush the cache after each fragment was copied by calling the wrapper tcmu_flush_dcache_range(). That means: 1) flush_dcache_page() can be called multiple times for the same page. 2) Calling flush_dcache_page() indirectly using the wrapper does not make sense, because each call of the wrapper is for one single page only and the calling routine already has the correct page pointer. Change (scatter|gather)_data_area() such that, instead of calling tcmu_flush_dcache_range() before/after each memcpy, it now calls flush_dcache_page() before unmapping a page (when writing is complete for that page) or after mapping a page (when starting to read the page). After this change only calls to tcmu_flush_dcache_range() for addresses in vmalloc'ed command ring are left over. The patch was tested on ARM with kernel 4.19.118 and 5.7.2 Link: https://lore.kernel.org/r/20200618131632.32748-2-bstroesser@ts.fujitsu.com Tested-by: JiangYu Tested-by: Daniel Meyerholt Acked-by: Mike Christie Signed-off-by: Bodo Stroesser Signed-off-by: Martin K. Petersen Signed-off-by: Greg Kroah-Hartman --- drivers/target/target_core_user.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) --- a/drivers/target/target_core_user.c +++ b/drivers/target/target_core_user.c @@ -676,8 +676,10 @@ static void scatter_data_area(struct tcm from = kmap_atomic(sg_page(sg)) + sg->offset; while (sg_remaining > 0) { if (block_remaining == 0) { - if (to) + if (to) { + flush_dcache_page(page); kunmap_atomic(to); + } block_remaining = DATA_BLOCK_SIZE; dbi = tcmu_cmd_get_dbi(tcmu_cmd); @@ -722,7 +724,6 @@ static void scatter_data_area(struct tcm memcpy(to + offset, from + sg->length - sg_remaining, copy_bytes); - tcmu_flush_dcache_range(to, copy_bytes); } sg_remaining -= copy_bytes; @@ -731,8 +732,10 @@ static void scatter_data_area(struct tcm kunmap_atomic(from - sg->offset); } - if (to) + if (to) { + flush_dcache_page(page); kunmap_atomic(to); + } } static void gather_data_area(struct tcmu_dev *udev, struct tcmu_cmd *cmd, @@ -778,13 +781,13 @@ static void gather_data_area(struct tcmu dbi = tcmu_cmd_get_dbi(cmd); page = tcmu_get_block_page(udev, dbi); from = kmap_atomic(page); + flush_dcache_page(page); } copy_bytes = min_t(size_t, sg_remaining, block_remaining); if (read_len < copy_bytes) copy_bytes = read_len; offset = DATA_BLOCK_SIZE - block_remaining; - tcmu_flush_dcache_range(from, copy_bytes); memcpy(to + sg->length - sg_remaining, from + offset, copy_bytes);