From nobody Wed Jul 31 04:38:20 2024 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4WYfVP0rCVz5SbrV; Wed, 31 Jul 2024 04:38:21 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R11" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4WYfVN63Rsz4X3v; Wed, 31 Jul 2024 04:38:20 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1722400700; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=+V+tzJ/XrxyD4k+ZLhcE9A8GpFd0c5iEQYWdiLtgnBs=; b=EEFTlfEdGScQFwOES78VzuC+bgmpjIoIYgo5KFQFN3jwgAS4S3EDZiAgayf28OSLT+4Z+A 9gbWbNjvQSO8WNRR4RR5Q5vTh1o8ToyJjfPjQlBP2+K6xbXLNg9jrXGm5lm5CIahR/U3x/ nfMe98nJbhCZF1mtx3xRNtW4cHBddSYdpVl6c4bwOfl4udk7G9epekIqSVIBpNdDt8Cxgq J4sxE1vP0s1nYNug0I03/AifpKrlkPgj8jnuCtKCGp7h2ZZdXBYubOMTGWct0wndKYt5P7 dWGVLeSaiZ2UN14mKEXn+7wDSzbgr5zn6hO4meYT5UKuemClGrd6J72Yy1CHBg== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1722400700; a=rsa-sha256; cv=none; b=Iqytpp1i/L9VSs+TUHKX6qv1LxRaoezuyU42PZDBEWNaHr4UyWTuT7WknKSk83o+8iK0M5 gGVLwLrJRJ/KC18CVtMJfgnHu3rNuGAl78eRuYLludawX5G0tsZg3lG0BaIq6RScBeuy3k umeWbrUXjw4ECMMVctpiS3xgFS+a9PRMU7DIfn5OzZ5Frnxt6w4Gn7YCB5q2sJKVNQ17iE /HlCBr4rPJlYqoUl+wRf70ILHnw0aXgw9asAxYhwg05lSdIiFK+rF6JLMYvAKHOu7YaNes /7bvmPflOx71GtfU03s1SlOR/XfxspQV+QD3xl62DsphGSlp2GyH9KfM1li03Q== ARC-Authentication-Results: i=1; mx1.freebsd.org; none ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1722400700; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=+V+tzJ/XrxyD4k+ZLhcE9A8GpFd0c5iEQYWdiLtgnBs=; b=u/5eSO/lddviRGIqWqCoK4URyw/z4+EA4OIqG7GHAHZNNK8E8ZwB6Pxpa+RviOESBGM6t/ UGNZVGNsSs3jHlTNYQHXP+Na3Pg2AVoxn++c49J8Hw+PGlgDplVHw5gRWwwl1LQGGVP29A 70Mv+t+TarkGGBNxGeDtB5GqzzOEpX5ghpWOSL+zOuq80ceB7zsXrTrxyhH13PnF61YlzR e+ZvM692Jf5U1CRxqyb1Qi1YLOKcocIMO4BbKS/6nG7aOkIeN3q4E8d0lhnlbqLoCDb0qL nNFgV39WqITtTLCUpwjAD1V616JviSdmZ0e5ckaiNecjXcDqXMSJURgO9vbovA== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4WYfVN5dLCzn50; Wed, 31 Jul 2024 04:38:20 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.18.1/8.18.1) with ESMTP id 46V4cKv4068626; Wed, 31 Jul 2024 04:38:20 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.18.1/8.18.1/Submit) id 46V4cKOB068623; Wed, 31 Jul 2024 04:38:20 GMT (envelope-from git) Date: Wed, 31 Jul 2024 04:38:20 GMT Message-Id: <202407310438.46V4cKOB068623@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org From: Eric Joyner Subject: git: 67c30c246d16 - stable/13 - iflib: Add subinterface interrupt allocation function List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: X-BeenThere: dev-commits-src-all@freebsd.org Sender: owner-dev-commits-src-all@FreeBSD.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: erj X-Git-Repository: src X-Git-Refname: refs/heads/stable/13 X-Git-Reftype: branch X-Git-Commit: 67c30c246d16414016f96fc87dd73413de25610d Auto-Submitted: auto-generated The branch stable/13 has been updated by erj: URL: https://cgit.FreeBSD.org/src/commit/?id=67c30c246d16414016f96fc87dd73413de25610d commit 67c30c246d16414016f96fc87dd73413de25610d Author: Eric Joyner AuthorDate: 2023-01-18 00:46:39 +0000 Commit: Eric Joyner CommitDate: 2024-07-31 04:29:23 +0000 iflib: Add subinterface interrupt allocation function The ice(4) driver will add the ability to create extra interfaces that hang off of the base interface; to do that the driver requires a method for the subinterface to request hardware interrupt resources from the base interface. Signed-off-by: Eric Joyner Sponsored by: Intel Corporation Differential Revision: https://reviews.freebsd.org/D39930 (cherry picked from commit ed34a6b6eab9ea39759ccd3f12876a815d271929) --- sys/net/iflib.c | 79 +++++++++++++++++++++++++++++++++++++++++++++++++++++++-- sys/net/iflib.h | 12 +++++++++ 2 files changed, 89 insertions(+), 2 deletions(-) diff --git a/sys/net/iflib.c b/sys/net/iflib.c index ed82ff9a3d09..38e7f57823d1 100644 --- a/sys/net/iflib.c +++ b/sys/net/iflib.c @@ -1458,8 +1458,8 @@ iflib_dma_alloc_align(if_ctx_t ctx, int size, int align, iflib_dma_info_t dma, i &dma->idi_tag); if (err) { device_printf(dev, - "%s: bus_dma_tag_create failed: %d\n", - __func__, err); + "%s: bus_dma_tag_create failed: %d (size=%d, align=%d)\n", + __func__, err, size, align); goto fail_0; } @@ -6423,6 +6423,81 @@ iflib_irq_set_affinity(if_ctx_t ctx, if_irq_t irq, iflib_intr_type_t type, return (0); } +/* + * Allocate a hardware interrupt for subctx using the parent (ctx)'s hardware + * resources. + * + * Similar to iflib_irq_alloc_generic(), but for interrupt type IFLIB_INTR_RXTX + * only. + * + * XXX: Could be removed if subctx's dev has its intr resource allocation + * methods replaced with custom ones? + */ +int +iflib_irq_alloc_generic_subctx(if_ctx_t ctx, if_ctx_t subctx, if_irq_t irq, + int rid, iflib_intr_type_t type, + driver_filter_t *filter, void *filter_arg, + int qid, const char *name) +{ + device_t dev, subdev; + struct grouptask *gtask; + struct taskqgroup *tqg; + iflib_filter_info_t info; + gtask_fn_t *fn; + int tqrid, err; + driver_filter_t *intr_fast; + void *q; + + MPASS(ctx != NULL); + MPASS(subctx != NULL); + + tqrid = rid; + dev = ctx->ifc_dev; + subdev = subctx->ifc_dev; + + switch (type) { + case IFLIB_INTR_RXTX: + q = &subctx->ifc_rxqs[qid]; + info = &subctx->ifc_rxqs[qid].ifr_filter_info; + gtask = &subctx->ifc_rxqs[qid].ifr_task; + tqg = qgroup_if_io_tqg; + fn = _task_fn_rx; + intr_fast = iflib_fast_intr_rxtx; + NET_GROUPTASK_INIT(gtask, 0, fn, q); + break; + default: + device_printf(dev, "%s: unknown net intr type for subctx %s (%d)\n", + __func__, device_get_nameunit(subdev), type); + return (EINVAL); + } + + info->ifi_filter = filter; + info->ifi_filter_arg = filter_arg; + info->ifi_task = gtask; + info->ifi_ctx = q; + + NET_GROUPTASK_INIT(gtask, 0, fn, q); + + /* Allocate interrupts from hardware using parent context */ + err = _iflib_irq_alloc(ctx, irq, rid, intr_fast, NULL, info, name); + if (err != 0) { + device_printf(dev, "_iflib_irq_alloc failed for subctx %s: %d\n", + device_get_nameunit(subdev), err); + return (err); + } + + if (tqrid != -1) { + err = iflib_irq_set_affinity(ctx, irq, type, qid, gtask, tqg, q, + name); + if (err) + return (err); + } else { + taskqgroup_attach(tqg, gtask, q, dev, irq->ii_res, name); + } + + return (0); +} + int iflib_irq_alloc_generic(if_ctx_t ctx, if_irq_t irq, int rid, iflib_intr_type_t type, driver_filter_t *filter, diff --git a/sys/net/iflib.h b/sys/net/iflib.h index f9b1045266c4..f23b8138435c 100644 --- a/sys/net/iflib.h +++ b/sys/net/iflib.h @@ -402,6 +402,11 @@ typedef enum { * function. */ #define IFLIB_FEATURE_QUEUE_SELECT_V2 1301509 +/* + * Driver can create subinterfaces with their own Tx/Rx queues + * that all share a single device (or commonly, port) + */ +#define IFLIB_FEATURE_SUB_INTERFACES 1303503 /* * These enum values are used in iflib_needs_restart to indicate to iflib @@ -506,4 +511,11 @@ uint16_t iflib_get_extra_msix_vectors_sysctl(if_ctx_t ctx); if_pseudo_t iflib_clone_register(if_shared_ctx_t); void iflib_clone_deregister(if_pseudo_t); +/* + * Sub-interface support + */ +int iflib_irq_alloc_generic_subctx(if_ctx_t ctx, if_ctx_t subctx, if_irq_t irq, + int rid, iflib_intr_type_t type, + driver_filter_t *filter, void *filter_arg, + int qid, const char *name); #endif /* __IFLIB_H_ */