}
 
 /**
- * longest_prefix_match() - determine the longest prefix
+ * __longest_prefix_match() - determine the longest prefix
  * @trie:      The trie to get internal sizes from
  * @node:      The node to operate on
  * @key:       The key to compare to @node
  *
  * Determine the longest prefix of @node that matches the bits in @key.
  */
-static size_t longest_prefix_match(const struct lpm_trie *trie,
-                                  const struct lpm_trie_node *node,
-                                  const struct bpf_lpm_trie_key_u8 *key)
+static __always_inline
+size_t __longest_prefix_match(const struct lpm_trie *trie,
+                             const struct lpm_trie_node *node,
+                             const struct bpf_lpm_trie_key_u8 *key)
 {
        u32 limit = min(node->prefixlen, key->prefixlen);
        u32 prefixlen = 0, i = 0;
        return prefixlen;
 }
 
+static size_t longest_prefix_match(const struct lpm_trie *trie,
+                                  const struct lpm_trie_node *node,
+                                  const struct bpf_lpm_trie_key_u8 *key)
+{
+       return __longest_prefix_match(trie, node, key);
+}
+
 /* Called from syscall or from eBPF program */
 static void *trie_lookup_elem(struct bpf_map *map, void *_key)
 {
                 * If it's the maximum possible prefix for this trie, we have
                 * an exact match and can return it directly.
                 */
-               matchlen = longest_prefix_match(trie, node, key);
+               matchlen = __longest_prefix_match(trie, node, key);
                if (matchlen == trie->max_prefixlen) {
                        found = node;
                        break;