• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            小默

            struct sk_buff

            /home/green/src/list.c
            alloc_skb
            kfree_skb
            skb_put
            skb_trim


            #############
            /home/green/src/list.c
            #############
            alloc_skb
            kfree_skb
            skb_put  // used data后部擴(kuò)展
            skb_push // used data前部擴(kuò)展
            skb_pull // used data前部截?cái)?/div>
            skb_trim // used data后部截?cái)?/div>
            skb_reserve // data+分片后移,只允許對(duì)空緩存使用

            skb_queue_head_init  // 初始化struct sk_buff_head
            skb_queue_head  // list頭部添加一個(gè)packet
            skb_queue_tail  // list尾部添加一個(gè)packet
            skb_dequeue      // 移去list頭部第一個(gè)packet(返回移除的packet指針,內(nèi)存沒有收回?)
            skb_dequeue_tail // 移去list尾部第一個(gè)packet  
            skb_queue_purge  // 清空list中的節(jié)點(diǎn)
            skb_append      // 在list的給定packet后append一個(gè)packet
            skb_insert      // 在list的給定packet前insert一個(gè)packet



            #############
            alloc_skb
            #############
            <linux-2.6.36/net/core/skbuff.c>

            __alloc_skb()分析:

            申請(qǐng)struct skb_buff skb空間, 必須從CACHE中申請(qǐng)(skbuff_fclone_cache或skbuff_head_cache).
            申請(qǐng)數(shù)據(jù)區(qū)內(nèi)存, 使用kmalloc. 數(shù)據(jù)區(qū)包括字節(jié)對(duì)齊后的size和struct skb_shared_info.
            填充skb結(jié)構(gòu).
            填充分片信息struct skb_shared_info shinfo.
            如果頭部skb_buff是從skbuff_fclone_cache中申請(qǐng)的,do something... //TODO

            ********

            __alloc_skb()完成時(shí),內(nèi)存狀態(tài):

            skb           struct sk_buff     <-| skb->truesize
                          --------------       |
            data          size                 |
            skb->data                          |
            skb->head                          |
                          -------------      <-|
                          struct skb_shared_info

            tail 和 end是偏移量
            skb->tail = skb->data - skb->head = 0
            skb->end = skb->tail + skb->size

            ********

            head,data是指針,tail,end是偏移量。

            <linux-2.6.36/include/linux/skbuff.h>
            #ifdef NET_SKBUFF_DATA_USES_OFFSET
            typedef unsigned int sk_buff_data_t;
            #else
            typedef unsigned char *sk_buff_data_t;
            #endif

            struct sk_buff {
                /* These elements must be at the end, see alloc_skb() for details.  */
                sk_buff_data_t      tail;
                sk_buff_data_t      end;
                unsigned char       *head,
                *data;

                unsigned int        truesize;
                atomic_t        users;
            };

            *********
            skb,shinfo的引用計(jì)數(shù)都是原子類型atomic_t.
            volatile只讀內(nèi)存,不讀寄存器. 


            #############
            kfree_skb
            #############
            內(nèi)存屏障

            軟件可通過讀寫屏障強(qiáng)制內(nèi)存訪問次序.所有在設(shè)置讀寫屏障之前發(fā)起的內(nèi)存訪問,必須先于在設(shè)置屏障之后發(fā)起的內(nèi)存訪問之前完成,確保內(nèi)存訪問按程序的順序完成.

            smp_mb()    適用于多處理器的內(nèi)存屏障。
            smp_rmb()   適用于多處理器的讀內(nèi)存屏障。

            http://blogold.chinaunix.net/u3/93713/showart_2061476.html


            #############
            skb_put
            #############
            BUG() BUGON()

            BUG()和BUG_ON()被用來提供斷言,當(dāng)被調(diào)用時(shí)會(huì)引發(fā)oops,導(dǎo)致棧的回溯和錯(cuò)誤信息的打印.
            大部分體系結(jié)構(gòu)把BUG()定義成某種非法操作.
            斷言某種情況不該發(fā)生:
            if(bad_thing):
                BUG();
            或者更好的形式:
            BUG_ON(bad_thing);

            ******
            frag_list

            如果傳輸層將數(shù)據(jù)包分片了,就會(huì)把這些數(shù)據(jù)包放到skb的frag_list鏈表中.

            ******
            skb_put 在尾部擴(kuò)展used data area.常被用于給數(shù)據(jù)塊添加協(xié)議尾部.
            其實(shí)就修改了tail偏移量和len值,別的什么都沒做.
            設(shè)了倆斷言:
            數(shù)據(jù)包不能有分片;
            擴(kuò)展數(shù)據(jù)區(qū)不能超出skb->end.


            #############
            skb_trim
            #############
            struct sk_buff

            truesize = skb + data
            len = data + 分片
            data+len = 分片

            posted on 2011-03-24 18:07 小默 閱讀(927) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Linux

            導(dǎo)航

            統(tǒng)計(jì)

            • 隨筆 - 289
            • 文章 - 0
            • 評(píng)論 - 84
            • 引用 - 0

            留言簿(13)

            隨筆分類(287)

            隨筆檔案(289)

            漏洞

            搜索

            •  

            積分與排名

            • 積分 - 292893
            • 排名 - 90

            最新評(píng)論

            閱讀排行榜

            久久精品日日躁夜夜躁欧美| 久久99精品久久久大学生| 久久精品国产亚洲网站| 久久久久亚洲精品天堂| 国产成人久久精品一区二区三区| 久久99久久99精品免视看动漫| 久久香蕉国产线看观看乱码| 色综合久久久久无码专区| 亚洲人成电影网站久久| 国产免费久久久久久无码| 99热都是精品久久久久久| 久久精品国产99国产电影网 | 亚洲AV日韩AV永久无码久久| 国产成人99久久亚洲综合精品| 久久久久一区二区三区| 99久久免费国产精精品| 久久精品国产精品亚洲精品| 国内精品久久人妻互换| 韩国无遮挡三级久久| 丁香五月网久久综合| 久久se精品一区精品二区国产| 狠狠色丁香久久婷婷综合蜜芽五月 | 久久人人爽人人爽人人片av麻烦 | 久久婷婷国产综合精品| 亚洲综合日韩久久成人AV| 久久久国产精品亚洲一区| 成人久久精品一区二区三区| 国产A级毛片久久久精品毛片| 久久久亚洲裙底偷窥综合| 青草国产精品久久久久久| 国产精品美女久久久久网| 国产国产成人久久精品| 东方aⅴ免费观看久久av| 91精品国产综合久久香蕉| 少妇无套内谢久久久久| 久久精品国产69国产精品亚洲| 久久99热这里只有精品66| 国产一级持黄大片99久久| 一本久道久久综合狠狠躁AV| 国内精品伊人久久久久| 18禁黄久久久AAA片|