From nobody Sun Mar 20 09:05:04 2022 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 C25841A291C7; Sun, 20 Mar 2022 09:05:04 +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 "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4KLsJw53ZWz3GvY; Sun, 20 Mar 2022 09:05:04 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1647767104; 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=WQKwuRw8YQRzlbHSYIL+4OMrJRNb2SWBUsIhPqUeWog=; b=rLA8AGpTfiEjyD65TY43PU88IljU+ZB2F6BdJiFMKmFSUl7H7VKsSMZilVRRSQtxfAni2N sAdWiBcLRF0F+p7VyOdLQLE3Sa4YlajGyD7aDUSrgtP+/WXSclwKrAoprvSVXfE+7Z1HfC Wk2oINzBM2drmuf9xwOMc8PRuZwOf7OT4pEoLGkykv2dhXHkH67rrr7mufhjLUatFLxjJ2 m6yHtEZAco5a1rbO7P+s5Maet0/BBmyzXxYHJXedzKkjf8pV7ysD3RiVnKOWrWEhQKmrXp I3ecUq0ZXTiHu+PfMUM8DbxYsUBRjjKa/ILMGqkB50DqPjm65alDkgGONJwHnA== 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 8D8EB24542; Sun, 20 Mar 2022 09:05:04 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.16.1/8.16.1) with ESMTP id 22K9540u028937; Sun, 20 Mar 2022 09:05:04 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.16.1/8.16.1/Submit) id 22K954QG028936; Sun, 20 Mar 2022 09:05:04 GMT (envelope-from git) Date: Sun, 20 Mar 2022 09:05:04 GMT Message-Id: <202203200905.22K954QG028936@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org From: Vincenzo Maffione Subject: git: ddb842e2ad63 - stable/13 - netmap: add a tunable for the maximum number of VALE switches 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: Sender: owner-dev-commits-src-all@freebsd.org X-BeenThere: dev-commits-src-all@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: vmaffione X-Git-Repository: src X-Git-Refname: refs/heads/stable/13 X-Git-Reftype: branch X-Git-Commit: ddb842e2ad6355f29c04387cb0f144344c859f98 Auto-Submitted: auto-generated ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1647767104; 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=WQKwuRw8YQRzlbHSYIL+4OMrJRNb2SWBUsIhPqUeWog=; b=umYuXDAaas8ooje2r8IMK/Pivi0SnIHH7emsXI31Xp6flw3x2LZtF2wsi97RSmtGCKm6kH 39bzxCE+dxsXTxBCbBA8kcHgdKSHZM2nfvEWOzEWiEkJHnYipnmUYQvvSXaxri9hw2Tin6 Q6ax0WXC3JCdX7qZKwvdmCEa/ehejZpSmMXkC7mg7udIb9G+ZQN/ePIUa2nKnUyTarO6xd C8yemSWuKCYHOwbL9GEVEVaepBIJM/nSeZZ7VK5jzr8HCUGZRPmc2vz/+sw2A+C/R3fO/v 44Qz0pz5V6nhWRCED03l94DVMOs9b2Gf3gfg1Pc9LhMqTmBkEu2E90W040lnaA== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1647767104; a=rsa-sha256; cv=none; b=w4beoAmTPBQ3kAFwe7JOL3QfQvkuT22uC5DPAzO/vi+WH9xNbiy58SGvtucMV+y0Zovx4l B2w9rbEUQ7KJs22/X9J3Z2CAJLuyRJqmLRGhTqDt936E9S/9NYjvQiBK0ZXLjLuuvkq2eL 3WSXQM4VWaFtVlCmnR9aBHJxNvjKPCfm/F6xcV4BOCXMai8nFUbE2cQYhW/+sbv2hobjB/ u04Yw3+Lc/TSrVAi9/WKQY3chtLyJ/mz7WOYHaIRt+rMVcBCKyetMS2LtOYRIY2zsW765J 9MQonHfMXjm5bBsxkjr9LDo9XWRJCke1R6SH663K+Vntj44kpf7/RYen7N7AzQ== ARC-Authentication-Results: i=1; mx1.freebsd.org; none X-ThisMailContainsUnwantedMimeParts: N The branch stable/13 has been updated by vmaffione: URL: https://cgit.FreeBSD.org/src/commit/?id=ddb842e2ad6355f29c04387cb0f144344c859f98 commit ddb842e2ad6355f29c04387cb0f144344c859f98 Author: Vincenzo Maffione AuthorDate: 2022-03-06 17:28:44 +0000 Commit: Vincenzo Maffione CommitDate: 2022-03-20 09:00:50 +0000 netmap: add a tunable for the maximum number of VALE switches The new dev.netmap.max_bridges sysctl tunable can be set in loader.conf(5) to change the default maximum number of VALE switches that can be created. Current defaults is 8. MFC after: 2 weeks (cherry picked from commit dd6ab49a9aebb5fbb85973d9a859d24daa5e2165) --- share/man/man4/netmap.4 | 7 ++++++- share/man/man4/vale.4 | 5 +++-- sys/dev/netmap/netmap_bdg.c | 4 ++-- sys/dev/netmap/netmap_kern.h | 4 +++- sys/dev/netmap/netmap_vale.c | 13 +++++++++---- 5 files changed, 23 insertions(+), 10 deletions(-) diff --git a/share/man/man4/netmap.4 b/share/man/man4/netmap.4 index d247c44b0df8..da1f5ec1592b 100644 --- a/share/man/man4/netmap.4 +++ b/share/man/man4/netmap.4 @@ -27,7 +27,7 @@ .\" .\" $FreeBSD$ .\" -.Dd October 3, 2020 +.Dd March 6, 2022 .Dt NETMAP 4 .Os .Sh NAME @@ -933,6 +933,11 @@ Batch size used when moving packets across a switch. Values above 64 generally guarantee good performance. +.It Va dev.netmap.max_bridges: 8 +Max number of +.Nm VALE +switches that can be created. This tunable can be specified +at loader time. .It Va dev.netmap.ptnet_vnet_hdr: 1 Allow ptnet devices to use virtio-net headers .El diff --git a/share/man/man4/vale.4 b/share/man/man4/vale.4 index a28114470a6e..f805b1b4031b 100644 --- a/share/man/man4/vale.4 +++ b/share/man/man4/vale.4 @@ -28,7 +28,7 @@ .\" $FreeBSD$ .\" $Id: $ .\" -.Dd February 6, 2020 +.Dd March 6, 2022 .Dt VALE 4 .Os .Sh NAME @@ -77,7 +77,8 @@ See for details on the API. .Ss LIMITS .Nm -currently supports up to 8 switches, with 254 ports per switch. +currently supports up to 254 ports per switch. The maximum +number of switches is provided by the max_bridges sysctl variable. .Sh SYSCTL VARIABLES See .Xr netmap 4 diff --git a/sys/dev/netmap/netmap_bdg.c b/sys/dev/netmap/netmap_bdg.c index 4d18859e2091..1ad540df45a9 100644 --- a/sys/dev/netmap/netmap_bdg.c +++ b/sys/dev/netmap/netmap_bdg.c @@ -1630,7 +1630,7 @@ netmap_init_bridges(void) #ifdef CONFIG_NET_NS return netmap_bns_register(); #else - nm_bridges = netmap_init_bridges2(NM_BRIDGES); + nm_bridges = netmap_init_bridges2(vale_max_bridges); if (nm_bridges == NULL) return ENOMEM; return 0; @@ -1643,6 +1643,6 @@ netmap_uninit_bridges(void) #ifdef CONFIG_NET_NS netmap_bns_unregister(); #else - netmap_uninit_bridges2(nm_bridges, NM_BRIDGES); + netmap_uninit_bridges2(nm_bridges, vale_max_bridges); #endif } diff --git a/sys/dev/netmap/netmap_kern.h b/sys/dev/netmap/netmap_kern.h index fd9db5842df3..297e4c25e641 100644 --- a/sys/dev/netmap/netmap_kern.h +++ b/sys/dev/netmap/netmap_kern.h @@ -1504,6 +1504,8 @@ int netmap_get_vale_na(struct nmreq_header *hdr, struct netmap_adapter **na, void *netmap_vale_create(const char *bdg_name, int *return_status); int netmap_vale_destroy(const char *bdg_name, void *auth_token); +extern unsigned int vale_max_bridges; + #else /* !WITH_VALE */ #define netmap_bdg_learning(_1, _2, _3, _4) 0 #define netmap_get_vale_na(_1, _2, _3, _4) 0 @@ -1551,7 +1553,7 @@ extern struct nm_bridge *nm_bridges; #define netmap_bns_get() #define netmap_bns_put(_1) #define netmap_bns_getbridges(b, n) \ - do { *b = nm_bridges; *n = NM_BRIDGES; } while (0) + do { *b = nm_bridges; *n = vale_max_bridges; } while (0) #endif /* Various prototypes */ diff --git a/sys/dev/netmap/netmap_vale.c b/sys/dev/netmap/netmap_vale.c index d32fc246bf57..f2a0524b04a2 100644 --- a/sys/dev/netmap/netmap_vale.c +++ b/sys/dev/netmap/netmap_vale.c @@ -84,10 +84,9 @@ __FBSDID("$FreeBSD$"); /* * system parameters (most of them in netmap_kern.h) - * NM_BDG_NAME prefix for switch port names, default "vale" + * NM_BDG_NAME prefix for switch port names, default "vale" * NM_BDG_MAXPORTS number of ports - * NM_BRIDGES max number of switches in the system. - * XXX should become a sysctl or tunable + * NM_BRIDGES max number of switches in the system. * * Switch ports are named valeX:Y where X is the switch name and Y * is the port. If Y matches a physical interface name, the port is @@ -115,10 +114,16 @@ __FBSDID("$FreeBSD$"); * last packet in the block may overflow the size. */ static int bridge_batch = NM_BDG_BATCH; /* bridge batch size */ + +/* Max number of vale bridges (loader tunable). */ +unsigned int vale_max_bridges = NM_BRIDGES; + SYSBEGIN(vars_vale); SYSCTL_DECL(_dev_netmap); SYSCTL_INT(_dev_netmap, OID_AUTO, bridge_batch, CTLFLAG_RW, &bridge_batch, 0, "Max batch size to be used in the bridge"); +SYSCTL_UINT(_dev_netmap, OID_AUTO, max_bridges, CTLFLAG_RDTUN, &vale_max_bridges, 0, + "Max number of vale bridges"); SYSEND; static int netmap_vale_vp_create(struct nmreq_header *hdr, struct ifnet *, @@ -364,7 +369,7 @@ netmap_vale_list(struct nmreq_header *hdr) j = req->nr_port_idx; NMG_LOCK(); - for (error = ENOENT; i < NM_BRIDGES; i++) { + for (error = ENOENT; i < vale_max_bridges; i++) { b = bridges + i; for ( ; j < NM_BDG_MAXPORTS; j++) { if (b->bdg_ports[j] == NULL)