欧美第一页在线_久久在线观看视频_成人激情视频在线观看_亚洲一区二区久久久_亚洲欧美一区二区三区四区_国产精品美女主播在线观看纯欲_日本精品久久电影_亚洲自拍偷拍网址_www.久久草.com_欧美精品免费在线_国产精品久久久久久久美男_国产一区二区三区在线视频_欧美日韩精品中文字幕_欧美老女人在线视频_欧美日韩中文字幕日韩欧美_色噜噜国产精品视频一区二区

內(nèi)容字號:默認(rèn)大號超大號

段落設(shè)置:段首縮進(jìn)取消段首縮進(jìn)

字體設(shè)置:切換到微軟雅黑切換到宋體






介紹一個開源的SIP(VOIP)協(xié)議庫PJSIP

時間:2016-06-12 來源:中國集群通信網(wǎng) 作者:本站整理 點擊:

 如果你對SIP/VoIP技術(shù)感興趣,哪希望你不要錯過:),如果你對寫出堪稱優(yōu)美的Code感興趣
,那么你也不可錯過:)

這期間我想分析一下一個實際的協(xié)議棧的設(shè)計到實現(xiàn)的相關(guān)技術(shù),算是自己的一個學(xué)習(xí)經(jīng)
歷記錄.

最初選擇這個庫做分析的原因很簡單,文檔齊全:),其它良好的特征則是慢慢發(fā)現(xiàn)的:)

www.pjsip.org

1. PJSIP簡介

PJSIP的實現(xiàn)是為了能在嵌入式設(shè)備上高效實現(xiàn)SIP/VOIP.其主要特征包括:
1).極具移植性.(Extremely portable)
當(dāng)前可支持平臺包括:
* Win32/x86 (Win95/98/ME, NT/2000/XP/2003, mingw).
    * arm, WinCE and Windows Mobile.
    * Linux/x86, (user mode and as kernel module(!)).
    * Linux/alpha
    * Solaris/ultra.
    * MacOS X/powerpc
    * RTEMS (x86 and powerpc).

正移植到:
    * Symbian OS 
    
    2).非常小的足印.(Very small footprint)
    官方宣稱編譯后的庫<150Kb,我在PC上編譯后加上strip后大概173Kb,這對于嵌入
    式設(shè)備,是個好消息:)
    
    3).高性能.(High performance)
    這點我們后面可以看看是否如作者宣稱的:)
    
    4).支持眾多的特征.(Many features)
    這點可以從http://www.pjsip.org/sip_media_features.htm#sip_features看出.


    
    5).充足的SIP文檔.(Extensive SIP documentation)
    這是我最初選擇該庫的原因,當(dāng)然不是最終的原因,最終的原因是它的code:)
    
2. PJSIP的組成.

其實說是PJSIP不是特別貼切,這個庫實際上是幾個部分組成的.
1).PJSIP - Open Source SIP Stack[開源的SIP協(xié)議棧]

2).PJMEDIA - Open Source Media Stack[開源的媒體棧]

3).PJNATH - Open Source NAT Traversal Helper Library[開源的NAT-T輔助庫]

4).PJLIB-UTIL - Auxiliary Library[輔助工具庫]

5).PJLIB - Ultra Portable Base Framework Library[基礎(chǔ)框架庫]

而在最上層庫的目錄分為:(可以使用tree -d -L 1 查看)

$TOP/build [包含Makefile]
$TOP/build.symbian [針對symbian的Makefile]
$TOP/pjlib [參考上面]
$TOP/pjlib-util [參考上面]
$TOP/pjnath [參考上面]
$TOP/pjmedia [參考上面]
$TOP/pjsip [參考上面]
$TOP/pjsip-apps
$TOP/third_party

而在每個子目錄,可以看到分為:
bin [編譯后產(chǎn)生的二進(jìn)制文件]
build [Makefile]
build/output
build/wince-evc4
docs [doxygen的文檔,用doxygen docs/doxygen.cfg產(chǎn)生]
include [頭文件]
lib [編譯后產(chǎn)生的庫]
src [源代碼]

3. PJLIB簡介

要理解好PJSIP,就不得不先說說PJLIB,PJLIB算的上是這個庫中最基礎(chǔ)的庫,正是這個
庫的優(yōu)美實現(xiàn),才讓PJSIP變得如此優(yōu)越。

PJLIB提供了一系列特征,這是我們下面分析的重點,涉及到:
1).非動態(tài)內(nèi)存分配[No Dynamic Memory Allocations]
實現(xiàn)了內(nèi)存池,獲取內(nèi)存是從與分配的內(nèi)存池中獲取,高性能程序多會自己構(gòu)造內(nèi)存池
,后面我們會解釋該內(nèi)存池的使用以及基本的原理。根據(jù)作者的比較,是常規(guī)的 malloc(
)/free()函數(shù)的30倍。

2).OS抽象[Operating System Abstraction]
實現(xiàn)OS抽象的根本原因在與可移植性,毋庸置疑:).
涉及到:
a).線程[Threads.]
b).線程本地存儲[Thread Local Storage.]
c).互斥[Mutexes.]
d).信號燈[Semaphores.]
e).原子變量[Atomic Variables.]
f).臨屆區(qū)[Critical sections.]
g).鎖對象[Lock Objects.]
h).事件對象[Event Object.]
i).時間管理[Time Data Type and Manipulation.]
j).高解析的時間戳[High Resolution Timestamp.]
等等,這些我們后面分析代碼時一一看來:)

3).低層的網(wǎng)絡(luò)相關(guān)IO[Low-Level Network I/O]
    這涉及到:
    a).Socket抽象[Socket Abstraction.]
    b).網(wǎng)絡(luò)地址解析[Network Address Resolution.]
    c).實現(xiàn)針對Socket的select API[Socket select() API.]
    
4).時間管理[Timer Management]
這主要涉及到兩個部分,一個時定時器的管理,還有就是時間解析的精度(舉例說來,就
是能精確到哪個時間等級,比如 POSIX sleep(),就只能以秒為單位,而使用select()則可
以實現(xiàn)毫秒級別的計時) 

5).各種數(shù)據(jù)結(jié)構(gòu)[Various Data Structures]
主要有:
a).針對字符串的操作[String Operations]
b).數(shù)組輔助[Array helper]
c).Hash表[Hash Tabl]
d).鏈表[Linked List]
e).紅黑平衡樹[Red/Black Balanced Tree]

6).異常處理[Exception Construct]
使用的是TRY/CATCH,知道C++/JAVA之類面向?qū)ο笳Z言的人看過會宛而一笑:)

7).LOG機(jī)制[Logging Facility]
很顯然,一個良好的程序,好的LOG機(jī)制不可少。這能很方便的讓你去調(diào)試程序,對此我
是深有體會,任何時候,不要忘記“好的程序,是架構(gòu)出來的;而能跑的程序,是調(diào)試出
來的:)”

8).隨機(jī)數(shù)以及GUID的產(chǎn)生[Random and GUID Generation]
GUID指的是"globally unique identifier",只是一個標(biāo)識而已,比如說你的省份證,
算的上是一個GUID,當(dāng)然,準(zhǔn)確說來是“china unique identifier”:).

看了這么多的特征列舉,是不是很完備,的確。

總算是初步列舉完了PJLIB的基本特征了,后面我們來說說它的使用與實現(xiàn):

4. PJLIB的使用

有了上述介紹,是不是很想知道這個庫的使用,沒關(guān)系,我們慢慢說來:)

首先是頭文件和編譯出來的庫的位置,這就不必多說了,除非你沒有使用過手動編譯的庫
,如果不太了解步驟,google一下,啊:)

1).為了使用這個庫,需要使用:
#include 
當(dāng)然,也可以選擇:
#include 
    #include 
    這種分離的方式,不過,簡介其間,還是使用第一種吧:),畢竟,你不需要確認(rèn)到你所
需的函數(shù)或者數(shù)據(jù)結(jié)構(gòu)具體到哪個具體的頭文件:)
    
    2).確保在使用PJLIB之前調(diào)用 pj_init()來完成PJLIB庫使用前說必須的一些初始化.

    這是一個必不可少的步驟.
    ~~~~~~~~~~~~~~~~~~~~~~~
    
    3).使用PJLIB的一些建議
    作者對使用PJLIB的程序提出了一些建議,包括如下 :
    a).不要使用ANSI C[Do NOT Use ANSI C]
    觀點很明確,ANSI C并不會讓程序具有最大的移植性,應(yīng)該使用PJSIP庫所提供的響
應(yīng)機(jī)制來實現(xiàn)你所需要的功能.
    
    b).使用pj_str_t取代C風(fēng)格的字符串[Use pj_str_t instead of C Strings]
    原因之一是移植性,之二則是PJLIB內(nèi)置的pj_str_t相關(guān)操作會更快(性能).
    
    c).從內(nèi)存池分配內(nèi)存[Use Pool for Memory Allocations]
    這很明顯,如果你知道為什么會使用內(nèi)存池的話(提示一下,性能以及易用性:))
    
    d).使用PJLIB的LOG機(jī)制做文字顯示[Use Logging for Text Display]
    很明顯:)
    
     還有些關(guān)于移植的一些問題,不在我們的討論范圍,如果你需要移植到其它平臺或者
環(huán)境,請參考http://www.pjsip.org/pjlib/docs/html/porting_pjlib_pg.htm

5. PJLIB的使用以及原理
終于開始提及實現(xiàn)原理以及具體的編碼了:),前面的列舉還真是個瑣碎的事情,還是奔主題
來:).

5.1快速內(nèi)存池[Fast Memory Pool]
前面說過,使用內(nèi)存池的原因在于性能的考慮,原因是C風(fēng)格的malloc()以及C++風(fēng)格的new
操作在高性能或?qū)崟r條件下表現(xiàn)并不太好,原因在于性能的瓶頸在于內(nèi)存碎片問題.

下面列舉其優(yōu)點與需要主要的問題:
優(yōu)點:
a).不像其它內(nèi)存池,允許分配不同尺寸的chunks.
b).快速.
內(nèi)存chunks擁有O(1)的復(fù)雜度,并且操作僅僅是指針的算術(shù)運算,其間不需要使用鎖住任
何互斥量.
c).有效使用內(nèi)存.
除了可能因為內(nèi)存對齊的原因會浪費很少的內(nèi)存外,內(nèi)存的使用效率非常高.
d).可預(yù)防內(nèi)存泄漏.
在C/C++程序中如果出現(xiàn)內(nèi)存泄漏問題,其查找過程哪個艱辛,不足為外人道也:(
[曾經(jīng)有次用別人的Code,出現(xiàn)了內(nèi)存泄漏,在開發(fā)板上查找N天,又沒工具可在開發(fā)板上使
用,哪個痛苦,想自殺:(]
原因很簡單,你的內(nèi)存都是從內(nèi)存池中獲取的,就算你沒有釋放你獲取的內(nèi)存,只要你記得
把內(nèi)存池destroy,那么內(nèi)存還是會還給系統(tǒng).

還有設(shè)計帶來的一些其它益處,比如可用性和靈活性:
e).內(nèi)存泄漏更容易被跟蹤.
這是因為你的內(nèi)存是在指定的內(nèi)存池中分配的,只要能很快定位到內(nèi)存池,內(nèi)存泄漏的偵
測就方便多了.
f).設(shè)計上從內(nèi)存池中獲取內(nèi)存這一操作是非線程安全的.
原因是設(shè)計者認(rèn)為內(nèi)存池被上層對象所擁有,線程安全應(yīng)該由上層對象去保證,這樣的話
,沒有鎖的問題會讓內(nèi)存分配變得非常的快.
g).內(nèi)存池的行為像C++中的new的行為,當(dāng)內(nèi)存池獲取內(nèi)存chunks會拋出PJ_NO_MEMORY_EX
CEPTION異常,當(dāng)然,因為支持異常處理,也可以使用其它方式讓上層程序靈活的定義異常的
處理.
[這是異常處理的基本出發(fā)點,但是這有大量的爭論,原因是這改變了程序的正常流程,誰能
去保證這種流程是用戶所需要的呢,因此C++中的異常處理飽受爭議,請酌情使用]
h). 可以在后端使用任何的內(nèi)存分配器.默認(rèn)情況下是使用malloc/free管理內(nèi)存池的塊,
但是應(yīng)用程序也可以指定自己的策略(strategy),例如從一個全局存儲空間分配內(nèi)存.

恩,要知道,任何事務(wù)都是兩面的(頗為佩服創(chuàng)造出“雙贏”這個詞的語言天才, 不過,文
字游戲?qū)τ诩夹g(shù)人員不能說是件好事情:(),好了,使用時,不要認(rèn)為這個內(nèi)存池是哪種"per
fect"的技術(shù),要記得"任何設(shè)計,都是在各種限制條件中的一個折中,對于'戴著鐐銬的舞蹈
',除了'舞蹈',也不要忘記'鐐銬'哦",不要忘了告誡:):
告誡[Caveats]:
a).使用合適的大小來初始化內(nèi)存池.
使用內(nèi)存池時,需要指定一個初始內(nèi)存池大小, 這個值是內(nèi)存池的初始值,如果你想要高
性能,要謹(jǐn)慎選擇這個值哦,太大的化會浪費內(nèi)存,過小又會讓內(nèi)存池自身頻繁的去增加內(nèi)存
,顯然這兩種情況都不可取.
b). 注意,內(nèi)存池只能增加,而不能被縮小(shrink),因為內(nèi)存池沒有函數(shù)把內(nèi)存chunks釋
放還給系統(tǒng),這就要去內(nèi)存池的構(gòu)造者和使用者明確使用內(nèi)存.

恩,基本的原理都差不多了,后面我們來看看如何使用這個內(nèi)存池.

5.2內(nèi)存池的使用[Using Memory Pool]
內(nèi)存池的使用相當(dāng)?shù)暮唵?扳個手指頭就搞定了,如果你看明白了上面的原理和特征:)

a).創(chuàng)建內(nèi)存池工廠[Create Pool Factory]
上面不是提及內(nèi)存池的內(nèi)部分配策略以及異常處理方式么, 其實這就是指定這個的:)

當(dāng)然,不需要你每個內(nèi)存池都自己取指定策略和異常處理方式,PJLIB已經(jīng)有了一個默認(rèn)的
實現(xiàn):Caching Pool Factory,這個內(nèi)存池工廠的初始化使用函數(shù)pj_caching_pool_init()


b).創(chuàng)建內(nèi)存池[Create The Pool]
使用pj_pool_create(),其參數(shù)分別為內(nèi)存工廠(Pool Factory),內(nèi)存池的名字(name),初
始時的大小以及增長時的大小.

c).根據(jù)需要分配內(nèi)存[Allocate Memory as Required]
然后,你就可以使用pj_pool_alloc(), pj_pool_calloc(), 或pj_pool_zalloc()從指定
的內(nèi)存池根據(jù)需要去獲取內(nèi)存了:)

d).Destroy內(nèi)存池[Destroy the Pool]
這實際上是把預(yù)分配的內(nèi)存還給系統(tǒng).

e).Destroy內(nèi)存池工廠[Destroy the Pool Factory]
這沒什么好說的.

很簡單吧:)
作者在文檔中給出了一個例子:
如下:
#include 

   #define THIS_FILE    "pool_sample.c"

   static void my_perror(const char *title, pj_status_t status)
   {
        char errmsg[PJ_ERR_MSG_SIZE];

        pj_strerror(status, errmsg, sizeof(errmsg));
        PJ_LOG(1,(THIS_FILE, "%s: %s [status=%d]", title, errmsg, status));
   }

   static void pool_demo_1(pj_pool_factory *pfactory)
   {
        unsigned i;
        pj_pool_t *pool;

        // Must create pool before we can allocate anything
        pool = pj_pool_create(pfactory,  // the factory
                              "pool1",   // pool's name
                              4000,      // initial size
                              4000,      // increment size
                              NULL);     // use default callback.
        if (pool == NULL) {
            my_perror("Error creating pool", PJ_ENOMEM);
            return;
        }

        // Demo: allocate some memory chunks
        for (i=0; i<1000; ++i) {
            void *p;

            p = pj_pool_alloc(pool, (pj_rand()+1) % 512);

            // Do something with p
            ...

            // Look! No need to free p!!
        }

        // Done with silly demo, must free pool to release all memory.
        pj_pool_release(pool);
   }

   int main()
   {
        pj_caching_pool cp;
        pj_status_t status;

        // Must init PJLIB before anything else
        status = pj_init();
        if (status != PJ_SUCCESS) {
            my_perror("Error initializing PJLIB", status);
            return 1;
        }

        // Create the pool factory, in this case, a caching pool,
        // using default pool policy.
        pj_caching_pool_init(&cp, NULL, 1024*1024 );

        // Do a demo
        pool_demo_1(&cp.factory);

        // Done with demos, destroy caching pool before exiting app.
        pj_caching_pool_destroy(&cp);

        return 0;
   }
   
   我就不解釋了:)

 


(中國集群通信網(wǎng) | 責(zé)任編輯:李俊勇)
本文標(biāo)簽: VOIP, PJSIP, SIP

相關(guān)文章

中國集群通信網(wǎng),國內(nèi)首家集群通信專業(yè)網(wǎng)站。

Copyright © PttCn.Net, All Rights Reserved.   

聯(lián)系我們 聯(lián)系我們 中國集群通信網(wǎng) 對講機(jī)學(xué)堂 對講機(jī)世界

免费在线观看的电影网站| 亚洲码欧美码一区二区三区| 视频在线你懂的| jvid福利在线一区二区| 色噜噜狠狠色综合网| 好看的中文字幕在线播放| 亚洲美女免费在线| 国内精品国产三级国产a久久| 久久噜噜亚洲综合| 最新中文字幕在线观看| 国产精品理伦片| 91色婷婷久久久久合中文| 精品综合久久久久久97| 日本高清不卡在线观看| 日本免费看黄色| 欧美激情第3页| 五月激情六月综合| 日本不卡免费在线视频| 欧美在线视频不卡| 青青草精品毛片| 亚洲成av人片在www色猫咪| 国产精品熟女视频| 日本人妻熟妇久久久久久| 欧美三日本三级三级在线播放| 黄色污污视频软件| 亚洲人午夜精品天堂一二香蕉| 中文字幕中文在线| 亚洲国产欧美日韩在线观看第一区| 国产精品一区二区果冻传媒| 亚洲欧美日韩精品一区二区| 久久久国产精品无码| 噜噜噜噜噜在线视频| 夜夜操夜夜骑| 欧美jizzhd69巨大| 国产精品国产自产拍高清av| 蜜桃91丨九色丨蝌蚪91桃色| 国产乱淫av片杨贵妃| 欧美精品 - 色网| 免费人成网站在线观看欧美高清| 欧美精品一区二区三区久久久| 91精品国产综合久久久久久久久| 国产精品777777| 亚洲色图另类图片| 日本在线观看一区| 亚洲精品乱码久久久久久| 不卡av在线播放| 中文字幕资源网在线观看| 欧美娇小性xxxx| 亚洲男人天堂影院| 国产极品在线视频| 极品少妇一区二区三区| 国产精品美女免费看| 欧美丰满少妇xxxxx| 亚洲欧美国产日韩天堂区| 亚洲成人在线视频播放| 四虎永久在线精品无码视频| 日本免费在线观看视频| 久久福利免费视频| www99热| 欧美久草视频| 狂野欧美性猛交xxxx乱大交| 美女激情视频网站| 国产精品极品美女在线观看免费| 国产一区二区三区四区视频| 一级aaaa毛片| 久操视频在线免费观看| 欧美电影在线观看一区| 黄网址在线观看| 欧美性受极品xxxx喷水| 国内精品偷拍视频| 领导边摸边吃奶边做爽在线观看| 三级外国片在线观看视频| 欧美日韩免费高清一区色橹橹| 在线免费av导航| 欧美色欧美亚洲另类七区| 精品麻豆剧传媒av国产九九九| 日本少妇激情舌吻| 91九色蝌蚪在线| 少妇愉情理伦三级| 不卡的av影片| 国产激情视频一区| 国内精品久久久久影院 日本资源| 欧美精品卡一卡二| 国产精品无码久久久久成人app| 精品视频在线你懂得| 国产一区二区三区四区福利| 免费黄色电影在线观看| 精品人在线二区三区| 在线无限看免费粉色视频| 亚洲一区二区欧美日韩| 91精品国产91久久久久久黑人| 一本大道一区二区三区| 水蜜桃一区二区| 国产日韩精品在线播放| 蜜桃精品视频在线观看| 中文精品视频一区二区在线观看| 91网站在线看| 国产精品传媒麻豆hd| 男女羞羞免费视频| 天天操天天干天天摸| 尤物在线观看视频| 91亚洲精品国产| 中文字幕日韩精品久久| 奇米色在线视频| 成人亚洲欧美激情在线电影| 日本wwwxxxx| 国产精品美女xx| 头脑特工队2在线播放| 国产精品996| 成人黄色毛片| 一本色道久久综合熟妇| 极品中文字幕一区| www.涩涩爱| 欧美 日韩 激情| jizzjizz日本少妇| 国产精品久久777777换脸| 久久一留热品黄| 国产富婆一区二区三区| 国产高清免费av| 精品久久久av| 538国产精品一区二区免费视频| 青青草在线观看视频| 精品国产亚洲一区二区三区大结局| 日韩黄色大片网站| 明星国产一级毛片范冰冰视频| 亚洲精品久久久久久久蜜桃臀| 手机看片久久久| 91精品国产麻豆| 成年女人免费又黄又爽视频| 久久这里只有精品1| 波多野结衣在线观看一区二区| 一级片久久久久| 深夜福利国产精品| 亚洲精品爱爱久久| 日本免费高清一区二区| 欧美成人禁片在线观看网址| 欧美卡一卡二| 视频一区亚洲| 色欧美片视频在线观看在线视频| 日韩成人一区二区三区| 高清无码视频直接看| 精品一区二区三区在线| 精品一区二区三区在线观看| 国产三级精品三级在线| 一个色在线综合| 高清欧美性猛交| 久久精品网址| 痴汉一区二区三区| 国产精品3区| 欧美极品少妇xxxxⅹ免费视频| 国产一区二区三区小说| yourporn在线观看中文站| 日韩一区二区三区四区五区六区| 亚洲第一男人天堂| 香蕉视频免费在线播放| 鲁一鲁一鲁一鲁一色| 女~淫辱の触手3d动漫| 久草在线资源福利| 在线观看欧美日韩电影| 国产精品熟女久久久久久| 欧洲一区在线观看| 国产日韩欧美一区二区三区四区| 国产又爽又黄无码无遮挡在线观看| 五月婷婷在线观看视频| 激情av在线播放| 高潮按摩久久久久久av免费| 视频一区 中文字幕| 免费福利视频一区二区三区| 亚洲人在线观看视频| 欧洲金发美女大战黑人| 欧美a在线视频| 粉嫩av一区| 狠狠色成人综合网图片区| jizz中文字幕| 成人av番号网| 精品国产电影一区| 在线免费一区三区| 久久久久99精品成人片我成大片| 亚洲国产一区二区精品专区| 国产精品久久久久久亚洲调教| 国产女人水真多18毛片18精品视频| 国产第一页在线播放| 日韩在线视频网站| 欧美熟妇另类久久久久久不卡| 波多野结衣久久高清免费| 99精品视频在线播放免费| 久久精品ww人人做人人爽| 色综合色综合色综合色综合| 美女av一区二区| 亚洲专区一区二区三区| 最近中文字幕免费视频| 亚洲精品视频观看| 欧美巨猛xxxx猛交黑人97人| 青草青青在线视频| 欧美不卡视频在线观看| 男人天堂av网站| 国产美女撒尿一区二区| 中文字幕一区二区三区人妻在线视频| 色婷婷综合久久久中文一区二区| 国产欧美一区二区精品久导航| 9l视频自拍九色9l视频成人| 欧美在线网址| 麻豆91精品91久久久| 久久精品视频在线免费观看| 国产一级片免费在线观看| 在线观看日韩av先锋影音电影院| 精品人妻人人做人人爽| av一级在线| 亚洲第一二三四区| 国产婷婷一区二区三区| 国产一区二区三区四区五区加勒比| 国产色婷婷亚洲99精品小说| 国产九一视频| 欧美偷窥清纯综合图区| 性欧美孕妇孕交| 亚洲免费黄色网| 亚洲一区区二区| 色哟哟在线观看视频| 久久亚洲国产精品| 久久久9999久久精品小说| 日本视频在线| 国产www.大片在线| 欧美午夜精品理论片a级按摩| 成人欧美一区二区三区黑人| 欧美做a欧美| 亚洲影视第一页| 在线观看麻豆视频| 蜜桃久久影院| 中文字幕资源网| 国内精品视频一区二区三区八戒| 久久一综合视频| 国产三级久久久| h网站在线看| 久久精品国产96久久久香蕉| 少妇被狂c下部羞羞漫画| 久久久一区二区三区四区| 亚洲丝袜美腿一区| 免费在线中文字幕| 国产精品麻豆一区| 色网在线播放| 婷婷亚洲久悠悠色悠在线播放| 国产精选第一页| 国产精品电影久久久久电影网| 成人一区二区三区仙踪林| 欧美精品少妇videofree| 日本精品一区在线观看| 黑人精品一区二区| av色影在线看免费| 人妖一区二区三区| 日韩欧美电影在线| 国产乱码精品一区二区三区卡| 日韩不卡视频在线观看| 六月婷婷激情综合| 五月天婷婷综合网| 婷婷中文字幕在线观看| 成人黄色片视频| 最新97超碰在线| 欧美mv和日韩mv国产网站| 熟女性饥渴一区二区三区| 亚洲女人的天堂| 国产欧美一区二区三区精品酒店| 国产探花一区二区三区| 99国产精品久久久久久久成人热| 最新日本中文字幕| www插插插无码免费视频网站| 亚洲男人天堂2023| 亚洲人体一区| 欧洲精品在线播放| 色多多视频在线播放| 卡一精品卡二卡三网站乱码| 国产一区二区三区视频在线| 国产精品影院在线观看| 夜夜骑日日射| www.午夜激情| 国产精品免费看久久久无码| 精品一区二区成人精品| 久久久久久久中文字幕| 精品久久久影院| 国产精品综合在线视频| 国产一级二级视频| 麻豆app在线观看| 日韩精品欧美一区二区三区| 91国内精品在线视频| 亚洲调教一区| 丝袜视频国产在线播放| 北条麻妃av高潮尖叫在线观看| 亚洲视频免费观看| 一级二级三级在线观看| 大色综合视频网站在线播放| 青草影视电视剧免费播放在线观看| 农村妇女精品一区二区| 日韩欧美高清dvd碟片| 成人在线黄色| 欧美日韩国产第一页| 免费污视频在线一区| 黄色小网站91| 中文字幕欧美日本乱码一线二线| 日韩国产在线播放| 久久精品一级片| 亚洲图片制服诱惑| 国产免费一区二区视频| 黄色av一区二区| 精品人妻一区二区三区麻豆91| 超碰caoporn久久| 一道本无吗dⅴd在线播放一区| 伊人久久久久久久久| 日韩国产欧美精品在线| 一区二区视频在线观看| 欧美乱偷一区二区三区在线| 97色在线观看| 78国产伦精品一区二区三区| 亚洲AV无码成人片在线观看| 高清在线观看日韩| 中文字幕色一区二区| 国产免费大片| 亚洲在线观看| 国产精品日韩av| 色偷偷亚洲女人天堂观看欧| 亚洲人成网站777色婷婷| 亚洲成av人片在线观看香蕉| 精品久久国产| 精品视频无码一区二区三区| √天堂资源在线| 久久99精品国产自在现线小黄鸭| 怡红院男人的天堂| 欧美一区二区色| 精品久久久网站| www.av一区视频|