Received: by 2002:a5d:925a:0:0:0:0:0 with SMTP id e26csp1411234iol; Sun, 12 Jun 2022 15:49:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwhdE4wMDxIluKQNslnNj513WRotdlDBFi17nfqq9o78rtTrefDnVE+3DbkxhklJoSH///M X-Received: by 2002:a17:906:af0d:b0:708:d48a:271 with SMTP id lx13-20020a170906af0d00b00708d48a0271mr50672982ejb.329.1655074171267; Sun, 12 Jun 2022 15:49:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655074171; cv=none; d=google.com; s=arc-20160816; b=WPhleozBeIOIFpp7aqHn5s7QORfaThYRS/IihQO3TlnV7zYrgirtSzCNQM2uQdoaM7 EJfZI5ZSYulqLkudQVODmyt5fgzSpmH8XMQZG16wjfpXPLSZgblhvp0RjIRvItXT2rZQ sUgrR8dTw5Vh4LwOIG98BWHhDB/IqgQCel1LPjNvyaj02NO+IBxnB6/v+48XGxGYIxix y+4Ln4D2k8WurEWe7JrzI0P2B3xu+P8IxYnmZk2pvtOkX7B05jLj4d4/ls4LKjsCymQP ZepST2C/24uF25LiPtCQo7O6xXaxrGUEZBMcPqGGOzez5mwjEniOmY6mrVgTJuDMHvDJ /9BQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:reply-to:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:dkim-filter; bh=HmE3yStdCPEAS6wUO5BsxoUHsQSxeQL72W//rVfgedU=; b=eVEz8ApiEYsH05jJ7TkL1fjLu7bzj53z6Qq6ddsTESQnzWk3eDkRZkE5BnhbXkAy1g buHd5ebGv8QAHD7jrQyMtmwMWiSFaOY+2rur20nDx0FJHPgf+9T5UzZUxRbDejgGvVSc Hq8RQ9jghY/UUlsjnXrfjWLJ6ETN6Kx03RC1E2WbF+Kp9kyaQdQjwb2LjoaIaKZYeVPO UiOpVHSQS0nhG3k2y4jA9GnLXFp5GWOyEyYhCt/O87MOKD9ySPFRMLNw1x5+dv82Wjs4 RcJy1ztXLVeyDsRQjgHCkxJX54mEe8wj+sX71H+ecljg1aJYMJqBNIcmzisVBgBxLk6d I7cA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxonhyperv.com header.s=default header.b=rl0OMU26; 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=linuxonhyperv.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hc9-20020a170907168900b0071576eb9e6bsi5699743ejc.211.2022.06.12.15.49.06; Sun, 12 Jun 2022 15:49:31 -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=@linuxonhyperv.com header.s=default header.b=rl0OMU26; 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=linuxonhyperv.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235633AbiFLVPU (ORCPT + 99 others); Sun, 12 Jun 2022 17:15:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34302 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235735AbiFLVPK (ORCPT ); Sun, 12 Jun 2022 17:15:10 -0400 Received: from linux.microsoft.com (linux.microsoft.com [13.77.154.182]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 255A713CCA; Sun, 12 Jun 2022 14:15:10 -0700 (PDT) Received: by linux.microsoft.com (Postfix, from userid 1004) id D9C0120C14C9; Sun, 12 Jun 2022 14:15:09 -0700 (PDT) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com D9C0120C14C9 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linuxonhyperv.com; s=default; t=1655068509; bh=HmE3yStdCPEAS6wUO5BsxoUHsQSxeQL72W//rVfgedU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:Reply-To:From; b=rl0OMU26pOTg3EoadpQQ3gX0j9IjF2yKSFQqHLaErWZj0xq/OUJn968EiJJxorLhG GNJY4bT7TBjlAq7k5RyCZL59ToW41P9Ug3jqY9SldGqav9aEQaMH15Alch28rEY8Jq OgYM/INa1FCmcWrx9iNBuOjtFcUxDIREHnJJ2CRk= From: longli@linuxonhyperv.com To: "K. Y. Srinivasan" , Haiyang Zhang , Stephen Hemminger , Wei Liu , Dexuan Cui , "David S. Miller" , Jakub Kicinski , Paolo Abeni , Jason Gunthorpe , Leon Romanovsky , edumazet@google.com, shiraz.saleem@intel.com, Ajay Sharma Cc: linux-hyperv@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-rdma@vger.kernel.org, Long Li Subject: [Patch v3 03/12] net: mana: Handle vport sharing between devices Date: Sun, 12 Jun 2022 14:14:45 -0700 Message-Id: <1655068494-16440-4-git-send-email-longli@linuxonhyperv.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1655068494-16440-1-git-send-email-longli@linuxonhyperv.com> References: <1655068494-16440-1-git-send-email-longli@linuxonhyperv.com> Reply-To: longli@microsoft.com X-Spam-Status: No, score=-11.6 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, RCVD_IN_DNSWL_MED,SPF_HELO_PASS,SPF_PASS,T_SCC_BODY_TEXT_LINE, USER_IN_DEF_SPF_WL 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 From: Long Li For outgoing packets, the PF requires the VF to configure the vport with corresponding protection domain and doorbell ID for the kernel or user context. The vport can't be shared between different contexts. Implement the logic to exclusively take over the vport by either the Ethernet device or RDMA device. Signed-off-by: Long Li --- Change log: v2: use refcount instead of directly using atomic variables drivers/net/ethernet/microsoft/mana/mana.h | 4 +++ drivers/net/ethernet/microsoft/mana/mana_en.c | 27 +++++++++++++++++-- 2 files changed, 29 insertions(+), 2 deletions(-) diff --git a/drivers/net/ethernet/microsoft/mana/mana.h b/drivers/net/ethernet/microsoft/mana/mana.h index 51bff91b63ee..6aacbf42aeaf 100644 --- a/drivers/net/ethernet/microsoft/mana/mana.h +++ b/drivers/net/ethernet/microsoft/mana/mana.h @@ -375,6 +375,7 @@ struct mana_port_context { unsigned int num_queues; mana_handle_t port_handle; + refcount_t port_use_count; u16 port_idx; @@ -567,4 +568,7 @@ struct mana_adev { struct gdma_dev *mdev; }; +int mana_cfg_vport(struct mana_port_context *apc, u32 protection_dom_id, + u32 doorbell_pg_id); +void mana_uncfg_vport(struct mana_port_context *apc); #endif /* _MANA_H */ diff --git a/drivers/net/ethernet/microsoft/mana/mana_en.c b/drivers/net/ethernet/microsoft/mana/mana_en.c index 745a9783dd70..839f7099ac2d 100644 --- a/drivers/net/ethernet/microsoft/mana/mana_en.c +++ b/drivers/net/ethernet/microsoft/mana/mana_en.c @@ -530,13 +530,26 @@ static int mana_query_vport_cfg(struct mana_port_context *apc, u32 vport_index, return 0; } -static int mana_cfg_vport(struct mana_port_context *apc, u32 protection_dom_id, - u32 doorbell_pg_id) +void mana_uncfg_vport(struct mana_port_context *apc) +{ + refcount_dec(&apc->port_use_count); +} +EXPORT_SYMBOL_GPL(mana_uncfg_vport); + +int mana_cfg_vport(struct mana_port_context *apc, u32 protection_dom_id, + u32 doorbell_pg_id) { struct mana_config_vport_resp resp = {}; struct mana_config_vport_req req = {}; int err; + /* Ethernet driver and IB driver can't take the port at the same time */ + refcount_inc(&apc->port_use_count); + if (refcount_read(&apc->port_use_count) > 2) { + refcount_dec(&apc->port_use_count); + return -ENODEV; + } + mana_gd_init_req_hdr(&req.hdr, MANA_CONFIG_VPORT_TX, sizeof(req), sizeof(resp)); req.vport = apc->port_handle; @@ -563,9 +576,13 @@ static int mana_cfg_vport(struct mana_port_context *apc, u32 protection_dom_id, apc->tx_shortform_allowed = resp.short_form_allowed; apc->tx_vp_offset = resp.tx_vport_offset; + + netdev_info(apc->ndev, "Configured vPort %llu PD %u DB %u\n", + apc->port_handle, protection_dom_id, doorbell_pg_id); out: return err; } +EXPORT_SYMBOL_GPL(mana_cfg_vport); static int mana_cfg_vport_steering(struct mana_port_context *apc, enum TRI_STATE rx, @@ -626,6 +643,9 @@ static int mana_cfg_vport_steering(struct mana_port_context *apc, resp.hdr.status); err = -EPROTO; } + + netdev_info(ndev, "Configured steering vPort %llu entries %u\n", + apc->port_handle, num_entries); out: kfree(req); return err; @@ -1678,6 +1698,8 @@ static void mana_destroy_vport(struct mana_port_context *apc) } mana_destroy_txq(apc); + + mana_uncfg_vport(apc); } static int mana_create_vport(struct mana_port_context *apc, @@ -1928,6 +1950,7 @@ static int mana_probe_port(struct mana_context *ac, int port_idx, apc->num_queues = gc->max_num_queues; apc->port_handle = INVALID_MANA_HANDLE; apc->port_idx = port_idx; + refcount_set(&apc->port_use_count, 1); ndev->netdev_ops = &mana_devops; ndev->ethtool_ops = &mana_ethtool_ops; -- 2.17.1