diff options
Diffstat (limited to 'net')
-rw-r--r-- | net/core/dev.c | 10 | ||||
-rw-r--r-- | net/ethernet/eth.c | 1 |
2 files changed, 5 insertions, 6 deletions
diff --git a/net/core/dev.c b/net/core/dev.c index e1cc162bf295..9d153eb1e8cf 100644 --- a/net/core/dev.c +++ b/net/core/dev.c | |||
@@ -1536,17 +1536,14 @@ static int ing_filter(struct sk_buff *skb) | |||
1536 | __u32 ttl = (__u32) G_TC_RTTL(skb->tc_verd); | 1536 | __u32 ttl = (__u32) G_TC_RTTL(skb->tc_verd); |
1537 | if (MAX_RED_LOOP < ttl++) { | 1537 | if (MAX_RED_LOOP < ttl++) { |
1538 | printk("Redir loop detected Dropping packet (%s->%s)\n", | 1538 | printk("Redir loop detected Dropping packet (%s->%s)\n", |
1539 | skb->input_dev?skb->input_dev->name:"??",skb->dev->name); | 1539 | skb->input_dev->name, skb->dev->name); |
1540 | return TC_ACT_SHOT; | 1540 | return TC_ACT_SHOT; |
1541 | } | 1541 | } |
1542 | 1542 | ||
1543 | skb->tc_verd = SET_TC_RTTL(skb->tc_verd,ttl); | 1543 | skb->tc_verd = SET_TC_RTTL(skb->tc_verd,ttl); |
1544 | 1544 | ||
1545 | skb->tc_verd = SET_TC_AT(skb->tc_verd,AT_INGRESS); | 1545 | skb->tc_verd = SET_TC_AT(skb->tc_verd,AT_INGRESS); |
1546 | if (NULL == skb->input_dev) { | 1546 | |
1547 | skb->input_dev = skb->dev; | ||
1548 | printk("ing_filter: fixed %s out %s\n",skb->input_dev->name,skb->dev->name); | ||
1549 | } | ||
1550 | spin_lock(&dev->ingress_lock); | 1547 | spin_lock(&dev->ingress_lock); |
1551 | if ((q = dev->qdisc_ingress) != NULL) | 1548 | if ((q = dev->qdisc_ingress) != NULL) |
1552 | result = q->enqueue(skb, q); | 1549 | result = q->enqueue(skb, q); |
@@ -1572,6 +1569,9 @@ int netif_receive_skb(struct sk_buff *skb) | |||
1572 | if (!skb->stamp.tv_sec) | 1569 | if (!skb->stamp.tv_sec) |
1573 | net_timestamp(&skb->stamp); | 1570 | net_timestamp(&skb->stamp); |
1574 | 1571 | ||
1572 | if (!skb->input_dev) | ||
1573 | skb->input_dev = skb->dev; | ||
1574 | |||
1575 | orig_dev = skb_bond(skb); | 1575 | orig_dev = skb_bond(skb); |
1576 | 1576 | ||
1577 | __get_cpu_var(netdev_rx_stat).total++; | 1577 | __get_cpu_var(netdev_rx_stat).total++; |
diff --git a/net/ethernet/eth.c b/net/ethernet/eth.c index f6dbfb99b14d..f444a2f2675f 100644 --- a/net/ethernet/eth.c +++ b/net/ethernet/eth.c | |||
@@ -163,7 +163,6 @@ __be16 eth_type_trans(struct sk_buff *skb, struct net_device *dev) | |||
163 | skb->mac.raw=skb->data; | 163 | skb->mac.raw=skb->data; |
164 | skb_pull(skb,ETH_HLEN); | 164 | skb_pull(skb,ETH_HLEN); |
165 | eth = eth_hdr(skb); | 165 | eth = eth_hdr(skb); |
166 | skb->input_dev = dev; | ||
167 | 166 | ||
168 | if(*eth->h_dest&1) | 167 | if(*eth->h_dest&1) |
169 | { | 168 | { |