]> Git Repo - linux.git/commitdiff
netdev: avoid CFI problems with sock priv helpers
authorJakub Kicinski <[email protected]>
Wed, 15 Jan 2025 16:14:36 +0000 (08:14 -0800)
committerPaolo Abeni <[email protected]>
Thu, 16 Jan 2025 12:15:40 +0000 (13:15 +0100)
Li Li reports that casting away callback type may cause issues
for CFI. Let's generate a small wrapper for each callback,
to make sure compiler sees the anticipated types.

Reported-by: Li Li <[email protected]>
Link: https://lore.kernel.org/CANBPYPjQVqmzZ4J=rVQX87a9iuwmaetULwbK_5_3YWk2eGzkaA@mail.gmail.com
Fixes: 170aafe35cb9 ("netdev: support binding dma-buf to netdevice")
Signed-off-by: Jakub Kicinski <[email protected]>
Reviewed-by: Mina Almasry <[email protected]>
Link: https://patch.msgid.link/[email protected]
Signed-off-by: Paolo Abeni <[email protected]>
net/core/netdev-genl-gen.c
tools/net/ynl/ynl-gen-c.py

index a89cbd8d87c3e230c34e8844e9b733799afcb87c..996ac6a449eba18416a582dcdc4de8a467766e4b 100644 (file)
@@ -197,6 +197,16 @@ static const struct genl_multicast_group netdev_nl_mcgrps[] = {
        [NETDEV_NLGRP_PAGE_POOL] = { "page-pool", },
 };
 
+static void __netdev_nl_sock_priv_init(void *priv)
+{
+       netdev_nl_sock_priv_init(priv);
+}
+
+static void __netdev_nl_sock_priv_destroy(void *priv)
+{
+       netdev_nl_sock_priv_destroy(priv);
+}
+
 struct genl_family netdev_nl_family __ro_after_init = {
        .name           = NETDEV_FAMILY_NAME,
        .version        = NETDEV_FAMILY_VERSION,
@@ -208,6 +218,6 @@ struct genl_family netdev_nl_family __ro_after_init = {
        .mcgrps         = netdev_nl_mcgrps,
        .n_mcgrps       = ARRAY_SIZE(netdev_nl_mcgrps),
        .sock_priv_size = sizeof(struct list_head),
-       .sock_priv_init = (void *)netdev_nl_sock_priv_init,
-       .sock_priv_destroy = (void *)netdev_nl_sock_priv_destroy,
+       .sock_priv_init = __netdev_nl_sock_priv_init,
+       .sock_priv_destroy = __netdev_nl_sock_priv_destroy,
 };
index d8201c4b1520995e8c36f1f0fd22be55f546f80c..6750fdb425642549b0015c30436476a0fc212781 100755 (executable)
@@ -2384,6 +2384,17 @@ def print_kernel_family_struct_src(family, cw):
     if not kernel_can_gen_family_struct(family):
         return
 
+    if 'sock-priv' in family.kernel_family:
+        # Generate "trampolines" to make CFI happy
+        cw.write_func("static void", f"__{family.c_name}_nl_sock_priv_init",
+                      [f"{family.c_name}_nl_sock_priv_init(priv);"],
+                      ["void *priv"])
+        cw.nl()
+        cw.write_func("static void", f"__{family.c_name}_nl_sock_priv_destroy",
+                      [f"{family.c_name}_nl_sock_priv_destroy(priv);"],
+                      ["void *priv"])
+        cw.nl()
+
     cw.block_start(f"struct genl_family {family.ident_name}_nl_family __ro_after_init =")
     cw.p('.name\t\t= ' + family.fam_key + ',')
     cw.p('.version\t= ' + family.ver_key + ',')
@@ -2401,9 +2412,8 @@ def print_kernel_family_struct_src(family, cw):
         cw.p(f'.n_mcgrps\t= ARRAY_SIZE({family.c_name}_nl_mcgrps),')
     if 'sock-priv' in family.kernel_family:
         cw.p(f'.sock_priv_size\t= sizeof({family.kernel_family["sock-priv"]}),')
-        # Force cast here, actual helpers take pointer to the real type.
-        cw.p(f'.sock_priv_init\t= (void *){family.c_name}_nl_sock_priv_init,')
-        cw.p(f'.sock_priv_destroy = (void *){family.c_name}_nl_sock_priv_destroy,')
+        cw.p(f'.sock_priv_init\t= __{family.c_name}_nl_sock_priv_init,')
+        cw.p(f'.sock_priv_destroy = __{family.c_name}_nl_sock_priv_destroy,')
     cw.block_end(';')
 
 
This page took 0.113309 seconds and 4 git commands to generate.