git: 20a2a59f3990 - stable/14 - libnetmap: remove interface name validation

From: Vincenzo Maffione <vmaffione_at_FreeBSD.org>
Date: Sun, 01 Sep 2024 17:57:23 UTC
The branch stable/14 has been updated by vmaffione:

URL: https://cgit.FreeBSD.org/src/commit/?id=20a2a59f3990778a82bccf0e69ce8f9d7f6a904a

commit 20a2a59f3990778a82bccf0e69ce8f9d7f6a904a
Author:     Vincenzo Maffione <vmaffione@FreeBSD.org>
AuthorDate: 2023-12-21 14:43:57 +0000
Commit:     Vincenzo Maffione <vmaffione@FreeBSD.org>
CommitDate: 2024-09-01 17:56:17 +0000

    libnetmap: remove interface name validation
    
    When trying to use a VLAN device (e.g. "em0.123") with a dot
    the library fails to parse the interface correctly. The former
    pattern is much too restrictive given that almost all characters
    can be coerced into a device name via ifconfig.
    
    Remove the particularly restrictive validation.  Some characters
    still cannot be used as an interface name as they are used as
    delimiters in the syntax, but this allows to be able to use most
    of them without an issue.
    
    Submitted by:   franco@opnsense.org
    Differential Revision:  https://reviews.freebsd.org/D42485
    Reviewed by:    vmaffione
---
 lib/libnetmap/nmreq.c | 5 -----
 1 file changed, 5 deletions(-)

diff --git a/lib/libnetmap/nmreq.c b/lib/libnetmap/nmreq.c
index 645f01abc130..2477337d8791 100644
--- a/lib/libnetmap/nmreq.c
+++ b/lib/libnetmap/nmreq.c
@@ -156,11 +156,6 @@ nmreq_header_decode(const char **pifname, struct nmreq_header *h, struct nmctx *
 	for (pipesep = vpname; pipesep != scan && !index("{}", *pipesep); pipesep++)
 		;
 
-	if (!nm_is_identifier(vpname, pipesep)) {
-		nmctx_ferror(ctx, "%s: invalid port name '%.*s'", *pifname,
-				pipesep - vpname, vpname);
-		goto fail;
-	}
 	if (pipesep != scan) {
 		pipesep++;
 		if (*pipesep == '\0') {