Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3044366pxf; Mon, 5 Apr 2021 01:23:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzlyoURTnqxUl9J+bXCu/WtcsrJ1WK8slx4+iv13il6ZxQQpFQm/x6gXJVo3im0PwStwLA/ X-Received: by 2002:a50:ed90:: with SMTP id h16mr29936902edr.101.1617611029117; Mon, 05 Apr 2021 01:23:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617611029; cv=none; d=google.com; s=arc-20160816; b=NTLLGvK/s/rupiARPD582Il1lNiLf3/r4xlRXs9k87eTS97Q35hlAdmVPDUaowoSXm WUVxwUkH7Jccx8eEyW1dhbEGX+qNLtxxml+sLXBSIIvdrRiqujKjzA6G8SHlk6LYNIAZ Lw9tl9dO8jF/D7YDu9Ep7/Ky3HFOJDdbpK49mKOhg1yI8ovMxLWJi/tlWI2s6XbowW5/ DG5nnibn/gIvbIf+5aFij99Kh5CMUC6QejXHwQq7KS68DmEvydN484TbPCFc3YCsVuhM Sw6FRK/boWNLPZihXxB/sxmlHUaBTmslLxwE3WBK7HZGnHOGDcBOTrra2eUydJ/ML/SQ QJfQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=IllAWTlByjnUDMPrbBdicSIRjER11MckY9g1Tlavi8g=; b=AtodyXBUG1xN6pp8JEB/JMtnyWQ+aTEc3dMUddr5fLkDUKBx55/MJMI+1aC3r3zwVp 2H20gufJ2ahm1/mhR3Lxr+lKP3obDqxHnk9zRvMtGVOZ15U2janDY8QvW9q8gVCuG3OO thszz5gp19/S128r/s9wlmqFnDRFFZ1fDgTa/MP544Z3o/pumfuh4dMvAn1RmmWdDOUi TiDYr+ZCmJrQpxQBHb/IIUaNtzObQRFucKCZYuUsCu7i4lbItR71sA0mvLvSHrjheAlH iDViMA3XwAciS2iwUgNuSQWprFYf5a2+chCDjosQ1lExaMg4da5nUjcNH3fshJgV/AZd FiRQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amazon.com header.s=amazon201209 header.b=hndZNfFt; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amazon.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id eb13si13325411edb.223.2021.04.05.01.23.26; Mon, 05 Apr 2021 01:23:49 -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=@amazon.com header.s=amazon201209 header.b=hndZNfFt; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amazon.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232133AbhDEGVE (ORCPT + 99 others); Mon, 5 Apr 2021 02:21:04 -0400 Received: from smtp-fw-4101.amazon.com ([72.21.198.25]:14366 "EHLO smtp-fw-4101.amazon.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229454AbhDEGVD (ORCPT ); Mon, 5 Apr 2021 02:21:03 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amazon.com; i=@amazon.com; q=dns/txt; s=amazon201209; t=1617603659; x=1649139659; h=subject:to:cc:references:from:message-id:date: mime-version:in-reply-to:content-transfer-encoding; bh=IllAWTlByjnUDMPrbBdicSIRjER11MckY9g1Tlavi8g=; b=hndZNfFtp/TFS1Z+8GWNI6kPThiNTqhGDlLLc/h7NGDMKI6iZ3NxkfSm AnCZVz7FGrsE6HEbQRlGqtqMXsy1irxp3L2zqCNw6WnLmKIAoGmQVx78B F/SJhDT3Zo2wH5zyF62DUJSjVyPueo7r8wmuMp3TYzkdJgcH/dHFcWEAp s=; X-IronPort-AV: E=Sophos;i="5.81,305,1610409600"; d="scan'208";a="99090077" Received: from iad12-co-svc-p1-lb1-vlan2.amazon.com (HELO email-inbound-relay-1a-821c648d.us-east-1.amazon.com) ([10.43.8.2]) by smtp-border-fw-out-4101.iad4.amazon.com with ESMTP; 05 Apr 2021 06:20:51 +0000 Received: from EX13D19EUB003.ant.amazon.com (iad12-ws-svc-p26-lb9-vlan3.iad.amazon.com [10.40.163.38]) by email-inbound-relay-1a-821c648d.us-east-1.amazon.com (Postfix) with ESMTPS id 7A7F4A1E03; Mon, 5 Apr 2021 06:20:45 +0000 (UTC) Received: from 8c85908914bf.ant.amazon.com (10.43.162.239) by EX13D19EUB003.ant.amazon.com (10.43.166.69) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Mon, 5 Apr 2021 06:20:38 +0000 Subject: Re: [PATCH rdma-next 1/8] RDMA/core: Check if client supports IB device or not To: Leon Romanovsky , Doug Ledford , Jason Gunthorpe CC: Parav Pandit , "David S. Miller" , Dennis Dalessandro , Jakub Kicinski , Karsten Graul , , , , Mike Marciniszyn , , , Santosh Shilimkar References: <20210405055000.215792-1-leon@kernel.org> <20210405055000.215792-2-leon@kernel.org> From: Gal Pressman Message-ID: <43f5eb80-55b9-722b-1006-23d823108eb1@amazon.com> Date: Mon, 5 Apr 2021 09:20:32 +0300 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:78.0) Gecko/20100101 Thunderbird/78.9.0 MIME-Version: 1.0 In-Reply-To: <20210405055000.215792-2-leon@kernel.org> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.43.162.239] X-ClientProxiedBy: EX13D44UWC004.ant.amazon.com (10.43.162.209) To EX13D19EUB003.ant.amazon.com (10.43.166.69) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/04/2021 8:49, Leon Romanovsky wrote: > From: Parav Pandit > > RDMA devices are of different transport(iWarp, IB, RoCE) and have > different attributes. > Not all clients are interested in all type of devices. > > Implement a generic callback that each IB client can implement to decide > if client add() or remove() should be done by the IB core or not for a > given IB device, client combination. > > Signed-off-by: Parav Pandit > Signed-off-by: Leon Romanovsky > --- > drivers/infiniband/core/device.c | 3 +++ > include/rdma/ib_verbs.h | 9 +++++++++ > 2 files changed, 12 insertions(+) > > diff --git a/drivers/infiniband/core/device.c b/drivers/infiniband/core/device.c > index c660cef66ac6..c9af2deba8c1 100644 > --- a/drivers/infiniband/core/device.c > +++ b/drivers/infiniband/core/device.c > @@ -691,6 +691,9 @@ static int add_client_context(struct ib_device *device, > if (!device->kverbs_provider && !client->no_kverbs_req) > return 0; > > + if (client->is_supported && !client->is_supported(device)) > + return 0; Isn't it better to remove the kverbs_provider flag (from previous if statement) and unify it with this generic support check?