lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20250912195339.20635-8-yana2bsh@gmail.com>
Date: Fri, 12 Sep 2025 22:53:30 +0300
From: Yana Bashlykova <yana2bsh@...il.com>
To: "David S. Miller" <davem@...emloft.net>
Cc: Yana Bashlykova <yana2bsh@...il.com>,
	Eric Dumazet <edumazet@...gle.com>,
	Jakub Kicinski <kuba@...nel.org>,
	Paolo Abeni <pabeni@...hat.com>,
	linux-kernel@...r.kernel.org,
	netdev@...r.kernel.org,
	lvc-project@...uxtesting.org
Subject: [PATCH 6.1 07/15] genetlink: add THIRD_GENL family

- New family with echo command
- Supports string and flag attributes
- Sysfs interface at /sys/kernel/third_genl/message

Signed-off-by: Yana Bashlykova <yana2bsh@...il.com>
---
 .../net-pf-16-proto-16-family-PARALLEL_GENL.c | 103 ++++++++++++++++++
 1 file changed, 103 insertions(+)

diff --git a/drivers/net/genetlink/net-pf-16-proto-16-family-PARALLEL_GENL.c b/drivers/net/genetlink/net-pf-16-proto-16-family-PARALLEL_GENL.c
index cdedd77b2a1b..f651159a311c 100644
--- a/drivers/net/genetlink/net-pf-16-proto-16-family-PARALLEL_GENL.c
+++ b/drivers/net/genetlink/net-pf-16-proto-16-family-PARALLEL_GENL.c
@@ -152,10 +152,13 @@ static DEFINE_MUTEX(genl_mutex);
 
 #define PARALLEL_GENL_FAMILY_NAME "PARALLEL_GENL"
 
+#define THIRD_GENL_FAMILY_NAME "THIRD_GENL"
+
 #define PATH_GENL_TEST_NUM "/sys/kernel/genl_test/value"
 #define PATH_GENL_TEST_MES "/sys/kernel/genl_test/message"
 #define PATH_GENL_TEST_DEV "/sys/kernel/genl_test/some_info"
 #define PATH_PARALLEL_GENL_MES "/sys/kernel/parallel_genl/message"
+#define PATH_THIRD_GENL_MES "/sys/kernel/third_genl/message"
 
 // TEST_GENL
 enum {
@@ -205,6 +208,8 @@ static struct genl_family my_genl_family;
 
 static struct genl_family my_genl_family_parallel;
 
+static struct genl_family third_genl_family;
+
 enum my_multicast_groups {
 	MY_MCGRP_GENL,
 };
@@ -1077,6 +1082,94 @@ static struct genl_family my_genl_family_parallel = {
 	.n_mcgrps = ARRAY_SIZE(genl_many_mcgrps_two),
 };
 
+// THIRD_GENL
+enum {
+	THIRD_GENL_ATTR_UNSPEC,
+	THIRD_GENL_ATTR_DATA,
+	THIRD_GENL_ATTR_FLAG,
+	__THIRD_GENL_ATTR_MAX,
+};
+
+#define THIRD_GENL_ATTR_MAX (__THIRD_GENL_ATTR_MAX - 1)
+
+enum {
+	THIRD_GENL_CMD_UNSPEC,
+	THIRD_GENL_CMD_ECHO,
+	__THIRD_GENL_CMD_MAX,
+};
+
+#define THIRD_GENL_CMD_MAX (__THIRD_GENL_CMD_MAX - 1)
+
+static const struct nla_policy third_genl_policy[THIRD_GENL_ATTR_MAX + 1] = {
+	[THIRD_GENL_ATTR_UNSPEC] = { .type = NLA_UNSPEC },
+	[THIRD_GENL_ATTR_DATA] = { .type = NLA_STRING },
+	[THIRD_GENL_ATTR_FLAG] = { .type = NLA_FLAG },
+};
+
+// Functions for THIRD_GENL family
+static int third_genl_echo(struct sk_buff *skb, struct genl_info *info)
+{
+	struct sk_buff *msg;
+	void *data;
+	int ret;
+	char *str;
+
+	if (info->nlhdr->nlmsg_flags & NLM_F_ECHO) {
+		msg = genlmsg_new(GENLMSG_DEFAULT_SIZE, GFP_KERNEL);
+		if (!msg)
+			return -ENOMEM;
+
+		data = genlmsg_put_reply(msg, info, &my_genl_family, 0,
+					 THIRD_GENL_CMD_ECHO);
+		if (!data)
+			goto error;
+
+		str = "Hello from THIRD_GENL!";
+		strcpy(sysfs_data.third_genl_message, str);
+
+		ret = nla_put_string(msg, THIRD_GENL_ATTR_DATA, str);
+		if (ret < 0)
+			goto error;
+
+		ret = nla_put_flag(msg, THIRD_GENL_ATTR_FLAG);
+		if (ret < 0)
+			goto error;
+
+		genlmsg_end(msg, data);
+
+		genlmsg_reply(msg, info);
+	}
+
+	return 0;
+
+error:
+	nlmsg_free(msg);
+	return -EMSGSIZE;
+}
+
+// Generic Netlink operations for THIRD_GENL family
+static const struct genl_ops third_genl_ops[] = {
+	{
+		.cmd = THIRD_GENL_CMD_ECHO,
+		.flags = 0,
+		.policy = third_genl_policy,
+		.doit = third_genl_echo,
+		.dumpit = NULL,
+	},
+};
+
+// genl_family struct for THIRD_GENL family
+static struct genl_family third_genl_family = {
+	.hdrsize = 0,
+	.name = THIRD_GENL_FAMILY_NAME,
+	.version = 1,
+	.maxattr = THIRD_GENL_ATTR_MAX,
+	.netnsok = true,
+	.ops = third_genl_ops,
+	.n_ops = ARRAY_SIZE(third_genl_ops),
+	.policy = third_genl_policy,
+};
+
 // genl_family struct with incorrect name
 static struct genl_family incorrect_genl_family = {
 	.hdrsize = 0,
@@ -1144,8 +1237,16 @@ static int __init init_netlink(void)
 		goto failure_2;
 	}
 
+	rc = genl_register_family(&third_genl_family);
+	if (rc) {
+		pr_err("%s: Failed to register Generic Netlink family\n", __func__);
+		goto failure_3;
+	}
+
 	return 0;
 
+failure_3:
+	genl_unregister_family(&my_genl_family_parallel);
 failure_2:
 	genl_unregister_family(&my_genl_family);
 failure_1:
@@ -1311,6 +1412,7 @@ static int __init module_netlink_init(void)
 err_family:
 	genl_unregister_family(&my_genl_family);
 	genl_unregister_family(&my_genl_family_parallel);
+	genl_unregister_family(&third_genl_family);
 err_sysfs:
 	sysfs_remove_file(kobj_genl_test, &my_attr_u32_genl_test.attr);
 	sysfs_remove_file(kobj_genl_test, &my_attr_str_genl_test.attr);
@@ -1330,6 +1432,7 @@ static void __exit module_netlink_exit(void)
 	netlink_unregister_notifier(&genl_notifier);
 	genl_unregister_family(&my_genl_family);
 	genl_unregister_family(&my_genl_family_parallel);
+	genl_unregister_family(&third_genl_family);
 
 	sysfs_remove_file(kobj_genl_test, &my_attr_u32_genl_test.attr);
 	sysfs_remove_file(kobj_genl_test, &my_attr_str_genl_test.attr);
-- 
2.34.1


Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ