Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp643630yba; Wed, 24 Apr 2019 07:21:25 -0700 (PDT) X-Google-Smtp-Source: APXvYqzTzZAr8zqRsfFcMJsJQ4CjOKRmkvwgVyXSGItu4CJ+EvI6rbvFdoWreKjEQUEsDhtwTVz+ X-Received: by 2002:a63:6a42:: with SMTP id f63mr30931518pgc.207.1556115685590; Wed, 24 Apr 2019 07:21:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556115685; cv=none; d=google.com; s=arc-20160816; b=0O3NXR4q360wAyerG+Ky0WNTf9l+iSYx/TDBcKPjiaPWEt38gy3gd4cVQ27F8UGKlm B2YBNvUwweC+e9I0Cvl95Anuk/YMBtGsBr2zhY3bi1uNQ+7AX4TvEJr431Io3a6S4Dtj VDHqtxelOOPsVQoOBRVCquGBcVtSqQLT7EOFGUbLsY/qPXqDvywbExKk+p2jvwSKdI+q K7suBx1CSoxW6qOFVjzCtUnrkiZI3Cqa563rVnlFS6fv5vmK7OSSRhnL6PhiCbh/gDab AAr4tWofAwkPBl4jxIuaj6hFtffomNM4ifRA4ppJgVNvjMslF/LnrC4yOnfbKR3TV9hF PBLQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=GEXaBMD3U4sWuwXoHlsxPa0R20Q7P10dRF3KDQL2tvo=; b=y/RGRWQuncH9S6l2kJLvSlcjUGUhd6MTOL3kiQhNgIXRCzNVRVNHXqXxel9dJzaHVk Dy8d0gf+G7IFbUI/JP1iog4WSbwrtnS7VNulrFxATTCJNjQFkiXJ7pTmA2xCLyvYBG7C rJEpylgpGn4rnbYldSrUTCLXyuM/yUBRvwaXYdfZCGwAVarqlbN9ekJygUKuwilLg5Qb tSDvZ1ZOSsKJxpPz1v6x+OUESUSoNhi4ELWnzyUCFIn6i9wTrLNeMMTtr4zOz4enhEZw 5c3jrzkmbWEddRh/vYB40asJTh4yi7LTxNKGFUQSIavDE+QS+xWF8t1JMRsaFYgrYSI1 XQDA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@arista.com header.s=googlenew header.b="MZCe//Am"; 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; dmarc=pass (p=QUARANTINE sp=REJECT dis=NONE) header.from=arista.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t1si18465996pgi.330.2019.04.24.07.21.09; Wed, 24 Apr 2019 07:21:25 -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=@arista.com header.s=googlenew header.b="MZCe//Am"; 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; dmarc=pass (p=QUARANTINE sp=REJECT dis=NONE) header.from=arista.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728860AbfDXOUE (ORCPT + 99 others); Wed, 24 Apr 2019 10:20:04 -0400 Received: from mail-ed1-f68.google.com ([209.85.208.68]:42321 "EHLO mail-ed1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725935AbfDXOUE (ORCPT ); Wed, 24 Apr 2019 10:20:04 -0400 Received: by mail-ed1-f68.google.com with SMTP id u23so15757413eds.9 for ; Wed, 24 Apr 2019 07:20:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arista.com; s=googlenew; h=from:to:cc:subject:date:message-id; bh=GEXaBMD3U4sWuwXoHlsxPa0R20Q7P10dRF3KDQL2tvo=; b=MZCe//Am5X21XLFVYlr3pytX7fCBJ/q1M912/aF3gzt4UqSFUTgrB26DmfRZYqceQg ygy/yVUZWBxf8ANuZE1PuNElLSzIaZbCIEpWYbP06zULQ4fX5tKg2wOTL0a1fwJ3qUW3 ok/Zr+2hDDlnIP+y1tFT51fKLh1DCYiw59PETX6diQDrGd8nKeveMN016v/vbZFXqWML BSTQVwx0kDW7Ma0T9wVtKm7GiNxNScSDGYfHxZVm1U6aqFLgbIqYoayPy66QFWxaMc2j I0r0NSmw29K0e7nY06nyM0Ja5ZATnurmdkCgnNWs/gn32j3oOqpIXitKVpuU+EF1xZmc t63w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=GEXaBMD3U4sWuwXoHlsxPa0R20Q7P10dRF3KDQL2tvo=; b=ubxpKxHQBpqAYVPfBoG6q1cru49AxpYHiCfpddNM0P+BtktFtpz6dQHj+G4o+xMtuR sYvUpQGpg+TnQFyhWO4BXUWBSnIwZkYvNVP9LZfakEL4OlflUn9EpqHRvs3YTfmRe9zg RbzxHR2/iQEWkMbY7eMgdWUpx/b5R5zNDe+KcbQzTKr9e4eoRBJkJXzkqGXvtC8Yh1re +SG2zDamKGEoOR+m3s9TXoTA7TWzh6weBfDkKJqS7qrstXjfkK96nYTvPgsnkIOLde27 igY0lKGyO7zdvnX7ELM/DWFobxHyWv1GqUdzbK+o+sAUZK2FgeZP9dXjN1waWzOBF5/U xQ/w== X-Gm-Message-State: APjAAAWEL2YKsEaJOFrVDhdmHWKolsxnLCSYUXiSqISQXHYv6Ba5i6vy mol21QgZR9e361D/4kxcHngJ9g== X-Received: by 2002:aa7:d50a:: with SMTP id y10mr20113750edq.261.1556115602709; Wed, 24 Apr 2019 07:20:02 -0700 (PDT) Received: from linux-ThinkPad-X1-Carbon-5th.Hitronhub.home ([89.100.89.87]) by smtp.gmail.com with ESMTPSA id r24sm1582159ejo.84.2019.04.24.07.20.01 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 24 Apr 2019 07:20:02 -0700 (PDT) From: Tom Murphy To: iommu@lists.linux-foundation.org Cc: murphyt7@tcd.ie, Tom Murphy , Joerg Roedel , linux-kernel@vger.kernel.org Subject: [PATCH] iommu/amd: flush not present cache in iommu_map_page Date: Wed, 24 Apr 2019 15:18:59 +0100 Message-Id: <20190424141900.8883-1-tmurphy@arista.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org check if there is a not-present cache present and flush it if there is. Signed-off-by: Tom Murphy --- drivers/iommu/amd_iommu.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/drivers/iommu/amd_iommu.c b/drivers/iommu/amd_iommu.c index f7cdd2ab7f11..8ef43224aae0 100644 --- a/drivers/iommu/amd_iommu.c +++ b/drivers/iommu/amd_iommu.c @@ -1636,6 +1636,12 @@ static int iommu_map_page(struct protection_domain *dom, pte[i] = __pte; update_domain(dom); + if (!dom->updated) { + if (unlikely(amd_iommu_np_cache)) { + domain_flush_pages(dom, bus_addr, page_size); + domain_flush_complete(dom); + } + } /* Everything flushed out, free pages now */ free_page_list(freelist); -- 2.17.1