Received: by 2002:a25:2c96:0:0:0:0:0 with SMTP id s144csp1048182ybs; Mon, 25 May 2020 06:05:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyD+glEnjlElPHodu+X47lFXWYHplWhBz1Cy740M+EtulOHbTXxjNEoLUVfKE6ME6smlhNr X-Received: by 2002:a17:906:c7d1:: with SMTP id dc17mr19906197ejb.166.1590411952961; Mon, 25 May 2020 06:05:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590411952; cv=none; d=google.com; s=arc-20160816; b=PJQpieqH4HdTjX4Vl5yGihgDeB4SSyUA/tokJ+daLyeBVESRMGc0dN1YFf1KuJzTGs DL/4X+GeKu3FAnWEB6a4hSdnk24xDBSOQ8yKZe/dPi1mC66KlXnzyN+tmyoJ6wzrUdka YoIiXXJ4ZKHnWZyB2Z/CBCQOt2aLHMVbDlxWmI3HYm7GfMKNZ8z7lTlgudnnkl/V8ANG okR0OkeIiMZYu/d5YaANyWqEjXCjg1cBvWz3X9yqC4S3gcUDeUq+BWZ0jEr1XG0uVdo6 04PKy/r6h8YzSdrezw/+aUuIs8xVabcSTh4g1J0FehXIUe4ss7U7VsLGzqqx5cfYpLpz qtfA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=hQesnJAs8lyBhgm+n3Eh652Ou0VEyS/FbVga6u9aDKA=; b=ibfaKavSoJN/wFBt2nFfmcLtYorfXdkuFRMjYJlhy+567RGKAVM3weTeFiUjchc8cC 07gZOCKE/kvbAkrN1sNf79wAPJiApbtHf8iX1FV8rQ+NzjdU87WF8eU/9wyiIcO03mKO 0ggaVITSR3Dw9g7Xtw7x19IJPFMuEIofIRFX3YNMX2p6dFr/ln6s3WB9LSbSE3BLz3cC T7FLdIXCxgX3p+q2Tl9HgP5vXrixOy4qNvtJqQ9hosF4fP+XUZxI1eVBSHxoW2OtyZJE y1upznuQ32zkjbPqFojJsQkSwPLDSUtejtEPw9Tu4TjoqAgeTJjIB4/9Wv2Ge5Tc1vtb oBeQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 96si9612740edq.298.2020.05.25.06.05.29; Mon, 25 May 2020 06:05:52 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390723AbgEYNC6 (ORCPT + 99 others); Mon, 25 May 2020 09:02:58 -0400 Received: from mx2.suse.de ([195.135.220.15]:33362 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388757AbgEYNC5 (ORCPT ); Mon, 25 May 2020 09:02:57 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id 17DBFACDB; Mon, 25 May 2020 13:02:58 +0000 (UTC) Date: Mon, 25 May 2020 15:02:53 +0200 From: Joerg Roedel To: Sai Prakash Ranjan Cc: Will Deacon , Robin Murphy , Joerg Roedel , iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Evan Green , Douglas Anderson Subject: Re: [PATCH] iommu: Fix group refcount in iommu_alloc_default_domain() Message-ID: <20200525130253.GH5075@suse.de> References: <20200522130145.30067-1-saiprakash.ranjan@codeaurora.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200522130145.30067-1-saiprakash.ranjan@codeaurora.org> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On Fri, May 22, 2020 at 06:31:45PM +0530, Sai Prakash Ranjan wrote: > diff --git a/drivers/iommu/iommu.c b/drivers/iommu/iommu.c > index a4c2f122eb8b..05f7b77c432f 100644 > --- a/drivers/iommu/iommu.c > +++ b/drivers/iommu/iommu.c > @@ -1491,6 +1491,7 @@ static int iommu_alloc_default_domain(struct device *dev) > { > struct iommu_group *group; > unsigned int type; > + int ret; > > group = iommu_group_get(dev); > if (!group) > @@ -1501,7 +1502,11 @@ static int iommu_alloc_default_domain(struct device *dev) > > type = iommu_get_def_domain_type(dev); > > - return iommu_group_alloc_default_domain(dev->bus, group, type); > + ret = iommu_group_alloc_default_domain(dev->bus, group, type); > + > + iommu_group_put(group); > + > + return ret; > } > > /** Thanks for the report and the fix. I think it is better to fix this by not taking a group reference in iommu_alloc_default_domain() at all and pass group as a parameter. Please see the patch I just sent out. Regards, Joerg