Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp4318494pxk; Tue, 29 Sep 2020 22:52:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzXQaDOA7Dzj8QHccpIkfHOyHAFQOGGVwHatZkpfjtcmE5ZJ0gqn0oUFz6MGTtFH2z88BmY X-Received: by 2002:a17:906:f0d3:: with SMTP id dk19mr1160502ejb.202.1601445135983; Tue, 29 Sep 2020 22:52:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601445135; cv=none; d=google.com; s=arc-20160816; b=AxCCUcV2oRmgQfr9okyiQ0C90q4SsxWeA255G8P+90kZjt4Jk9wOCNfzjyyxogF1HF hwUx9uG4/32ldhnml39PO+M6lw0TYGbTFOmPiLezZ/RMPSW03wtY5l0IdPuapjljN25X qgFjkwd31aAqlNsW5wWSFJliizJVHi6Igxl62xbHDcsEY69vMwM6OgyOcx4MeTG214xo GqCeUXD+XPXwqTuCiZnxvAoss1BZgc6iuTAknUBV3igS1377GrPFSgKG8aBJS2nEEd28 u7F+PT8VU1DUbWWWi55gCr2DgZfJrYus20d+sif+J+xwc1llLN5v6jBE5k81ATkMDa/2 lyMg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dmarc-filter:sender:dkim-signature; bh=csUK9uYek77Sg24Ed4HC/1KhWPMOuko9IoFtpoBEwDg=; b=rX2DPIrgoVFy+zHaqu4JI+lDSlOtM8+LpJMl91467/3FhBntgAEd9ZK35Kvz/cPfD8 3pqu9XWj+cCJD35C/MP9ziNB8MSMHhwC7GcoQ0LJX/lUBzzxKFSKYZd9skO8Oqlno3/j 8bvziHNwX4VeYkfMNIjzY4zuoHgO+pjPJepmz7CagSoLKHE0wkh2k7k3IOqpGd5OC/Az BraAvs6d1fQv7HvMsIJQVVIaGCEGOEpo8cI9zO0FNCxmLdssZ8lwKv8iEYpataD61vW9 B0YUjfanUULDq4NhHcw3hPUha2TqW4MU7+BHb3a0eT96G1ZvtTyuVmyjya4W08hdbc8q +CXA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=AdIXrrNy; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y24si514142eju.401.2020.09.29.22.51.53; Tue, 29 Sep 2020 22:52:15 -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=@mg.codeaurora.org header.s=smtp header.b=AdIXrrNy; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726637AbgI3Frv (ORCPT + 99 others); Wed, 30 Sep 2020 01:47:51 -0400 Received: from z5.mailgun.us ([104.130.96.5]:39501 "EHLO z5.mailgun.us" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725306AbgI3Fru (ORCPT ); Wed, 30 Sep 2020 01:47:50 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1601444870; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=csUK9uYek77Sg24Ed4HC/1KhWPMOuko9IoFtpoBEwDg=; b=AdIXrrNy7LC7ltEL3JmNLgsmHPAMAWZ/0N7JNdKqUel97bjwhRCkiLkLibeT9FH6Yh7gxh7Q lD+xGzQljEK1bRWGbwDUS8nGGNT9MTiUeM+iNr6zK53UTPLSotd74KtjWku+d/ZKnAAWoh+u 5iU5sp3KZtkcuMAlO40Q5uS7VpY= X-Mailgun-Sending-Ip: 104.130.96.5 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n01.prod.us-west-2.postgun.com with SMTP id 5f741c059025c3a79732cf32 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Wed, 30 Sep 2020 05:47:49 GMT Sender: vjitta=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id CAF17C433C8; Wed, 30 Sep 2020 05:47:49 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00,SPF_FAIL, URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.0 Received: from vjitta-linux.qualcomm.com (unknown [202.46.22.19]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: vjitta) by smtp.codeaurora.org (Postfix) with ESMTPSA id 9DE51C433CA; Wed, 30 Sep 2020 05:47:46 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 9DE51C433CA Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=fail smtp.mailfrom=vjitta@codeaurora.org From: vjitta@codeaurora.org To: joro@8bytes.org, iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org Cc: vinmenon@codeaurora.org, kernel-team@android.com, vjitta@codeaurora.org, robin.murphy@arm.com Subject: [PATCH v4 2/2] iommu/iova: Free global iova rcache on iova alloc failure Date: Wed, 30 Sep 2020 11:17:21 +0530 Message-Id: <1601444841-12267-2-git-send-email-vjitta@codeaurora.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1601444841-12267-1-git-send-email-vjitta@codeaurora.org> References: <1601444841-12267-1-git-send-email-vjitta@codeaurora.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Vijayanand Jitta When ever an iova alloc request fails we free the iova ranges present in the percpu iova rcaches and then retry but the global iova rcache is not freed as a result we could still see iova alloc failure even after retry as global rcache is holding the iova's which can cause fragmentation. So, free the global iova rcache as well and then go for the retry. Signed-off-by: Vijayanand Jitta --- drivers/iommu/iova.c | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/drivers/iommu/iova.c b/drivers/iommu/iova.c index c3a1a8e..64ce082 100644 --- a/drivers/iommu/iova.c +++ b/drivers/iommu/iova.c @@ -442,6 +442,7 @@ alloc_iova_fast(struct iova_domain *iovad, unsigned long size, flush_rcache = false; for_each_online_cpu(cpu) free_cpu_cached_iovas(cpu, iovad); + free_global_cached_iovas(iovad); goto retry; } @@ -1057,5 +1058,26 @@ void free_cpu_cached_iovas(unsigned int cpu, struct iova_domain *iovad) } } +/* + * free all the IOVA ranges of global cache + */ +static void free_global_cached_iovas(struct iova_domain *iovad) +{ + struct iova_rcache *rcache; + unsigned long flags; + int i, j; + + for (i = 0; i < IOVA_RANGE_CACHE_MAX_SIZE; ++i) { + rcache = &iovad->rcaches[i]; + spin_lock_irqsave(&rcache->lock, flags); + for (j = 0; j < rcache->depot_size; ++j) { + iova_magazine_free_pfns(rcache->depot[j], iovad); + iova_magazine_free(rcache->depot[j]); + rcache->depot[j] = NULL; + } + rcache->depot_size = 0; + spin_unlock_irqrestore(&rcache->lock, flags); + } +} MODULE_AUTHOR("Anil S Keshavamurthy "); MODULE_LICENSE("GPL"); -- QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation 2.7.4