| /linux-6.15/net/core/ |
| H A D | dst_cache.c | 36 dst_cache->dst = dst; in dst_cache_per_cpu_dst_set() 39 static struct dst_entry *dst_cache_per_cpu_get(struct dst_cache *dst_cache, in dst_cache_per_cpu_get() argument 66 struct dst_entry *dst_cache_get(struct dst_cache *dst_cache) in dst_cache_get() argument 68 if (!dst_cache->cache) in dst_cache_get() 71 return dst_cache_per_cpu_get(dst_cache, this_cpu_ptr(dst_cache->cache)); in dst_cache_get() 93 void dst_cache_set_ip4(struct dst_cache *dst_cache, struct dst_entry *dst, in dst_cache_set_ip4() argument 108 void dst_cache_set_ip6(struct dst_cache *dst_cache, struct dst_entry *dst, in dst_cache_set_ip6() argument 123 struct dst_entry *dst_cache_get_ip6(struct dst_cache *dst_cache, in dst_cache_get_ip6() argument 143 int dst_cache_init(struct dst_cache *dst_cache, gfp_t gfp) in dst_cache_init() argument 155 void dst_cache_destroy(struct dst_cache *dst_cache) in dst_cache_destroy() argument [all …]
|
| H A D | dst.c | 173 dst_cache_reset_now(&md_dst->u.tun_info.dst_cache); in dst_release() 312 dst_cache_destroy(&md_dst->u.tun_info.dst_cache); in metadata_dst_free() 348 dst_cache_destroy(&one_md_dst->u.tun_info.dst_cache); in metadata_dst_free_percpu()
|
| H A D | Makefile | 38 obj-$(CONFIG_DST_CACHE) += dst_cache.o
|
| /linux-6.15/include/net/ |
| H A D | dst_cache.h | 11 struct dst_cache { struct 24 struct dst_entry *dst_cache_get(struct dst_cache *dst_cache); 33 struct rtable *dst_cache_get_ip4(struct dst_cache *dst_cache, __be32 *saddr); 43 void dst_cache_set_ip4(struct dst_cache *dst_cache, struct dst_entry *dst, 56 void dst_cache_set_ip6(struct dst_cache *dst_cache, struct dst_entry *dst, 66 struct dst_entry *dst_cache_get_ip6(struct dst_cache *dst_cache, 77 static inline void dst_cache_reset(struct dst_cache *dst_cache) in dst_cache_reset() argument 79 WRITE_ONCE(dst_cache->reset_ts, jiffies); in dst_cache_reset() 91 void dst_cache_reset_now(struct dst_cache *dst_cache); 98 int dst_cache_init(struct dst_cache *dst_cache, gfp_t gfp); [all …]
|
| H A D | udp_tunnel.h | 171 struct dst_cache *dst_cache); 179 struct dst_cache *dst_cache);
|
| H A D | ip6_tunnel.h | 53 struct dst_cache dst_cache; /* cached dst */ member
|
| H A D | ip_tunnels.h | 106 struct dst_cache dst_cache; member 167 struct dst_cache dst_cache; member
|
| H A D | dst_metadata.h | 170 if (new_md->u.tun_info.dst_cache.cache) { in tun_dst_unclone() 173 ret = dst_cache_init(&new_md->u.tun_info.dst_cache, GFP_ATOMIC); in tun_dst_unclone()
|
| H A D | vxlan.h | 209 struct dst_cache dst_cache; member
|
| /linux-6.15/net/ipv6/ |
| H A D | ip6_udp_tunnel.c | 143 struct dst_cache *dst_cache) in udp_tunnel6_dst_lookup() argument 149 if (dst_cache) { in udp_tunnel6_dst_lookup() 150 dst = dst_cache_get_ip6(dst_cache, saddr); in udp_tunnel6_dst_lookup() 177 if (dst_cache) in udp_tunnel6_dst_lookup() 178 dst_cache_set_ip6(dst_cache, dst, &fl6.saddr); in udp_tunnel6_dst_lookup()
|
| H A D | sit.c | 481 dst_cache_reset(&t->dst_cache); in ipip6_tunnel_prl_ctl() 524 dst_cache_reset(&tunnel->dst_cache); in ipip6_tunnel_uninit() 944 rt = dst_cache_get_ip4(&tunnel->dst_cache, &fl4.saddr); in ipip6_tunnel_xmit() 951 dst_cache_set_ip4(&tunnel->dst_cache, &rt->dst, fl4.saddr); in ipip6_tunnel_xmit() 1163 dst_cache_reset(&t->dst_cache); in ipip6_tunnel_update() 1194 dst_cache_reset(&t->dst_cache); in ipip6_tunnel_update_6rd() 1414 dst_cache_destroy(&tunnel->dst_cache); in ipip6_dev_free() 1457 err = dst_cache_init(&tunnel->dst_cache, GFP_KERNEL); in ipip6_tunnel_init()
|
| H A D | ip6_gre.c | 401 dst_cache_reset(&t->dst_cache); in ip6erspan_tunnel_uninit() 414 dst_cache_reset(&t->dst_cache); in ip6gre_tunnel_uninit() 1235 dst_cache_reset(&t->dst_cache); in ip6gre_tnl_copy_tnl_parm() 1446 dst_cache_destroy(&t->dst_cache); in ip6gre_dev_free() 1504 ret = dst_cache_init(&tunnel->dst_cache, GFP_KERNEL); in ip6gre_tunnel_init_common() 1529 dst_cache_destroy(&tunnel->dst_cache); in ip6gre_tunnel_init_common() 1887 ret = dst_cache_init(&tunnel->dst_cache, GFP_KERNEL); in ip6erspan_tap_init() 1910 dst_cache_destroy(&tunnel->dst_cache); in ip6erspan_tap_init()
|
| H A D | ip6_tunnel.c | 251 dst_cache_destroy(&t->dst_cache); in ip6_dev_free() 383 dst_cache_reset(&t->dst_cache); in ip6_tnl_dev_uninit() 1155 dst = dst_cache_get(&t->dst_cache); in ip6_tnl_xmit() 1242 dst_cache_set_ip6(&t->dst_cache, ndst, &fl6->saddr); in ip6_tnl_xmit() 1549 dst_cache_reset(&t->dst_cache); in ip6_tnl_change() 1882 ret = dst_cache_init(&t->dst_cache, GFP_KERNEL); in ip6_tnl_dev_init_gen() 1906 dst_cache_destroy(&t->dst_cache); in ip6_tnl_dev_init_gen()
|
| /linux-6.15/net/ipv6/ila/ |
| H A D | ila_lwt.c | 21 struct dst_cache dst_cache; member 62 dst = dst_cache_get(&ilwt->dst_cache); in ila_output() 94 dst_cache_set_ip6(&ilwt->dst_cache, dst, &fl6.saddr); in ila_output() 231 ret = dst_cache_init(&ilwt->dst_cache, GFP_ATOMIC); in ila_build_state() 266 dst_cache_destroy(&ila_lwt_lwtunnel(lwt)->dst_cache); in ila_destroy_state()
|
| /linux-6.15/net/ipv4/ |
| H A D | udp_tunnel_core.c | 215 struct dst_cache *dst_cache) in udp_tunnel_dst_lookup() argument 221 if (dst_cache) { in udp_tunnel_dst_lookup() 222 rt = dst_cache_get_ip4(dst_cache, saddr); in udp_tunnel_dst_lookup() 250 if (dst_cache) in udp_tunnel_dst_lookup() 251 dst_cache_set_ip4(dst_cache, &rt->dst, fl4.saddr); in udp_tunnel_dst_lookup()
|
| H A D | ip_tunnel.c | 309 dst_cache_reset(&tunnel->dst_cache); in ip_tunnel_bind_dev() 634 dst_cache_set_ip4(&tun_info->dst_cache, &rt->dst, in ip_md_tunnel_xmit() 787 rt = dst_cache_get_ip4(&tun_info->dst_cache, in ip_tunnel_xmit() 790 rt = connected ? dst_cache_get_ip4(&tunnel->dst_cache, in ip_tunnel_xmit() 802 dst_cache_set_ip4(&tun_info->dst_cache, &rt->dst, in ip_tunnel_xmit() 805 dst_cache_set_ip4(&tunnel->dst_cache, &rt->dst, in ip_tunnel_xmit() 904 dst_cache_reset(&t->dst_cache); in ip_tunnel_update() 1103 dst_cache_destroy(&tunnel->dst_cache); in ip_tunnel_dev_free() 1319 err = dst_cache_init(&tunnel->dst_cache, GFP_KERNEL); in ip_tunnel_init() 1325 dst_cache_destroy(&tunnel->dst_cache); in ip_tunnel_init() [all …]
|
| /linux-6.15/net/tipc/ |
| H A D | udp_media.c | 85 struct dst_cache dst_cache; member 172 struct udp_media_addr *dst, struct dst_cache *cache) in tipc_udp_xmit() 259 &ub->rcast.dst_cache); in tipc_udp_send_msg() 272 &rcast->dst_cache); in tipc_udp_send_msg() 316 if (dst_cache_init(&rcast->dst_cache, GFP_ATOMIC)) { in tipc_udp_rcast_add() 779 err = dst_cache_init(&ub->rcast.dst_cache, GFP_ATOMIC); in tipc_udp_enable() 798 dst_cache_destroy(&ub->rcast.dst_cache); in tipc_udp_enable() 813 dst_cache_destroy(&rcast->dst_cache); in cleanup_bearer() 820 dst_cache_destroy(&ub->rcast.dst_cache); in cleanup_bearer()
|
| /linux-6.15/net/netfilter/ |
| H A D | nft_flow_offload.c | 32 struct dst_entry *dst_cache, in nft_default_forward_path() argument 35 route->tuple[!dir].in.ifindex = dst_cache->dev->ifindex; in nft_default_forward_path() 36 route->tuple[dir].dst = dst_cache; in nft_default_forward_path() 37 route->tuple[dir].xmit_type = nft_xmit_type(dst_cache); in nft_default_forward_path() 50 const struct dst_entry *dst_cache, in nft_dev_fill_forward_path() argument 56 struct net_device *dev = dst_cache->dev; in nft_dev_fill_forward_path() 63 n = dst_neigh_lookup(dst_cache, daddr); in nft_dev_fill_forward_path()
|
| H A D | nf_flow_table_ip.c | 267 return dst_check(tuple->dst_cache, tuple->dst_cookie); in nf_flow_dst_check() 444 rt = dst_rtable(tuplehash->tuple.dst_cache); in nf_flow_offload_ip_hook() 456 rt = dst_rtable(tuplehash->tuple.dst_cache); in nf_flow_offload_ip_hook() 739 rt = dst_rt6_info(tuplehash->tuple.dst_cache); in nf_flow_offload_ipv6_hook() 751 rt = dst_rt6_info(tuplehash->tuple.dst_cache); in nf_flow_offload_ipv6_hook()
|
| H A D | nf_flow_table_offload.c | 278 const struct dst_entry *dst_cache; in flow_offload_eth_dst() local 295 dst_cache = this_tuple->dst_cache; in flow_offload_eth_dst() 296 n = dst_neigh_lookup(dst_cache, daddr); in flow_offload_eth_dst() 589 dst = this_tuple->dst_cache; in flow_offload_encap_tunnel() 614 dst = other_tuple->dst_cache; in flow_offload_decap_tunnel() 758 other_dst = other_tuple->dst_cache; in nf_flow_offload_rule_alloc()
|
| H A D | nf_flow_table_core.c | 81 return rt6_get_cookie(dst_rt6_info(flow_tuple->dst_cache)); in flow_offload_dst_cookie() 135 flow_tuple->dst_cache = dst; in flow_offload_fill_route() 152 dst_release(flow->tuplehash[dir].tuple.dst_cache); in nft_flow_dst_release()
|
| /linux-6.15/drivers/net/ |
| H A D | bareudp.c | 332 (struct dst_cache *)&info->dst_cache : NULL); in bareudp_xmit_skb() 402 (struct dst_cache *) &info->dst_cache : NULL); in bareudp6_xmit_skb() 520 use_cache ? &info->dst_cache : NULL); in bareudp_fill_metadata_dst() 534 use_cache ? &info->dst_cache : NULL); in bareudp_fill_metadata_dst()
|
| H A D | geneve.c | 346 err = dst_cache_init(&geneve->cfg.info.dst_cache, GFP_KERNEL); in geneve_init() 359 dst_cache_destroy(&geneve->cfg.info.dst_cache); in geneve_uninit() 849 (struct dst_cache *)&info->dst_cache : NULL); in geneve_xmit_skb() 961 (struct dst_cache *)&info->dst_cache : NULL); in geneve6_xmit_skb() 1101 use_cache ? &info->dst_cache : NULL); in geneve_fill_metadata_dst() 1127 use_cache ? &info->dst_cache : NULL); in geneve_fill_metadata_dst() 1393 dst_cache_reset(&geneve->cfg.info.dst_cache); in geneve_configure() 1748 dst_cache_reset(&cfg.info.dst_cache); in geneve_changelink()
|
| /linux-6.15/drivers/net/wireguard/ |
| H A D | peer.h | 45 struct dst_cache endpoint_cache;
|
| H A D | socket.c | 21 struct endpoint *endpoint, u8 ds, struct dst_cache *cache) in send4() 98 struct endpoint *endpoint, u8 ds, struct dst_cache *cache) in send6()
|