Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp3846420imw; Mon, 11 Jul 2022 17:40:44 -0700 (PDT) X-Google-Smtp-Source: AGRyM1tVY6hA8b6z1OTConjFAlXZfLnkg4Sgl+WUHpF9SbVB8Srwv/WzagFYfL31kWJyKihloKz1 X-Received: by 2002:a17:906:478b:b0:72b:5cd6:3f50 with SMTP id cw11-20020a170906478b00b0072b5cd63f50mr5953335ejc.514.1657586443881; Mon, 11 Jul 2022 17:40:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657586443; cv=none; d=google.com; s=arc-20160816; b=06aTqUBpV8VcfK7AQVJpzHD3NATOAmJs03O5CLizdcmaGtLO7jGcqvo3DT557S/USt dGwmwC1E399TGXXZwimBswrRzhC90tVODEf68ewuiyg3mXgBdCqlfAT8vmsTnUAwlUW5 4cKpyyRUvmz+5lfmEuXY/XsAC2Engrd/eVU0znpKPAGKEgxSF+BfbYi0FCkLrikYYHdF BwzY6C7fPeYfoEODWzTwpZUX74Z2JiVtQ/16q0MM1a29bFwnZZVXGVEf9wWcUZkelqsS Wz2kcnfrRe+lf0ZtMLJLD8VwhkhHL8Au3iQqLs2yVlALyLM8EgCZMuKfzXg6sgvPbarg omzA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=3pYM7eSvZm8Ya6KYAwZ0waJVPnpTQjUPzL3HENev0A8=; b=H5uZ0dxg94Ae9LKj047k4zD38heik7L1DEr0kppwyJvBXXZt4gANlxV2eOuUfc3ip9 o3USi6mYCXsdFLi2qfg98lJ1AMk0PFj8/X6Nf2Z69BiFGVNwpbnkX2UNSIceEzMaBsqe 4NUUr778B6lAt/dGU2OqknKgiZTHPHX2hqPBO0GUDD9sqXvBV2jkSfy4yGu6myBmp//h SQMaz8vrAAPbgnOO7pAS0YRzTYlrprYoWdH26vqDzvVLO5IZff8BabvlYDxVqYUjGPN5 xJX4d+5M1bDTMz6QSgqxpshDRUtCzfdug/pHaDTYFOclkVitZav1yeejh7KFPo66QN+A LLaA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=dzJxJV07; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hb44-20020a170907162c00b007269661baf2si12819409ejc.475.2022.07.11.17.40.11; Mon, 11 Jul 2022 17:40:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=dzJxJV07; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231867AbiGLAQ1 (ORCPT + 99 others); Mon, 11 Jul 2022 20:16:27 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49412 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231895AbiGLAPw (ORCPT ); Mon, 11 Jul 2022 20:15:52 -0400 Received: from mga03.intel.com (mga03.intel.com [134.134.136.65]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 184FB8BA99 for ; Mon, 11 Jul 2022 17:14:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1657584896; x=1689120896; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=qKKsYPnFKnFFJPzOZhVWU6Nqf98mNpvKExXx01NfN9M=; b=dzJxJV077CaU1ysDrYo1ZJ69sjV12GqISlqo3Jee/A2NfcA70MzTsxrw PhQ0tMJgdkD73KbEEMRfAl6Krx1PxLyaWn3sxeHM9/T008+H6Xb9Uotff eHoPyzb0Dn418fl6M7oltZLxD8TeOnSuzp5VXrn6uktAccPC/IkQ1ke/G J8L9WaH2MAtex5DRVJt1AWtULhZvmH87zWOz+NFvWnFz2XZ2xQMkW9l+Q hwdMnuWwbyOXBJbITUrPdzydffqPR2VcScCmhirnZVi76qG0YlJlZ6afd 3f+EzIm16u+1SE9UtOAHD0hGxwdK8LfDrRlZyCY6D/FE6pStDFV5dV+xr w==; X-IronPort-AV: E=McAfee;i="6400,9594,10405"; a="285929340" X-IronPort-AV: E=Sophos;i="5.92,264,1650956400"; d="scan'208";a="285929340" Received: from orsmga007.jf.intel.com ([10.7.209.58]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 11 Jul 2022 17:14:27 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.92,264,1650956400"; d="scan'208";a="592445865" Received: from allen-box.sh.intel.com ([10.239.159.48]) by orsmga007.jf.intel.com with ESMTP; 11 Jul 2022 17:14:14 -0700 From: Lu Baolu To: Joerg Roedel Cc: iommu@lists.linux.dev, linux-kernel@vger.kernel.org Subject: [PATCH 23/25] iommu/vt-d: Remove unnecessary check in intel_iommu_add() Date: Tue, 12 Jul 2022 08:09:06 +0800 Message-Id: <20220712000908.3431936-24-baolu.lu@linux.intel.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220712000908.3431936-1-baolu.lu@linux.intel.com> References: <20220712000908.3431936-1-baolu.lu@linux.intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.9 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The Intel IOMMU hot-add process starts from dmar_device_hotplug(). It uses the global dmar_global_lock to synchronize all the hot-add and hot-remove paths. In the hot-add path, the new IOMMU data structures are allocated firstly by dmar_parse_one_drhd() and then initialized by dmar_hp_add_drhd(). All the IOMMU units are allocated and initialized in the same synchronized path. There is no case where any IOMMU unit is created and then initialized for multiple times. This removes the unnecessary check in intel_iommu_add() which is the last reference place of the global IOMMU array. Signed-off-by: Lu Baolu Reviewed-by: Kevin Tian Reviewed-by: Steve Wahl Link: https://lore.kernel.org/r/20220702015610.2849494-5-baolu.lu@linux.intel.com --- drivers/iommu/intel/iommu.c | 3 --- 1 file changed, 3 deletions(-) diff --git a/drivers/iommu/intel/iommu.c b/drivers/iommu/intel/iommu.c index 36b3649a83e8..2f64ff6e6e75 100644 --- a/drivers/iommu/intel/iommu.c +++ b/drivers/iommu/intel/iommu.c @@ -3460,9 +3460,6 @@ static int intel_iommu_add(struct dmar_drhd_unit *dmaru) int sp, ret; struct intel_iommu *iommu = dmaru->iommu; - if (g_iommus[iommu->seq_id]) - return 0; - ret = intel_cap_audit(CAP_AUDIT_HOTPLUG_DMAR, iommu); if (ret) goto out; -- 2.25.1