Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp1881327pxf; Fri, 19 Mar 2021 19:54:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJySUaDljba+iDQVVU+7i2U2fD2uOE3C2qn5mruAMqwdIwgs+XGCJmOvO74TIXg4bdM/ksg7 X-Received: by 2002:a17:906:f10c:: with SMTP id gv12mr7724405ejb.53.1616208854783; Fri, 19 Mar 2021 19:54:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616208854; cv=none; d=google.com; s=arc-20160816; b=K/fdTUt8nhNXjH4O7yyjBBa8br+Ztcz1BTAPlgfz2JgEuoCXCAYk7OHWzPAwknXjV4 aVK3nV47ZS67w4Kl4sGA2HfzbM+uJEqfsgrZeb4Fbco44EStkMREGAv7IyhHP/BiTFfa wdnanOnF9PeQfxNyY3arzCn0bmEWf1KtGNSdXE14nVXGUL3wKCIXbD9VqH29UVu8S6Cy LFOk4+XJZJANn/of2Ppmo+R0svlPzlCFqAvf3/fT3Bd5T0G1BhUDjyq5llVxcv/xIMEx rsMSp6XwDlBKPQA8vr+sfVCgepM8YYDHjIuh+Tns5ef0kz6eG0kdYeh2jdWnlFwdfAHh fw1Q== 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 :message-id:date:subject:cc:to:from:ironport-sdr:ironport-sdr; bh=9tNBebYbbjUn7S9J8R0rJMMGNJRzdX2Y7tNpE5a10kk=; b=g/zTfmSTJpsSkkFsQeFplePrDEKyFu8T9v3B2ExJHgxEl9hvgIYl/VX/7M1s5WRVnb wXLUTxjuBH2Nsbg/4mPEnG/wSO1SJyvnmZA2YB0227h1cQbdF9ODCxHac8AAJbA5PUaB LiUzcG8OAe8A3b1e2g7U5WpGj3fNKRFsGMujzzcMzJJF4Q+YS/6YLvJrpbXnoGFlrdWU uG+OeI2CRbuo2u6COXXLmDNJ8R0ZBC+yNR6of7sBtwc2KAn5QJBr3YMitOw+uUhMXShP TYcm87UdvYkvXwrmdD83N455kzGkPpgBIBFqMwmzKUWu4+06Oxt2cnn96PE3lt+cwXfx 7ojA== ARC-Authentication-Results: i=1; mx.google.com; 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id js6si5585824ejc.497.2021.03.19.19.53.43; Fri, 19 Mar 2021 19:54:14 -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; 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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229708AbhCTCwd (ORCPT + 99 others); Fri, 19 Mar 2021 22:52:33 -0400 Received: from mga04.intel.com ([192.55.52.120]:28795 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229618AbhCTCwD (ORCPT ); Fri, 19 Mar 2021 22:52:03 -0400 IronPort-SDR: M381lL2TPLkC1EJOToXKDYc/KM9+ksMzZ8p1iR/PDseloStD+hC2M9usZOILtiCFczsB6SBHET ztnjMrkOtdsQ== X-IronPort-AV: E=McAfee;i="6000,8403,9928"; a="187653548" X-IronPort-AV: E=Sophos;i="5.81,263,1610438400"; d="scan'208";a="187653548" Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 19 Mar 2021 19:52:03 -0700 IronPort-SDR: qjpDpDNx3t0xf//3uJctk11VldlRpcPSXM8m8qegIoNLYXeQEBsmmf42C8v9j/G3wBJkl7sTtk amCNsVEE9i5Q== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.81,263,1610438400"; d="scan'208";a="512686651" Received: from allen-box.sh.intel.com ([10.239.159.128]) by fmsmga001.fm.intel.com with ESMTP; 19 Mar 2021 19:52:01 -0700 From: Lu Baolu To: Joerg Roedel , Will Deacon Cc: Dave Jiang , iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org, Lu Baolu , Jacob Pan , Liu Yi L Subject: [PATCH v2 1/1] iommu/vt-d: Don't set then clear private data in prq_event_thread() Date: Sat, 20 Mar 2021 10:41:56 +0800 Message-Id: <20210320024156.640798-1-baolu.lu@linux.intel.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The VT-d specification (section 7.6) requires that the value in the Private Data field of a Page Group Response Descriptor must match the value in the Private Data field of the respective Page Request Descriptor. The private data field of a page group response descriptor is set then immediately cleared in prq_event_thread(). This breaks the rule defined by the VT-d specification. Fix it by moving clearing code up. Fixes: 5b438f4ba315d ("iommu/vt-d: Support page request in scalable mode") Cc: Jacob Pan Reviewed-by: Liu Yi L Signed-off-by: Lu Baolu --- drivers/iommu/intel/svm.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) Log: v1->v2: - v1: https://lore.kernel.org/linux-iommu/20210309004641.3809653-1-baolu.lu@linux.intel.com/ - Refine the commit title to make the affected field clear. - Refine the commit message to declare why the change matters. diff --git a/drivers/iommu/intel/svm.c b/drivers/iommu/intel/svm.c index 677d7f6b43bb..5d590d63ab52 100644 --- a/drivers/iommu/intel/svm.c +++ b/drivers/iommu/intel/svm.c @@ -1034,12 +1034,12 @@ static irqreturn_t prq_event_thread(int irq, void *d) QI_PGRP_RESP_TYPE; resp.qw1 = QI_PGRP_IDX(req->prg_index) | QI_PGRP_LPIG(req->lpig); + resp.qw2 = 0; + resp.qw3 = 0; if (req->priv_data_present) memcpy(&resp.qw2, req->priv_data, sizeof(req->priv_data)); - resp.qw2 = 0; - resp.qw3 = 0; qi_submit_sync(iommu, &resp, 1, 0); } prq_advance: -- 2.25.1