Chinaunix首页 | 论坛 | 博客
  • 博客访问: 436295
  • 博文数量: 99
  • 博客积分: 65
  • 博客等级: 民兵
  • 技术积分: 1012
  • 用 户 组: 普通用户
  • 注册时间: 2012-04-20 16:30
个人简介

linux kernel 工程师

文章分类

全部博文(99)

文章存档

2018年(5)

2017年(12)

2016年(27)

2015年(10)

2014年(43)

2012年(2)

我的朋友

发布时间:2014-02-14 10:36:11

工作的环境应当是进程的上下文 _dev_xmit_skb函数主要做两件事情: (1) 如果qdisc为空的,试图直接发送数据包(2)如果qdisc不空,将数据包加入qdisc,并运行qdisc 当设备进入调度队列准备传输时,qdisc_run函数就会选出下一个要传输的帧,而该函数会间接的调用相关联的队列规则dequeue函数,从对了中取出.........【阅读全文】

阅读(3359) | 评论(0) | 转发(0)

发布时间:2014-02-14 10:27:37

static void net_tx_action(struct softirq_action *h){ struct softnet_data *sd = &__get_cpu_var(softnet_data); //1. 释放completion_queue中的skb if (sd->completion_queue) {  struct sk_buff *clist;  local_irq_disable();  clist = sd->completion_.........【阅读全文】

阅读(1508) | 评论(0) | 转发(0)

发布时间:2014-02-14 10:01:18

register_netdevice会初始化netdev的Tx调度discipline, 缺省使用noop_qdiscregister_netdevice --->dev_init_schedulervoid dev_init_scheduler(struct net_device *dev){ dev->qdisc = &noop_qdisc; netdev_for_each_tx_queue(dev, dev_init_scheduler_queue, &noop_qdisc); if (dev_.........【阅读全文】

阅读(3178) | 评论(0) | 转发(0)

发布时间:2014-02-14 09:34:18

net/sched/sched_fifo.c 实现了pfifo和bfifo这两种策略都是fifo策略,即入队时放在队列尾部,出队时从头部出队,即先进先出的方式不同点在于入队时的限制:bfifo 对队列的字节长度做限制pfofo 对队列的packets数目做限制static int bfifo_enqueue(struct sk_buff *skb, struct Qdisc *sch){   .........【阅读全文】

阅读(2158) | 评论(0) | 转发(0)

发布时间:2014-02-14 09:27:06

// pfifo_fast 这个discipiline里面有skb队列数组,优先级从大到小,队列下标分别是0,1,2// enqueue 根据skb的priority, 使用prio2band数组找出skb对应的队列// dequeue 优先选择下标为0的skb队列,0队列变空后选择1队列,1队列变空后选择2队列 // 同样优先级的skb,实现fifo策略, 入队时插入队列尾部,出队时从.........【阅读全文】

阅读(2034) | 评论(0) | 转发(0)
给主人留下些什么吧!~~
留言热议
请登录后留言。

登录 注册