Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp319818pxj; Tue, 18 May 2021 04:16:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx25ulzlsKKzTM28YcYyCIqQmYzgA6CSsHFpZ3X3aEskN01EGljoRbjmP0tL6KaFMiY96wX X-Received: by 2002:a92:cf0f:: with SMTP id c15mr3815220ilo.288.1621336589294; Tue, 18 May 2021 04:16:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621336589; cv=none; d=google.com; s=arc-20160816; b=vqfJ/nJIE8tFJs0PIu5XwPsottNgW9/EIK0BB1MRNMGW5jhe2HwqOSKrFwhFT4ydnf TyGccxzDkjAOLUw9sNu8snfAQsW6I8cAs8GgdUhMDcZ4rYOqFB3YczKoysFmtChvNxIz 4iFaZZQR+yciZsVIeHI+B5S4n7lhucEnSoxt2m46E48Ri94afqVK2J45nSDWlCyV5oYz Cfg1v1oZwplG6fkBTTqj/outBjox57uQy4ggnxuJtYRFROErbbShZke8sVWnf8yvjzcs aqQJYdgsDzzEL11ZhQFzIQRLqd9sgwNeGRG/Qx8ubRNJ2kT2d5WjTiJGSZrKOMHi3iBQ AX5g== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=1ogUQ5u4vX4EIMvBs+3+jDjreKNPE2rhaaDJlJeSti4=; b=aUEulZ5oy3qUM1Y4tVfx64eB68ytAXmErZ0OKGVrCoOtmTfu1o7Jkjzi1vM/CSVyFc 4XQGVlvxb4DHU0hZueBFXMzdBX9HoeRZjmvWDtXN2PIMnfj6lU1WLRUC+UXB4JleDJDR 2sWajjYTDmhO7JMka2Nr8R+yR5QghakPbMC0n8aJChHkqV1D4yyuxPIh+u7nSPL3b8/W Dd/zmYDR2vC+D2tr7wpo5xPfGxGcy5vt+GgDGRN6hnMBe4Euy/2sMGGLFzNyHv5G+JT0 8gA7WCvuRJrmv3+HTrsp2pD5x8WlO7XkM8F2hRuwFADn4kp2RJwKERyIMcICiPFABVkM 5A9w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Y293pgkm; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v8si21958135ilu.72.2021.05.18.04.16.16; Tue, 18 May 2021 04:16:29 -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=@linuxfoundation.org header.s=korg header.b=Y293pgkm; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243479AbhEQPRT (ORCPT + 99 others); Mon, 17 May 2021 11:17:19 -0400 Received: from mail.kernel.org ([198.145.29.99]:47632 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242394AbhEQPGy (ORCPT ); Mon, 17 May 2021 11:06:54 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 02B7961C24; Mon, 17 May 2021 14:29:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1621261752; bh=Y+SWSglp076Y+h3TizzZinyQt/cP+d5bvvUCU2vhjTo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Y293pgkmzqG9t1dxDhazc2kBORZ3kVZdIf7dJPAC56rmSrUQ7s9cfQkf3xkRbMrrE pN4LHgoh/8Ku5arZshaojv+D1XeFB1GCFOeIqnNTLHQfX/B/HzF251lSHqNAlfbD4/ 6ZZ2OMnyxB69SnFOh4ASe2UDPCNkXZGuQPj8T1zE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jason Gunthorpe , Dave Jiang , Vinod Koul , Sasha Levin Subject: [PATCH 5.11 159/329] dmaengine: idxd: use ida for device instance enumeration Date: Mon, 17 May 2021 16:01:10 +0200 Message-Id: <20210517140307.516061233@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210517140302.043055203@linuxfoundation.org> References: <20210517140302.043055203@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Dave Jiang [ Upstream commit f7f7739847bd68b3c3103fd1b50d943038bd14c7 ] The idr is only used for an device id, never to lookup context from that id. Switch to plain ida. Fixes: bfe1d56091c1 ("dmaengine: idxd: Init and probe for Intel data accelerators") Reported-by: Jason Gunthorpe Signed-off-by: Dave Jiang Link: https://lore.kernel.org/r/161852984730.2203940.15032482460902003819.stgit@djiang5-desk3.ch.intel.com Signed-off-by: Vinod Koul Signed-off-by: Sasha Levin --- drivers/dma/idxd/init.c | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/drivers/dma/idxd/init.c b/drivers/dma/idxd/init.c index d223242a34f4..6e97a9870ba8 100644 --- a/drivers/dma/idxd/init.c +++ b/drivers/dma/idxd/init.c @@ -30,8 +30,7 @@ MODULE_AUTHOR("Intel Corporation"); bool support_enqcmd; -static struct idr idxd_idrs[IDXD_TYPE_MAX]; -static DEFINE_MUTEX(idxd_idr_lock); +static struct ida idxd_idas[IDXD_TYPE_MAX]; static struct pci_device_id idxd_pci_tbl[] = { /* DSA ver 1.0 platforms */ @@ -342,12 +341,10 @@ static int idxd_probe(struct idxd_device *idxd) dev_dbg(dev, "IDXD interrupt setup complete.\n"); - mutex_lock(&idxd_idr_lock); - idxd->id = idr_alloc(&idxd_idrs[idxd->type], idxd, 0, 0, GFP_KERNEL); - mutex_unlock(&idxd_idr_lock); + idxd->id = ida_alloc(&idxd_idas[idxd->type], GFP_KERNEL); if (idxd->id < 0) { rc = -ENOMEM; - goto err_idr_fail; + goto err_ida_fail; } idxd->major = idxd_cdev_get_major(idxd); @@ -355,7 +352,7 @@ static int idxd_probe(struct idxd_device *idxd) dev_dbg(dev, "IDXD device %d probed successfully\n", idxd->id); return 0; - err_idr_fail: + err_ida_fail: idxd_mask_error_interrupts(idxd); idxd_mask_msix_vectors(idxd); err_setup: @@ -512,9 +509,7 @@ static void idxd_remove(struct pci_dev *pdev) idxd_shutdown(pdev); if (device_pasid_enabled(idxd)) idxd_disable_system_pasid(idxd); - mutex_lock(&idxd_idr_lock); - idr_remove(&idxd_idrs[idxd->type], idxd->id); - mutex_unlock(&idxd_idr_lock); + ida_free(&idxd_idas[idxd->type], idxd->id); } static struct pci_driver idxd_pci_driver = { @@ -544,7 +539,7 @@ static int __init idxd_init_module(void) support_enqcmd = true; for (i = 0; i < IDXD_TYPE_MAX; i++) - idr_init(&idxd_idrs[i]); + ida_init(&idxd_idas[i]); err = idxd_register_bus_type(); if (err < 0) -- 2.30.2