数据收发的软中断以及数据从网卡发送

来源:互联网 发布:消音软件哪个好 编辑:程序博客网 时间:2024/05/16 23:38

注册软中断

static int __init net_dev_init(void){         ......        open_softirq(NET_TX_SOFTIRQ, net_tx_action);open_softirq(NET_RX_SOFTIRQ, net_rx_action);      ......}static void net_tx_action(struct softirq_action *h){struct softnet_data *sd = &__get_cpu_var(softnet_data);if (sd->completion_queue) {struct sk_buff *clist;local_irq_disable();clist = sd->completion_queue;sd->completion_queue = NULL;local_irq_enable();while (clist) {struct sk_buff *skb = clist;clist = clist->next;WARN_ON(atomic_read(&skb->users));__kfree_skb(skb);}}if (sd->output_queue) {struct Qdisc *head;local_irq_disable();head = sd->output_queue;sd->output_queue = NULL;local_irq_enable();                      //这里不是发送某个网卡的某个包,而是针对所有流控对象Qdisc的调度,逻辑上与网卡没有直接关系while (head) { struct Qdisc *q = head;spinlock_t *root_lock;head = head->next_sched;root_lock = qdisc_lock(q);if (spin_trylock(root_lock)) {smp_mb__before_clear_bit();clear_bit(__QDISC_STATE_SCHED,  &q->state);qdisc_run(q);spin_unlock(root_lock);} else {if (!test_bit(__QDISC_STATE_DEACTIVATED,      &q->state)) {__netif_reschedule(q);} else {smp_mb__before_clear_bit();clear_bit(__QDISC_STATE_SCHED,  &q->state);}}}}}static inline int qdisc_restart(struct Qdisc *q){struct netdev_queue *txq;struct net_device *dev;spinlock_t *root_lock;struct sk_buff *skb;/* Dequeue packet */skb = dequeue_skb(q);if (unlikely(!skb))return 0;root_lock = qdisc_lock(q);dev = qdisc_dev(q);txq = netdev_get_tx_queue(dev, skb_get_queue_mapping(skb));return sch_direct_xmit(skb, q, dev, txq, root_lock);}调用dev_hard_start_xmit将数据包发送出去int sch_direct_xmit(struct sk_buff *skb, struct Qdisc *q,struct net_device *dev, struct netdev_queue *txq,spinlock_t *root_lock){int ret = NETDEV_TX_BUSY;/* And release qdisc */spin_unlock(root_lock);HARD_TX_LOCK(dev, txq, smp_processor_id());if (!netif_tx_queue_stopped(txq) &&  !netif_tx_queue_frozen(txq))ret = dev_hard_start_xmit(skb, dev, txq);HARD_TX_UNLOCK(dev, txq);spin_lock(root_lock);switch (ret) {case NETDEV_TX_OK:/* Driver sent out skb successfully */ret = qdisc_qlen(q);break;case NETDEV_TX_LOCKED:/* Driver try lock failed */ret = handle_dev_cpu_collision(skb, txq, q);break;default:/* Driver returned NETDEV_TX_BUSY - requeue skb */if (unlikely (ret != NETDEV_TX_BUSY && net_ratelimit()))printk(KERN_WARNING "BUG %s code %d qlen %d\n",       dev->name, ret, q->q.qlen);ret = dev_requeue_skb(skb, q);break;}if (ret && (netif_tx_queue_stopped(txq) ||netif_tx_queue_frozen(txq)))ret = 0;return ret;}int dev_hard_start_xmit(struct sk_buff *skb, struct net_device *dev,struct netdev_queue *txq){const struct net_device_ops *ops = dev->netdev_ops;int rc;if (likely(!skb->next))         {if (!list_empty(&ptype_all))dev_queue_xmit_nit(skb, dev);if (netif_needs_gso(dev, skb)) {if (unlikely(dev_gso_segment(skb)))goto out_kfree_skb;if (skb->next)goto gso;}if (dev->priv_flags & IFF_XMIT_DST_RELEASE)skb_dst_drop(skb);rc = ops->ndo_start_xmit(skb, dev);if (rc == NETDEV_TX_OK)txq_trans_update(txq);return rc;}gso:      rc = ops->ndo_start_xmit(skb, dev); }



ndo_start_xmit调用驱动的发送方法将包发出

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 打坐时间不长怎么办 余利宝无法开通怎么办 qq群视频进不去怎么办 qq空间状态异常怎么办 手机qq空间异常怎么办 手机被恶意骚扰怎么办 织布机开不起来怎么办 座机键盘锁了怎么办 邮箱登录锁死怎么办 标志408油耗高怎么办 gucci白鞋掉皮怎么办 深圳摇不到车牌怎么办 车辆换牌照需要怎么办 商标申请有异议怎么办 唯品会账号被冻结怎么办 易直播回放收费怎么办 手机屏幕被摔了怎么办 xp调分辨率黑屏怎么办 公司logo被盗用怎么办 商标注册证掉了怎么办 商标注册证书丢了怎么办 市场监督管理局罚款怎么办 东莞居住证掉了怎么办 工商注销了税务怎么办 楼道自来水爆了怎么办 工商证没年检怎么办 工行信用卡被锁怎么办 外地卡密码锁了怎么办 营业执照年审过期了怎么办 工商营业执照吊销了怎么办 小规模企业工商年检怎么办 血流变检查偏高怎么办 信誉卡没有邮箱怎么办 税务年报没报怎么办 工商忘记年审了怎么办 营业执照脱审了怎么办 公司年审没有弄怎么办 车检标志丢了怎么办 机动车年检丢了怎么办 汽车保险标志丢了怎么办 车辆年检贴丢失怎么办