netfilter: nf_tables: avoid retpoline overhead for objref calls
authorFlorian Westphal <fw@strlen.de>
Tue, 3 Jan 2023 12:47:16 +0000 (13:47 +0100)
committerFlorian Westphal <fw@strlen.de>
Wed, 18 Jan 2023 12:05:25 +0000 (13:05 +0100)
objref expression is builtin, so avoid calls to it for
RETOLINE=y builds.

Signed-off-by: Florian Westphal <fw@strlen.de>
include/net/netfilter/nf_tables_core.h
net/netfilter/nf_tables_core.c
net/netfilter/nft_objref.c

index 3e82538..bedef37 100644 (file)
@@ -164,4 +164,8 @@ void nft_payload_inner_eval(const struct nft_expr *expr, struct nft_regs *regs,
                            const struct nft_pktinfo *pkt,
                            struct nft_inner_tun_ctx *ctx);
 
+void nft_objref_eval(const struct nft_expr *expr, struct nft_regs *regs,
+                    const struct nft_pktinfo *pkt);
+void nft_objref_map_eval(const struct nft_expr *expr, struct nft_regs *regs,
+                        const struct nft_pktinfo *pkt);
 #endif /* _NET_NF_TABLES_CORE_H */
index 0f26d00..d999290 100644 (file)
@@ -234,6 +234,8 @@ static void expr_call_ops_eval(const struct nft_expr *expr,
        X(e, nft_dynset_eval);
        X(e, nft_rt_get_eval);
        X(e, nft_bitwise_eval);
+       X(e, nft_objref_eval);
+       X(e, nft_objref_map_eval);
 #undef  X
 indirect_call:
 #endif /* CONFIG_RETPOLINE */
index 7b01aa2..cb37169 100644 (file)
@@ -13,9 +13,9 @@
 
 #define nft_objref_priv(expr)  *((struct nft_object **)nft_expr_priv(expr))
 
-static void nft_objref_eval(const struct nft_expr *expr,
-                           struct nft_regs *regs,
-                           const struct nft_pktinfo *pkt)
+void nft_objref_eval(const struct nft_expr *expr,
+                    struct nft_regs *regs,
+                    const struct nft_pktinfo *pkt)
 {
        struct nft_object *obj = nft_objref_priv(expr);
 
@@ -100,9 +100,9 @@ struct nft_objref_map {
        struct nft_set_binding  binding;
 };
 
-static void nft_objref_map_eval(const struct nft_expr *expr,
-                               struct nft_regs *regs,
-                               const struct nft_pktinfo *pkt)
+void nft_objref_map_eval(const struct nft_expr *expr,
+                        struct nft_regs *regs,
+                        const struct nft_pktinfo *pkt)
 {
        struct nft_objref_map *priv = nft_expr_priv(expr);
        const struct nft_set *set = priv->set;