/* * Copyright (c) 2015 Pablo Neira Ayuso <pablo@netfilter.org> * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 as published by * the Free Software Foundation. */ #include <linux/kernel.h> #include <linux/init.h> #include <linux/module.h> #include <linux/netlink.h> #include <linux/netfilter.h> #include <linux/netfilter/nf_tables.h> #include <net/netfilter/nf_tables.h>
void nf_dup_netdev_egress(const struct nft_pktinfo *pkt, int oif) { struct net_device *dev; struct sk_buff *skb; dev = dev_get_by_index_rcu(pkt->net, oif); if (dev == NULL) return; skb = skb_clone(pkt->skb, GFP_ATOMIC); if (skb == NULL) return; if (skb_mac_header_was_set(skb)) skb_push(skb, skb->mac_len); skb->dev = dev; dev_queue_xmit(skb); }Contributors
Person | Tokens | Prop | Commits | CommitProp | |
pablo neira ayuso | pablo neira ayuso | 87 | 100.00% | 1 | 100.00% |
Total | 87 | 100.00% | 1 | 100.00% |
Person | Tokens | Prop | Commits | CommitProp | |
pablo neira ayuso | pablo neira ayuso | 124 | 100.00% | 1 | 100.00% |
Total | 124 | 100.00% | 1 | 100.00% |