Chinaunix首页 | 论坛 | 博客
  • 博客访问: 999462
  • 博文数量: 442
  • 博客积分: 1146
  • 博客等级: 少尉
  • 技术积分: 1604
  • 用 户 组: 普通用户
  • 注册时间: 2010-11-04 12:52
个人简介

123

文章分类

全部博文(442)

文章存档

2017年(3)

2016年(15)

2015年(132)

2014年(52)

2013年(101)

2012年(110)

2011年(29)

分类:

2012-01-18 22:03:44

声明:本文为原创
#####请转贴时保留以下内容######
作者GTT
本文档归属http://oldtown.cublog.cn/.转载请注明出处!
请提出宝贵意见Mail:mtloveft@hotmail.com
Linux Version:2.6.33
提示本文是介绍关于linux 如何实现loopback NIC 驱动
 
最后看看Lookback NIC 是如何送信和收信的。
loopback nic 平时用的最多的可能是下面的命令吧
ping 127.0.0.1或者 吧。
loopback device driver 的操作VFT入下

static const struct net_device_ops loopback_ops = {
    .ndo_init = loopback_dev_init,
    .ndo_start_xmit= loopback_xmit,
    .ndo_get_stats = loopback_get_stats,
};

 
所以送信方法是loopback_xmit
看看source code

/*
 * The higher levels take care of making this non-reentrant (it's
 * called with bh's disabled).
 */

static netdev_tx_t loopback_xmit(struct sk_buff *skb,
                 struct net_device *dev)
{
    struct pcpu_lstats __percpu *pcpu_lstats;
    struct pcpu_lstats *lb_stats;
    int len;

    skb_orphan(skb);

    skb->protocol = eth_type_trans(skb, dev);

    /* it's OK to use per_cpu_ptr() because BHs are off */
    pcpu_lstats = (void __percpu __force *)dev->ml_priv;
    lb_stats = this_cpu_ptr(pcpu_lstats);

    len = skb->len;
    if (likely(netif_rx(skb) == NET_RX_SUCCESS)) {
        lb_stats->bytes += len;
        lb_stats->packets++;
    } else
        lb_stats->drops++;

    return NETDEV_TX_OK;
}

 
先根据eth_type_trans判断L3协议类型。
然后直接就调用netif_rx进行收数据包了。
所以loopback nic的送信里直接就调用收信方法。
netif_rx里在一层层分析。
 
 
 
 
 
 
 
 
 
 
 
 
 
 


阅读(892) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~