尤物国产精品_亚洲欧美校园另类一区_日韩无码久久精品视频_深夜大秀直播APP_中文字幕暖暖永久在线视频_水野优香中文字幕av网站_男女干逼免费网站无遮挡_北条麻妃av在线播放_国产白嫩色啪视频_人妻精品无码喷水

東莞市德峰智能科技有限公司

聯(lián)系我們Contact

您的位置: 首頁 ->  技術(shù)支持 -> 關(guān)于ZIGBEE技術(shù)

關(guān)于ZIGBEE技術(shù)



Zigbee的由來

在藍(lán)牙技術(shù)的使用過程中,人們發(fā)現(xiàn)藍(lán)牙技術(shù)盡管有許多優(yōu)點(diǎn),但仍存在許多缺陷。對工業(yè),家庭自動(dòng)化控制和遙測遙控領(lǐng)域而言,藍(lán)牙技術(shù)顯得太復(fù)雜,功耗大,距離近,組網(wǎng)規(guī)模太小等,而工業(yè)自動(dòng)化對無線通信的需求越來越強(qiáng)烈。正因此,經(jīng)過人們長期努力,Zigbee協(xié)議在2003年中通過后,于2004正式問世了。

Zigbee是什么

Zigbee是一個(gè)由可多到65000個(gè)無線數(shù)傳模塊組成的一個(gè)無線數(shù)傳網(wǎng)絡(luò)平臺(tái),十分類似現(xiàn)有的移動(dòng)通信的CDMA網(wǎng)或GSM網(wǎng),每一個(gè)Zigbee網(wǎng)絡(luò)數(shù)傳模塊類似移動(dòng)網(wǎng)絡(luò)的一個(gè)基站,在整個(gè)網(wǎng)絡(luò)范圍內(nèi),它們之間可以進(jìn)行相互通信;每個(gè)網(wǎng)絡(luò)節(jié)點(diǎn)間的距離可以從標(biāo)準(zhǔn)的75米,到擴(kuò)展后的幾百米,甚至幾公里;另外整個(gè)Zigbee網(wǎng)絡(luò)還可以與現(xiàn)有的其它的各種網(wǎng)絡(luò)連接。例如,你可以通過互聯(lián)網(wǎng)在北京監(jiān)控云南某地的一個(gè)Zigbee控制網(wǎng)絡(luò)。

不同的是,Zigbee網(wǎng)絡(luò)主要是為自動(dòng)化控制數(shù)據(jù)傳輸而建立,而移動(dòng)通信網(wǎng)主要是為語音通信而建立;每個(gè)移動(dòng)基站價(jià)值一般都在百萬元人民幣以上,而每個(gè)Zigbee“基站”卻不到1000元人民幣;每個(gè)Zigbee 網(wǎng)絡(luò)節(jié)點(diǎn)不僅本身可以與監(jiān)控對對象,例如傳感器連接直接進(jìn)行數(shù)據(jù)采集和監(jiān)控,它還可以自動(dòng)中轉(zhuǎn)別的網(wǎng)絡(luò)節(jié)點(diǎn)傳過來的數(shù)據(jù)資料; 除此之外,每一個(gè)Zigbee網(wǎng)絡(luò)節(jié)點(diǎn)(FFD)還可在自己信號覆蓋的范圍內(nèi),和多個(gè)不承擔(dān)網(wǎng)絡(luò)信息中轉(zhuǎn)任務(wù)的孤立的子節(jié)點(diǎn)(RFD)無線連接。

每個(gè)Zigbee網(wǎng)絡(luò)節(jié)點(diǎn)(FFD和RFD)可以可支持多到31個(gè)的傳感器和受控設(shè)備,每一個(gè)傳感器和受控設(shè)備終可以有8種不同的接口方式。可以采集和傳輸數(shù)字量和模擬量。

Zigbee技術(shù)的應(yīng)用領(lǐng)域

Zigbee技術(shù)的目標(biāo)就是針對工業(yè),家庭自動(dòng)化,遙測遙控,汽車自動(dòng)化、農(nóng)業(yè)自動(dòng)化和醫(yī)療護(hù)理等,例如燈光自動(dòng)化控制,傳感器的無線數(shù)據(jù)采集和監(jiān)控,油田,電力,礦山和物流管理等應(yīng)用領(lǐng)域。另外它還可以對局部區(qū)域內(nèi)移動(dòng)目標(biāo)例如城市中的車輛進(jìn)行定位.

通常,符合如下條件之一的應(yīng)用,就可以考慮采用Zigbee技術(shù)做無線傳輸:

1.需要數(shù)據(jù)采集或監(jiān)控的網(wǎng)點(diǎn)多;

2.要求傳輸?shù)臄?shù)據(jù)量不大,而要求設(shè)備成本低;

3.要求數(shù)據(jù)傳輸可性高,安全性高;

4.設(shè)備體積很小,不便放置較大的充電電池或者電源模塊;

5.電池供電;

6.地形復(fù)雜,監(jiān)測點(diǎn)多,需要較大的網(wǎng)絡(luò)覆蓋;

7.現(xiàn)有移動(dòng)網(wǎng)絡(luò)的覆蓋盲區(qū);

8.使用現(xiàn)存移動(dòng)網(wǎng)絡(luò)進(jìn)行低數(shù)據(jù)量傳輸?shù)倪b測遙控系統(tǒng)。

9.使用GPS效果差,或成本太高的局部區(qū)域移動(dòng)目標(biāo)的定位應(yīng)用。

Zigbee 技術(shù)的特點(diǎn)

省電:兩節(jié)五號電池支持長達(dá)6個(gè)月到2年左右的使用時(shí)間。

可靠:采用了碰撞避免機(jī)制,同時(shí)為需要固定帶寬的通信業(yè)務(wù)預(yù)留了專用時(shí)隙,避免了發(fā)送數(shù)據(jù)時(shí)的競爭和沖突;節(jié)點(diǎn)模塊之間具有自動(dòng)動(dòng)態(tài)組網(wǎng)的功能,信息在整個(gè)Zigbee網(wǎng)絡(luò)中通過自動(dòng)路由的方式進(jìn)行傳輸,從而保證了信息傳輸?shù)目煽啃浴?/span>

時(shí)延短:針對時(shí)延敏感的應(yīng)用做了優(yōu)化,通信時(shí)延和從休眠狀態(tài)激活的時(shí)延都非常短。

網(wǎng)絡(luò)容量大:可支持達(dá)65000個(gè)節(jié)點(diǎn)。

安全:ZigBee提供了數(shù)據(jù)完整性檢查和鑒權(quán)功能,加密算法采用通用的AES-128。

高保密性:64位出廠編號和支持AES-128加密。

Zigbee的發(fā)展前景

Zigbee技術(shù)和RFID 技術(shù)在2004年就被列為當(dāng)今世界發(fā)展最快,市場前景最廣闊的十大最新技術(shù)中的兩個(gè)。關(guān)于這方面的報(bào)道,你只需在百度,或GOOGLE搜索欄中鍵入“Zigbee”,你就會(huì)看到大量的有關(guān)報(bào)道??傊?,今后若干年,都將是Zigbee技術(shù)飛速發(fā)展的時(shí)期。

Zigbee技術(shù)在我國的應(yīng)用情況

盡管,國內(nèi)不少人已經(jīng)開始關(guān)注Zigbee這們新技術(shù),而且也有不少單位開始涉足Zigbee技術(shù)的開發(fā)工作,然而,由于Zigbee 本身是一種新的系統(tǒng)集成技術(shù),應(yīng)用軟件的開發(fā)必須和網(wǎng)絡(luò)傳輸,射頻技術(shù)和底層軟硬件控制技術(shù)結(jié)合在一起。因而深入理解這個(gè)來自國外的新技術(shù),再組織一個(gè)在這幾個(gè)方面都有豐富經(jīng)驗(yàn)的配套的隊(duì)伍,本身就不是一件容易的事情,因而,到目前為止,國內(nèi)目前除了成都西谷曙光數(shù)字技術(shù)有限公司,真正將Zigbee技術(shù)開發(fā)成產(chǎn)品,并成功地用于解決幾個(gè)領(lǐng)域的實(shí)際生產(chǎn)問題而外,尚未見到其它報(bào)道。

Zigbee 和現(xiàn)有移動(dòng)網(wǎng)(GPRS,CDMA-1X)的比較

1.無網(wǎng)絡(luò)使用費(fèi):使用移動(dòng)網(wǎng)需要長期支付網(wǎng)絡(luò)使用費(fèi),而且是按節(jié)點(diǎn)終端的數(shù)量計(jì)算的,而Zigbee沒有這筆費(fèi)用;

2.設(shè)備投入低:使用移動(dòng)網(wǎng)需要購買移動(dòng)終端設(shè)備,每個(gè)終端的價(jià)格在人民幣1000元上下,而使用Zigbee 網(wǎng)絡(luò),不僅Zigbee網(wǎng)絡(luò)節(jié)點(diǎn)模塊(相當(dāng)于基站)費(fèi)用每只人民幣不到1000元,而且,主要使用的網(wǎng)絡(luò)子節(jié)點(diǎn)(相當(dāng)于手機(jī))的價(jià)格還要低得多;

3.通信更可靠:由于現(xiàn)有移動(dòng)網(wǎng)主要是為手機(jī)通信而設(shè)計(jì)的,盡管CDMA-1X和GPRS可以進(jìn)行數(shù)據(jù)通信,但實(shí)踐發(fā)現(xiàn),不僅通信數(shù)率比設(shè)計(jì)速率低很多,而且數(shù)據(jù)通信的可靠信也存在一定的問題。而Zigbee網(wǎng)絡(luò)則是專門為控制數(shù)據(jù)的傳輸而設(shè)計(jì)的,因而控制數(shù)據(jù)的傳輸具有相當(dāng)?shù)谋WC。
    4.高度的靈活性和低成本:首先,通過使用覆蓋距離不同,功能不同的Zigbee網(wǎng)絡(luò)節(jié)點(diǎn),以及其它非Zigbee系統(tǒng)的低成本的無線收發(fā)模塊,建立起一個(gè)Zigbee局部自動(dòng)化控制網(wǎng),(這個(gè)網(wǎng)絡(luò)可以是星型,樹狀,網(wǎng)狀及其共同組成的復(fù)合網(wǎng)結(jié)構(gòu))再通過互聯(lián)網(wǎng)或移動(dòng)網(wǎng)與遠(yuǎn)端的計(jì)算機(jī)相連,從而實(shí)現(xiàn)低成本,高效率的工業(yè)自動(dòng)化遙測遙控;

5.比起現(xiàn)有的移動(dòng)網(wǎng)來,盡管Zigbee僅僅只是一個(gè)局域網(wǎng),覆蓋區(qū)域有限,但它卻可以與現(xiàn)有的移動(dòng)網(wǎng),互聯(lián)網(wǎng)和其它通信網(wǎng)絡(luò)相連接,將許多Zigbee局域網(wǎng)相互連成為一個(gè)整體。有效的解決移動(dòng)網(wǎng)的盲區(qū)覆蓋問題:我們知道,現(xiàn)有移動(dòng)網(wǎng)絡(luò)在許多地方存在盲區(qū),特別是鐵路,公路,油田,礦山等野外,更是如此。而增加一個(gè)移動(dòng)基站或直放站的費(fèi)用是相當(dāng)可觀的,此時(shí)使用Zigbee網(wǎng)絡(luò)進(jìn)行盲區(qū)覆蓋不僅經(jīng)濟(jì)有效,而且往往是現(xiàn)在唯一可行手段。

Zigbee與現(xiàn)有數(shù)傳電臺(tái)的比較

1.可靠性高:由于Zigbee模塊的集成度遠(yuǎn)比一般數(shù)傳電臺(tái)高,分離元器件少,因而可靠性更高;

2.使用方便安全:因?yàn)榧啥雀撸绕鹨话銛?shù)傳電臺(tái)來,Zigbee收法模塊體積可以做得很小,而且功耗低,例如成都西谷公司遠(yuǎn)距離傳輸模塊(2-5公里),最大發(fā)射電流比一個(gè)CDMA手機(jī)還要小許多,因而很容易集成或直接安放在到設(shè)備之中,不僅使用方便,而且在戶外使用時(shí),不容易受到破壞;

3.抗干擾力強(qiáng),保密性好,誤碼率低:Zigbee收發(fā)模塊使用的是2.4G直序擴(kuò)頻技術(shù),比起一般FSK, ASK和跳頻的數(shù)傳電臺(tái)來,具有更好的抗干擾能力,和更遠(yuǎn)的傳輸距離;參閱我們網(wǎng)站中有關(guān)CDMA直序擴(kuò)頻技術(shù)的優(yōu)越性討論,和Cypress公司有關(guān)實(shí)驗(yàn)報(bào)道。

4.免費(fèi)頻段:Zigbee使用的是免費(fèi)頻段,而許多數(shù)傳電臺(tái)所使用的頻段不僅需要申請,而且每年都需要向國家無委會(huì)交納相當(dāng)?shù)念l率使用費(fèi)。

5.價(jià)格低: Zigbee數(shù)傳模塊的價(jià)格只有具有類似功能的數(shù)傳電臺(tái)的幾分之一;(2.4G,250kps,3-5公里距離DSSS 數(shù)傳模塊每只不到200元人民幣)

提供低成本,高可靠性的無線數(shù)傳互聯(lián)網(wǎng)平臺(tái)(包括軟件和硬件),以及相關(guān)技術(shù)支持,以滿足不同客戶的具體需要,就是我們的服務(wù)宗旨。

 

 

 

 

學(xué)習(xí)Zstack1

Zstack情況:

本人采用的是TI的Zstack1.4.3協(xié)議,據(jù)說這個(gè)需要IAR7.30B及以上版本,而目前市面上又沒有破解,所以用的人很少,這也是我的機(jī)會(huì)!呵呵?。ㄉ敌τ悬c(diǎn)多,關(guān)鍵是WORD里沒有表情符號,不能正常表達(dá)我此時(shí)的心情!)

正式開始:

開始之前在說一句:從TI網(wǎng)站上下載的Zstack的方法就不介紹了。否則就是從-1開始了而不是從0開始了-----------------我是這么覺得的!

第一步:安裝Zstack

從TI官方網(wǎng)站上下載的Zstack為:swrc072c.zip,我想這個(gè)壓縮包大家都認(rèn)識。解壓之后為:ZStack-CC2430-1.4.3.exe文件。這個(gè)安裝文件大家都會(huì)了。默認(rèn)安裝路徑為:C:\Texas Instruments\ZStack-1.4.3。安裝之后在C:\Texas Instruments\ZStack-1.4.3目錄下有各PDF文檔為:Getting Started Guide CC2430.pdf,不用多說,這個(gè)肯定是要看的。既然把它放到這么前面,說明它是入門中的入門文檔。下面就簡單介紹下這個(gè)文檔:
1、介紹了安裝ZStack-CC2430-1.4.3.exe需要的硬件軟件條件:需要電腦、操作系統(tǒng)為Windows 2000或 Windows XP。至于更高或更低版本的本人沒有嘗試。
2、講了安裝流程。這個(gè)有點(diǎn)多余了,這年月哪個(gè)有電腦的沒有安裝上百上千次的軟件?。康切枰獜?qiáng)調(diào)的是安裝路徑----默認(rèn)就好!
3、接下來就是讓我們看的第一個(gè)文檔為:
Start->Programs->Texas Instruments->ZStack-1.4.3->Z-Stack User’s Guide,
既然讓我看我就來看看這個(gè)文檔!!

第二步:Z-Stack 用戶指導(dǎo)

這個(gè)文檔的更新時(shí)間為:2007年12月21日----應(yīng)該還是比較新的版本。由于本人英文的卻有限,就不翻譯了,瀏覽一遍,把大概意思說下就可以了:
1、介紹
1.1、適用范圍
本文檔適用于CC2430ZigBee開發(fā)板----CC2430ZDK。
2、產(chǎn)品包描述(TI提供的CC2430ZDK工具包)
2.1、安裝包內(nèi)容
這個(gè)就是上面提到的的ZStack-CC2430-1.4.3.exe安裝之后的所有內(nèi)容了。說白了就是包含Zstack開發(fā)所需要的所有軟件和文檔資料等。
2.2、開發(fā)板介紹
兩塊 SmartRF04EB 評估版,每個(gè)都可以用于CC2430EM評估模塊。如圖1-1所示:
 

個(gè)人認(rèn)為要求已經(jīng)相當(dāng)?shù)土?,如果你的電腦沒有這配置,個(gè)人強(qiáng)烈建議馬上扔掉!不過如今筆記本電腦很少有串口的,所以建議使用臺(tái)式電腦,而且裝機(jī)的時(shí)候一定要把串口引出,否則就比較麻煩了!
3.2、目標(biāo)板需求

其實(shí)也是開發(fā)環(huán)境需求--- IAR EW8051。目前需要的版本為7.30B及以上。要求還是比較高的,因?yàn)槟壳斑@個(gè)版本沒有破解的。但是在http://www.iar.com/上有30天評估版下載。這個(gè)版本使用一定要小心,因?yàn)槿绻?0天之后僅僅是卸載IAR重新安裝是沒有用的,一般最笨的辦法是重新安裝操作系統(tǒng)。解決這個(gè)問題最好的辦法就是買正版,呵呵,我想絕大多數(shù)像我這樣的中國人都不會(huì)買的。除此之外最好的辦法就是破解,但是目前這個(gè)破解極少,都是需要收費(fèi)的,而且都是國外網(wǎng)站才有,所以我們就只好期望中國的高人抓緊破解并公開了!當(dāng)然其他解決辦法就相對來說很多了,比如安裝后弄個(gè)還原點(diǎn)什么的;或者安裝后我不停地使用(每天24小時(shí)),30天之后我覺得你也學(xué)會(huì)了,就不用IAR這個(gè)版本了,說不定就移植到低版本上去了;等等類似之法我覺得都可以的。本人采用的是本辦法中相對比較聰明的,也是一位高人告訴我的:裝個(gè)虛擬操作系統(tǒng),在虛擬操作系統(tǒng)下時(shí)間可以隨時(shí)更改,讓它一直停留在某個(gè)時(shí)間,主要30天的試用就比較慢長了,只要你不要忘記改那時(shí)間。
4、產(chǎn)品安裝過程
4.1、安裝Z-Stack

這個(gè)也就是安裝ZStack-CC2430-1.4.3.exe的過程。
4.2、IAR安裝

一般來說安裝選擇默認(rèn)路徑,但是自定義路徑也不會(huì)出問題的。注意IAR版本7.30B及以上版本才可以運(yùn)行1.4.3協(xié)議。
4.3、設(shè)備IEEE地址

每個(gè) CC2430DB, CC2430EM,和 CC2431EM都已經(jīng)排列了一個(gè)唯一的64位物理地址(IEEE地址),這個(gè)地址已經(jīng)寫到了CC2430內(nèi)部FLASH里面,在CC2430DB, CC2430EM,和 CC2431EM板的底部有這個(gè)地址標(biāo)簽。

這個(gè)地址被寫入到FLASH的0x1FFF8地址中,注意這個(gè)地址也可以更改的,通過些FLASH軟件,一般0xFFFFFFFFFFFFFFFF地址被認(rèn)為是無效地址。
5、配置并試用Z-Stack
5.1、配置Z-Stack

這個(gè)詳見5.3節(jié)。
5.2、邏輯類型

這里主要是介紹了ZIGBEE協(xié)議中的三種設(shè)備類型:
ZigBee 協(xié)調(diào)者(ZC):這個(gè)設(shè)備被配置為初始化并建立一個(gè)PAN網(wǎng)絡(luò)
ZigBee 路由器(ZR):該設(shè)備被配置為加入一個(gè)存在的網(wǎng)絡(luò),可以加入一個(gè)協(xié)調(diào)求或路由器,然后允許其他設(shè)備加入它,在網(wǎng)絡(luò)中路有數(shù)據(jù)信息。
ZigBee 終端節(jié)點(diǎn) (ZED):該設(shè)備被配置為加入一個(gè)存在的網(wǎng)絡(luò),可以加入一個(gè)協(xié)調(diào)求或路由器。
5.3、建立樣品應(yīng)用設(shè)備:SampleApp
基本上就是采用SampleApp應(yīng)用中的Demo例子來演示整個(gè)流程,就是采用一個(gè)協(xié)調(diào)器和一個(gè)或多個(gè)路由器來形成一個(gè)ZigBee網(wǎng)絡(luò)演示。在該例子中主要通過SmartRF04EB板上的某些跳線來完成設(shè)備類型的選型,當(dāng)然這個(gè)方法在程序中是需要判斷哪個(gè)按鍵被拉低或拉高,對于做個(gè)設(shè)計(jì)的來說應(yīng)該是相當(dāng)好理解的。

申明:由于本人很窮,所以沒錢買TI原裝開發(fā)包,當(dāng)然也就沒有上面提到的硬件,本人采用的是某家公司(為了避免廣告,這里就不說明了)的硬件系統(tǒng)。
5.4、建立一個(gè)SampleLight協(xié)調(diào)器設(shè)備

至于提到的硬件連接這里一律省略。

無疑:首先要打開對應(yīng)工程,如圖1-4所示:
圖1-4
在工作窗口中選擇DemoEB,如圖1-5所示:
 
圖1-5
然后選擇工程菜單(Project)下的全部編譯(Rebuild All)選項(xiàng),如圖1-6所示:
 
圖1-6
然后選擇工程菜單(Project)下的調(diào)試(Debug)選項(xiàng),如圖1-7所示:
 
圖1-7
下載完之后就可以退出調(diào)試狀態(tài),通過選中調(diào)試菜單下的停止調(diào)試選項(xiàng),如圖1-8所示:
 

圖1-8
按照此種方法下載至少兩個(gè)CC2430EM模塊,就可以進(jìn)行Demo演示了。
6、 Z-Stack 示范

至于詳細(xì)的示范流程,這里先不說了,因?yàn)楸救瞬捎玫挠布c原裝有點(diǎn)差異,即使按照這個(gè)方法下載仍然不能演示,因?yàn)槲疫@個(gè)不能用跳線來選擇設(shè)備類型。

所以我必須進(jìn)入程序把跳線判斷程序進(jìn)行簡單必要的修改才能演示。

該文檔介紹的演示結(jié)果及現(xiàn)象都是基于CHIPCON原廠評估板。

7.PanID和通道(Channel)選擇

ZigBee協(xié)議規(guī)范規(guī)定,一個(gè)14位的個(gè)域網(wǎng)標(biāo)志符(PAN ID)來標(biāo)識唯一的一個(gè)網(wǎng)絡(luò)。Z-Stack可以用兩種方式由用戶自己選擇其PAN ID,當(dāng)ZDAPP_CONFIG_PAN_ID值設(shè)置不為0xFFFF時(shí),那么設(shè)備建立或加入網(wǎng)絡(luò)的PAN ID由ZDAPP_CONFIG_PAN_ID指定;如果設(shè)置ZDAPP_CONFIG_PAN_ID為0xFFFF;那么設(shè)備就將建立或加入它發(fā)現(xiàn)網(wǎng)絡(luò)中的“最好”的網(wǎng)絡(luò)。關(guān)于這里提到的“最好”的網(wǎng)絡(luò),我覺得可能是有些參數(shù)評估,只不過這里沒有詳細(xì)的介紹,在后續(xù)文檔中應(yīng)該有介紹的。

在2.4G頻段上,IEEE 802.15.4/ZIGBEE規(guī)范規(guī)定了16各頻道。用戶可以通過選擇DEFAULT_CHANLIST不同的值可以選擇不同的頻道,其頻道如圖1-9所示。改協(xié)議默認(rèn)頻道為0xB及0x00000800。


圖1-9
DEFAULT_CHANLIST 和 ZDAPP_CONFIG_PAN_ID都作為IAR IDE中的編譯選項(xiàng)可以進(jìn)行設(shè)置,在應(yīng)用文件中的…\Projects\Tools\CC2430DB目錄下的f8wConfig.cfg文件中有相應(yīng)設(shè)置,如圖1-10所示。

圖1-10

 

 

 

 

 

 

 

 

 

 

學(xué)習(xí)Zstack之2

上節(jié)基本上初步認(rèn)識了Zstack的一些情況,今天繼續(xù)我的學(xué)習(xí),打開Sample例子看看,究竟ZIGBEE是怎么回事。

毫無疑問:如果是第一次打開這個(gè)例子工程,肯定很迷糊,因?yàn)榇藭r(shí)我迷糊了。對圖2-1我簡直是相當(dāng)迷糊。
 
圖2-1

這么多文件夾,打開之后又有那么多文件,從何看起?不要著急,特別是有些人拿到之后,啥都不知道的人第一個(gè)問題就是:我要實(shí)現(xiàn)XXX,在哪修改或者在哪添加我的函數(shù)呢?凡是我遇到這樣的客戶,我就可以肯定他技術(shù)部咋的。就連我這個(gè)外行都知道,不把這些弄明白,就是實(shí)現(xiàn)XXX只需要修改一個(gè)字母,那也不知道在哪改啊?所以我不急,但是我也理解很多客戶,因?yàn)橛袝r(shí)候項(xiàng)目催的比較急,畢竟老板都是外行嘛!

兩條路:1就是先看主函數(shù),2就是看看TI提供例子說明文檔沒有。

我這里先看看主函數(shù)再說哈!因?yàn)槲揖椭缽闹骱瘮?shù)看起.

沒辦法大概每個(gè)文件夾找啊,主函數(shù)的特征還是比較明明顯的,見圖2-2所示:
 
圖2-2
下面把主函數(shù)復(fù)制過來簡單看下:
ZSEG int main( void )
{
// Turn off interrupts------------關(guān)閉中斷
osal_int_disable( INTS_ALL );
// Initialize HAL-----------初始化HAL,關(guān)于HAL是什么我想后面會(huì)有介紹的。
HAL_BOARD_INIT();
// Make sure supply voltage is high enough to run----電壓檢測,最好是能保證芯片能正常工作的電壓
zmain_vdd_check();
// Initialize stack memory-------------初始化stack存儲(chǔ)區(qū)
zmain_ram_init();
// Initialize board I/O------------初始化板載IO
InitBoard( OB_COLD );
// Initialze HAL drivers-------------初始化HAL驅(qū)動(dòng)
HalDriverInit();
// Initialize NV System--------------初始化NV系統(tǒng),NV是什么后面我想也會(huì)有介紹的
osal_nv_init( NULL );
// Determine the extended address------------確定擴(kuò)展地址(64位IEEE/物理地址)
zmain_ext_addr();
// Initialize basic NV items----------------初始化基本NV條目
zgInit();
// Initialize the MAC----------------初始化MAC
ZMacInit();
#ifndef NONWK
// Since the AF isn't a task, call it's initialization routine
afInit();
#endif
// Initialize the operating system----------初始化操作系統(tǒng),看樣子這里面還有OS,麻煩了……..!
osal_init_system();

// Allow interrupts-------------允許中斷
osal_int_enable( INTS_ALL );
// Final board initialization------------------最后的版在初始化
InitBoard( OB_READY );
// Display information about this device---------------顯示設(shè)備信息
zmain_dev_info();
/* Display the device info on the LCD */------------液晶支持顯示
#ifdef LCD_SUPPORTED
zmain_lcd_init();
#endif
osal_start_system(); // No Return from here-------------------這里沒有返回,大概是進(jìn)入OS了。
} // main()

可以看到基本上都是初始化函數(shù),因?yàn)楹瘮?shù)名稱都基本上帶了init字樣的,呵呵,個(gè)人覺得TI的變成習(xí)慣比我好,一看名稱就知道大概功能了。所以這里也奉勸各位像我這樣菜鳥級的初學(xué)者,一開始一定就要養(yǎng)成規(guī)范化編程的習(xí)慣,據(jù)說這樣維護(hù)以及以后升級或者移植兼容性都比較好。我就先不管各個(gè)初始化函數(shù)是怎么實(shí)現(xiàn)的,我先看看各個(gè)功能是什么,現(xiàn)掌握整體功能在細(xì)化,我覺得這樣的學(xué)習(xí)方法比較好,因?yàn)榇a是在太多了,從一開始就逐句看,我敢保證沒幾個(gè)人有耐心看完看明白!

幸好每個(gè)初始化函數(shù)都有一句說明,雖然是英文的,但是理解起來一點(diǎn)都不難的。關(guān)于每個(gè)函數(shù)的功能我就直接寫在上面的程序里面,節(jié)省紙張哈!

一句話:主函數(shù)的功能就是初始化!

主函數(shù)看完了又開始模糊了,又從何看起呢?在無從下手之際,只有去尋求TI說明文檔的幫助了。上節(jié)不是漏掉了內(nèi)容,是關(guān)于演示結(jié)果的,這里做上補(bǔ)充,怕因?yàn)槿闭{(diào)一點(diǎn)后面遇到什么不理解的就慘了!

Sample例子演示演示現(xiàn)象:
1、認(rèn)識硬件------------按鍵和LED

上節(jié)提到了EM和DB兩個(gè)板子,其硬件是不一樣的。按鍵EM就有5各SW1~SW5,而DB只有1各方向鍵,但是他們有個(gè)對應(yīng)關(guān)系,如圖2-3所示.

圖2-3

LED數(shù)量和顏色也不一樣,EM有四個(gè)LED,如圖2-4;而DB只有兩個(gè),如圖2-5。
如圖2-4

如圖2-5

關(guān)于上面幾個(gè)圖2-4/5中出現(xiàn)的LEDx實(shí)際上是程序中出現(xiàn)的關(guān)鍵字。
2、初始化64位IEEE地址

實(shí)際上在主函數(shù)中有這么個(gè)初始化函數(shù)的:zmain_ext_addr()。這里說如果地址復(fù)位為0xFFFFFFFFFFFFFFFF的話,那么就會(huì)不停的閃爍LED1,一直等到按鍵SW5按下后程序才能繼續(xù)運(yùn)行,意思就是說按下SW5后就把無效的地址初始化為有效地物理地址了,這個(gè)應(yīng)該是程序上實(shí)現(xiàn)的,那么就來看看對應(yīng)的程序zmain_ext_addr。
/*********************************************************************
* @fn   zmain_ext_addr
* @brief   Makes extended address if none exists.確定擴(kuò)展地址是有效的
* @return  none
 *********************************************************************/
static ZSEG void zmain_ext_addr( void )
{
uint8 i;
uint8 led;
uint8 tmp;
uint8 *xad;
uint16 AtoD;
// Initialize extended address in NV初始化NV里的擴(kuò)載地址
osal_nv_item_init(ZCD_NV_EXTADDR,Z_EXTADDR_LEN, NULL );
osal_nv_read( ZCD_NV_EXTADDR, 0, Z_EXTADDR_LEN, &aExtendedAddress );
// Check for uninitialized value (erased EEPROM = 0xFF)檢查是否為無效值(地址)
xad = (uint8*)&aExtendedAddress;
for (i =0;i < Z_EXTADDR_LEN; i++ )
if(*xad++ != 0xFF ) return;-----如果有一個(gè)字節(jié)不為0xFF,那么該地址有效返回
#ifdef ZDO_COORDINATOR
tmp = 0x10;
#else
tmp = 0x20;
#endif
// Initialize with a simple pattern----------------簡單初始化擴(kuò)展地址
xad = (uint8*)&aExtendedAddress;
for ( i = 0; i < Z_EXTADDR_LEN; i++ )
*xad++ = tmp++;
// Flash LED1 until user hits SW5 ---------閃爍LED1直到SW5按下
led = HAL_LED_MODE_OFF;
while ( HAL_KEY_SW_5 != HalKeyRead() )---------------------SW5循環(huán)檢測
{
MicroWait( 62500 );
HalLedSet( HAL_LED_1, led^=HAL_LED_MODE_ON );//Toggle the LED
MicroWait( 62500 );
}
HalLedSet( HAL_LED_1, HAL_LED_MODE_OFF );
// Plug AtoD data into lower bytes
AtoD = HalAdcRead (HAL_ADC_CHANNEL_7, HAL_ADC_RESOLUTION_10);
xad = (uint8*)&aExtendedAddress;
*xad++ = LO_UINT16( AtoD );
*xad = HI_UINT16( AtoD );
#if !defined( ZTOOL_PORT ) || defined( ZPORT ) || defined( NV_RESTORE )
// If no support for Z-Tool serial I/O,
// Write temporary 64-bit address to NV些臨時(shí)的64位物理地址進(jìn)入NV
osal_nv_write( ZCD_NV_EXTADDR, 0, Z_EXTADDR_LEN, &aExtendedAddress );
#endif
}

從程序中可以看出,一開始就檢測FLASH中的物理地址,因?yàn)檫@個(gè)地址在FLASH中是固定的存儲(chǔ)空間,一旦為有效地址就退出函數(shù),一旦為無效地址(0xFFFFFFFFFFFFFFFF),那么就對其物理地址進(jìn)行簡單的初始化并檢測SW5按鍵。還是比較好理解的!
3、運(yùn)行例子

在這里提到了跳線,由于本人采用的非TI原裝硬件,沒有該跳線,所以必須對程序進(jìn)行修改,否則檢測不到跳線,連ZIGBEE的設(shè)備類型都不能確定,肯定不能正常運(yùn)行了。所以這里就先暫時(shí)不說了,這里要說的是一切都正常的情況下,例子的驗(yàn)尸結(jié)果。小小跳躍一下。不然學(xué)習(xí)一直沒有進(jìn)展很麻煩的!

協(xié)調(diào)器:上電運(yùn)行,地址檢測如上面介紹的情況,通過之后呢-------就進(jìn)行通道掃描,此時(shí)LED1閃爍,一旦協(xié)調(diào)器成功建立網(wǎng)絡(luò),此時(shí)LED1停止閃爍,而LED3被點(diǎn)亮。

路由器:上電運(yùn)行,仍然是地址檢測在前。之后就是通道掃描尋求是否又存在的網(wǎng)絡(luò),此時(shí)LED1閃爍,一旦檢測到存在網(wǎng)絡(luò)并成功加入該網(wǎng)絡(luò),LED1將停止閃爍,被替換的是LED3別點(diǎn)亮,也就表明路由器成功加入了網(wǎng)絡(luò)。

那么此時(shí)能進(jìn)行的操作控制是什么呢,也是最簡單的表現(xiàn)手法---按鍵無線控制LED:

周期(5S)發(fā)送信息到網(wǎng)絡(luò)中每個(gè)設(shè)備

SW1按下,發(fā)送一個(gè)信息到組1的設(shè)備

SW2按下,退出/加入組1

這個(gè)我是經(jīng)過驗(yàn)證的。如:

按下協(xié)調(diào)器SW1,路由器的LED1狂閃幾下;按下路由器的SW1,那么協(xié)調(diào)器的LED1也就狂閃幾下;當(dāng)然我是只有兩個(gè)節(jié)點(diǎn)。

如果按1下協(xié)調(diào)器的SW2,在按下路由器的SW1,此時(shí)協(xié)調(diào)器就沒有反應(yīng),表明協(xié)調(diào)器已經(jīng)退出組1;但是再按下協(xié)調(diào)器SW2在按路由器的SW1就與上一步類似了。路由器與此類似可以通過SW2退出/加入組1.

終于把演示弄完了,接下來就來看看程序。在此之前還是來看看TI提供的Sample指導(dǎo)文檔。這個(gè)文檔個(gè)人覺得寫的不錯(cuò),要是沒看之前就看程序的卻很郁悶的!

但是本人英文很差,所以需要慢慢看,等點(diǎn)時(shí)間放上來!

Z-Stack3
Sample Application
分析(上)

1、Z-Stack CC2430DB and CC2430EB Sample Application
1.1、介紹

該文檔時(shí)介紹TI協(xié)議入門的一個(gè)例子SampleApp的,適用EM和DB開發(fā)板。
1.1.1、描述

這個(gè)例子是非常簡單的演示,每個(gè)設(shè)備都可以發(fā)送和接收兩個(gè)信息

周期信息-----加入該網(wǎng)絡(luò)的所有設(shè)備每隔10S(可能會(huì)加上一個(gè)隨機(jī)數(shù)的mS)都發(fā)送一個(gè)周期信息,該信息的數(shù)據(jù)載荷為發(fā)送信息次數(shù)的計(jì)數(shù)。

閃爍控制信息---------通過按下SW1可以發(fā)送一個(gè)控制燈閃爍的廣播信息,該廣播信息只針對組1的所有設(shè)備。

所有設(shè)備初始化為加入組1,所以網(wǎng)絡(luò)一旦成功建立/加入就可以進(jìn)行閃爍控制。可以通過按下設(shè)備的SW2退出組1,所以可以通過退出組1可以不接受閃燈信息。通過按下SW2也可以讓不在組1的設(shè)備加入近組1,從而又可以接受閃燈信息了。

這個(gè)理解應(yīng)該不困難的,反正我理解沒有什么障礙!
1.1.1.1、按鍵

SW1:發(fā)送閃爍信息到組1所有設(shè)備

SW2:轉(zhuǎn)換推出/加入組1狀態(tài)
1.1.2、用戶應(yīng)用開發(fā)

這里我基本上能看明白是什么,但是我不打算寫出來,因?yàn)樯婕暗揭恍㈱IGBEE的關(guān)鍵術(shù)語,不是很明白。

大概就是簡單介紹了下用戶怎么利用例子做自己的應(yīng)用,但是實(shí)用價(jià)值不高,說的太籠統(tǒng),全是概念性的說明。
1.2、OSAL任務(wù)
1.2.1、初始化

因?yàn)閆-Stack是在OS下運(yùn)行的,所以在之前必須調(diào)用osalAddTasks()初始化任務(wù)。
1.2.2、組織

關(guān)于OS的API函數(shù)介紹請看文檔:Z-Stack OSAL API (F8W-2003-0002),應(yīng)該說協(xié)議棧的每層或者說每部分都有相關(guān)的API說明文檔。osalAddTasks()初始化任務(wù),osalTaskAdd()函數(shù)添加任務(wù),都可以到API文檔或程序中詳細(xì)分析函數(shù)功能。
1.2.3、系統(tǒng)服務(wù)

OSAL和APL系統(tǒng)服務(wù)是唯一的,因?yàn)楸热绨存I和串口類似事件處罰就只能用唯一的一個(gè)任務(wù)標(biāo)識。這兩個(gè)硬件都留給了用戶自己定義使用。
1.2.4、應(yīng)用設(shè)計(jì)

用戶可能為每一個(gè)應(yīng)用對象都創(chuàng)建一個(gè)任務(wù),或者為所有的應(yīng)用對象只創(chuàng)建一個(gè)任務(wù)。當(dāng)選擇上述的設(shè)計(jì)的時(shí)候,下面是一些設(shè)計(jì)思路:
1.2.4.1、為許多應(yīng)用對象創(chuàng)建一個(gè)OSAL任務(wù)

下面是正面和反面(pros & cons)的一些敘述:

- Pro:接受一個(gè)互斥任務(wù)事件(開關(guān)按下或串口)時(shí),動(dòng)作是單一的。

- Pro:需要堆??臻g保存一些OSAL任務(wù)結(jié)構(gòu)。

- Con:接收一個(gè)AF信息或一個(gè)AF數(shù)據(jù)確認(rèn)時(shí),動(dòng)作是復(fù)雜的-----在一個(gè)用戶任務(wù)上,分支多路處理應(yīng)用對象的信息事件。

- Con:通過匹配描述符(如:自動(dòng)匹配)去發(fā)現(xiàn)服務(wù)的處理過程更復(fù)雜-----為了適當(dāng)?shù)膶DO_NEW_DSTADDR信息起作用,一個(gè)靜態(tài)標(biāo)志必須被維持。
1.2.4.2、為一個(gè)應(yīng)用對象創(chuàng)建一個(gè)OSAL任務(wù)

一對一設(shè)計(jì)的反面和正面(pros & cons)是與上面一對多設(shè)計(jì)相反的:

- Pro:在應(yīng)用對象試圖自動(dòng)匹配時(shí),僅僅一個(gè)ZDO_NEW_DSTADDR被接收。

- Pro:已經(jīng)被協(xié)議棧下層多元處理后的一個(gè)AF輸入信息或一個(gè)AF數(shù)據(jù)確認(rèn)。

- Con:需要堆棧空間保存一些OSAL任務(wù)結(jié)構(gòu)。

- Con:如果兩個(gè)或更多應(yīng)用對象用同一個(gè)唯一的資源,接收一個(gè)互斥任務(wù)事件的動(dòng)作就更復(fù)雜。
1.2.5、強(qiáng)制方法

任何一個(gè)OSAL任務(wù)必須用兩種方法執(zhí)行:一個(gè)是初始化,另一個(gè)是處理任務(wù)事件。
1.2.5.1、任務(wù)初始化

在例子中調(diào)用如下函數(shù)執(zhí)行任務(wù)初始化:

“Application Name”_Init(如SAPI_Init)。該任務(wù)初始化函數(shù)應(yīng)該完成如下功能:

變量或相應(yīng)應(yīng)用對象特征初始化,為了使OSAL內(nèi)存管理更有效,在這里應(yīng)該分配永久堆棧存儲(chǔ)區(qū)。

在AF層登記相應(yīng)應(yīng)用對象(如:afRegister())。

登記可用的OSAL或HAL系統(tǒng)服務(wù)(如:RegisterForKeys())
1.2.5.2、任務(wù)事件處理

調(diào)用如下函數(shù)處理任務(wù)事件:

“Application Name”_ProcessEvent (e.g. SAPI_ProcessEvent()).除了強(qiáng)制的事件之外,任一OSAL任務(wù)能被定義多達(dá)15個(gè)任務(wù)事件。
1.2.6、強(qiáng)制事件

一個(gè)任務(wù)事件SYS_EVENT_MSG (0x8000), 被保留必須通過OSAL任務(wù)設(shè)計(jì)。
2.2.6.1、SYS_EVENT_MSG (0x8000)

任務(wù)事件管理者應(yīng)該處理如下的系統(tǒng)信息子集,下面只列出了部分信息,但是是最常用的幾個(gè)信息處理,推薦根據(jù)例子復(fù)制到自己項(xiàng)目中使用。
1.2.6.1.1、AF_DATA_CONFIRM_CMD

調(diào)用AF_DataRequest()函數(shù)數(shù)據(jù)請求成功的指示。Zsuccess確認(rèn)數(shù)據(jù)請求傳輸成功,如果數(shù)據(jù)請求設(shè)置AF_ACK_REQUEST標(biāo)志位,那么,只有最終目的地址成功接收后,Zsuccess確認(rèn)才返回。如果如果數(shù)據(jù)請求沒有設(shè)置AF_ACK_REQUEST標(biāo)志位,那么,數(shù)據(jù)請求只要成功傳輸?shù)较绿?jié)點(diǎn)就返回Zsuccess確認(rèn)信息。
1.2.6.1.2、AF_INCOMING_MSG_CMD

AF信息輸入指示
1.2.6.1.3、KEY_CHANGE

鍵盤動(dòng)作指示
1.2.6.1.4、ZDO_NEW_DSTADDR

匹配描述符請求(Match Deor Request)響應(yīng)指示。(例如:自動(dòng)匹配)
1.2.6.1.5、ZDO_STATE_CHANGE

網(wǎng)絡(luò)狀態(tài)改變指示
1.3、網(wǎng)絡(luò)格式化

示例應(yīng)用程序編譯為協(xié)調(diào)器的在default_chanlist指定的通道上形成一個(gè)網(wǎng)絡(luò),協(xié)調(diào)器將建立一個(gè)隨機(jī)編號源于自身的IEEE地址或由zdapp_config_pan_id指定的網(wǎng)絡(luò)PAN ID(如果zdapp_config_pan_id不為0xFFFF)。

示例應(yīng)用程序編譯為路由器或結(jié)束設(shè)備的將嘗試加入網(wǎng)絡(luò)在default_chanlist指定的通道上,如果zdapp_config_pan_id沒有定義為0 xFFFF ,路由器將受到限制,只有加入?yún)?shù)zdapp_config_pan_id規(guī)定的網(wǎng)絡(luò)PAN ID。
1.3.1、自動(dòng)啟動(dòng)

設(shè)備自動(dòng)開始嘗試組建或加入網(wǎng)絡(luò)。如果設(shè)備設(shè)置為等待計(jì)時(shí)器或其他外部事件發(fā)生后才啟動(dòng),那么HOLD_AUTO_START必須被定義。為了稍后以手動(dòng)啟動(dòng)方式啟動(dòng)設(shè)備,那么需要調(diào)用ZDApp_StartUpFromApp(函數(shù)

1.3.2、軟件啟動(dòng)

為了在形成網(wǎng)絡(luò)過程中節(jié)省所需的設(shè)備類型,那么所有的路由器設(shè)備可以被通過soft_star定義作為一個(gè)協(xié)調(diào)器。如果自動(dòng)啟動(dòng)是需要的話,那么auto_soft_start必須被定義。
1.3.3、網(wǎng)絡(luò)恢復(fù)

通過設(shè)置NV_RESTORE和/或NV_INIT,可以讓設(shè)備斷電或者意外掉電重新啟動(dòng)后重新回復(fù)網(wǎng)絡(luò)。
1.3.4、加入通告

當(dāng)設(shè)備形成或加入網(wǎng)絡(luò)后會(huì)發(fā)通報(bào)到ZDO_STATE_CHANGE信息事件。

 

學(xué)Z-Stack4
Sample Application
分析(下)

上節(jié)介紹了建立一個(gè)應(yīng)用需要做的幾個(gè)必須的事情,現(xiàn)在就來通過分析Sample Application來具體看看需要做哪些事情,才能建立一個(gè)ZIGBEE應(yīng)用功能。當(dāng)然這里只是做點(diǎn)簡單的必須的工作。
The Sample Application (SampleApp)
1、介紹

主要是介紹一個(gè)應(yīng)用建立的結(jié)構(gòu)及需要進(jìn)行的程序流程。
1.1、程序流程
1.1.1、初始化

首先需要調(diào)用初始化函數(shù)SampleApp_Init()。

SampleApp_TaskID = task_id;

初始化應(yīng)用建立的任務(wù)ID號,其實(shí)用過OS的人都應(yīng)該曉得這個(gè)是干啥的,我沒用過,不是很理解,但是我知道是必須的,就相當(dāng)于一個(gè)任務(wù)的標(biāo)識,這樣才能區(qū)分運(yùn)行過程中不同任務(wù)中的不同事件。我是這么認(rèn)為的,ID說白了就是給該任務(wù)取了各名字,就向人名字一樣,區(qū)分不同的人,就是一個(gè)代號。人名可以重復(fù),重復(fù)了有時(shí)候叫起來就容易混淆;所以才程序中為了避免這種混淆,就強(qiáng)制性的規(guī)定任務(wù)ID不能重復(fù)。要是哪天國家或者聯(lián)合國姓名管理委員會(huì)規(guī)定,人民不能重復(fù),那么這個(gè)人名就需要全球統(tǒng)一管理了。那給娃取個(gè)名字就要向聯(lián)合國姓名管理委員會(huì)申請了。呵呵!

SampleApp_NwkState = DEV_INIT;

初始化應(yīng)用設(shè)備的網(wǎng)絡(luò)狀態(tài)。怎么說呢,據(jù)說是設(shè)備類型的改變都要產(chǎn)生一個(gè)事件,叫ZDO_STATE_CHANGE,從字面理解為ZDO狀態(tài)發(fā)生了改變。所以在設(shè)備初始化的時(shí)候一定要把它初始化為什么狀態(tài)都沒有。那么它就要去檢測整個(gè)環(huán)境,看是否能重新建立或者加入存在的網(wǎng)絡(luò)。但是有一種情況例外,就是當(dāng)NV_RESTORE被設(shè)置的時(shí)候(NV_RESTORE是把信息保存在非易失存儲(chǔ)器中),那么當(dāng)設(shè)備斷電或者某種意外重啟時(shí),由于網(wǎng)絡(luò)狀態(tài)存儲(chǔ)在非易失存儲(chǔ)器中,那么此時(shí)就只需要恢復(fù)其網(wǎng)絡(luò)狀態(tài),而不需要重新建立或者加入網(wǎng)絡(luò)了。我也是從文檔中這么理解的,至于為什么只有有待進(jìn)一步考證。

SampleApp_DstAddr.addrMode = (afAddrMode_t)AddrNotPresent;

SampleApp_DstAddr.endPoint = 0;

SampleApp_DstAddr.addr.shortAddr = 0;

看見這幾句話從字面理解為:初始化不標(biāo)設(shè)備地址模式及目標(biāo)設(shè)備EP號和網(wǎng)絡(luò)地址。從代碼可以看出,這些地址或EP均為0。也就是說目標(biāo)設(shè)備為協(xié)調(diào)者的ZDO,這個(gè)意義就很明顯了,就是設(shè)備建立后可以直接與協(xié)調(diào)器的ZDO交互信息。
SampleApp_epDesc.endPoint = SAMPLEAPP_ENDPOINT;
----- SampleApp EP描述符的EP號
SampleApp_epDesc.task_id = &SampleApp_TaskID;------ SampleApp EP描述符的任務(wù)ID
SampleApp_epDesc.simpleDesc =------------------ SampleApp EP簡單描述符
SimpleDeionFormat_t *)&SampleApp_SimpleDesc;
SampleApp_epDesc.latencyReq = noLatencyReqs;
//在AF層中登記注冊改應(yīng)用EP
afRegister( &SampleApp_epDesc );

這里其實(shí)是對SampleApp的EP描述符進(jìn)行初始化。

本人理解:要對改應(yīng)用進(jìn)行初始化并在AF進(jìn)行登記,告訴應(yīng)用層有這么一個(gè)EP已經(jīng)可以使用,那么下層要是有關(guān)于改應(yīng)用的信息或者應(yīng)用要對下層做哪些操作,就自動(dòng)得到下層的配合,至于這個(gè)配合是怎么回事,那么就需要好好研究下層的協(xié)議了。當(dāng)然在這里肯定是沒那時(shí)間精力和能力研究了!

其實(shí)在這個(gè)應(yīng)用中,只是讓AF配合SAMPLEAPP_PROFID / SAMPLEAPP_ENDPOINT這兩個(gè)應(yīng)用。那么通過什么呢,通過發(fā)送OSAL SYS_EVENT_MSG消息中的(AF_INCOMING_MSG_CMD)事件到SampleApp任務(wù)ID。

RegisterForKeys( SampleApp_TaskID );

登記按鍵事件到SampleApp_TaskID,在前面已經(jīng)說了按鍵這個(gè)是唯一的,也就是所有任務(wù)中有且只有各任務(wù)能登記鍵盤事件。前面還說了還有一個(gè)也是唯一,你猜是什么?

SampleApp_Group.ID = 0x0001;

osal_memcpy( SampleApp_Group.name, “Group1”);

aps_AddGroup( SAMPLEAPP_ENDPOINT, &SampleApp_Group );

閃燈信息被發(fā)送到組1,同樣也只有在組1的設(shè)備才能接收這個(gè)信息。設(shè)備啟動(dòng)時(shí)已經(jīng)被設(shè)定為組1設(shè)備了,但是可以通過按SW1推出/加入組1。這里提到了組的概念,我反正暫時(shí)不是很清楚這個(gè)是什么東西,在程序中怎么實(shí)現(xiàn)也很模糊,但是應(yīng)用中的好處還是不難想象的,不外呼是就是想控制誰可以事先規(guī)定好,還可以動(dòng)態(tài)更改。
1.2、事件處理

玩過OS的人都知道,OS中最重要的概念不外呼就是任務(wù)啦,消息啦,事件啦等。從我們自己平時(shí)的工作中也不難想象,如果老板安排了某項(xiàng)工作,那么我們就需要做的,這個(gè)工作可能是預(yù)先計(jì)劃好的,也有可能是臨時(shí)的,那么這些預(yù)先定好或者臨時(shí)的工作可以稱之為事件。而老板讓您做的方式,比如通過文件下達(dá),或者叫:某某你把XXX做下。那么讓老板下達(dá)的文件內(nèi)容或者說的內(nèi)容我這里可以稱之為消息。老板給了你不同的消息那么就需要干不同的事件,至于任務(wù)可以理解為公司的不同的員工,呵呵!我簡直是理解的天才,這樣舉例居然也能忽悠通過?。?!o(∩_∩)o…哈哈

在Z-Stack中,每個(gè)應(yīng)用任務(wù)都通過SampleApp_ProcessEvent()函數(shù)來處理任務(wù)中的事件。一旦SampleApp_TaskID任務(wù)的某個(gè)OSAL事件發(fā)生,那么就可以通過調(diào)用SampleApp_ProcessEvent()函數(shù)來處理。在SampleApp_ProcessEvent()中有一個(gè)事件處理循環(huán),循環(huán)檢測是哪個(gè)事件發(fā)生。
if ( events & SYS_EVENT_MSG )
{
MSGpkt = (afIncomingMSGPacket_t*)osal_msg_receive( SampleApp_TaskID );
while ( MSGpkt )
{

可以看到是通過檢測SYS_EVENT_MSG是否有事件信息發(fā)生。

switch ( MSGpkt->hdr.event )

這里是判斷SYS_EVENT_MSG事件類型,不同的SYS_EVENT_MSG類型需要不同的處理。
case KEY_CHANGE:
SampleApp_HandleKeys( ((keyChange_t *)MSGpkt)->state,
((keyChange_t *)MSGpkt)->keys );
break;

比如這里判斷是否是鍵盤事件,如果鍵盤事件就調(diào)用鍵盤處理函數(shù)。

如果一個(gè)OSAL任務(wù)已經(jīng)被登記組側(cè),那么任何鍵盤事件都將接受一個(gè)KEY_CHANGE事件信息??赡苡腥缦聨追N方式得到鍵盤事件信息

1)、HAL檢測到鍵盤按下(中斷或者查詢檢測)

2)、HAL的OSAL任務(wù)檢測到一個(gè)鍵盤狀態(tài)改變調(diào)用回叫函數(shù)產(chǎn)生

3)、OSAL鍵盤改變回叫函數(shù)發(fā)送一個(gè)OSAL系統(tǒng)事件信息(KEY_CHANGE)。

case AF_DATA_CONFIRM_CMD:
// The status is of ZStatus_t type [defined in ZComDef.h]
// The message fields are defined in AF.h
afDataConfirm = (afDataConfirm_t *)MSGpkt;
sentEP = afDataConfirm->endpoint;
sentStatus = afDataConfirm->hdr.status;
sentTransID = afDataConfirm->transID;
任何AF_DataRequest()數(shù)據(jù)請求函數(shù)調(diào)用后,都通過AF_DATA_CONFIRM_CMD系統(tǒng)事件信息回叫返回成功Zsuccess。
case ZDO_STATE_CHANGE:
SampleApp_NwkState = (devStates_t)(MSGpkt->hdr.status);
if ( (SampleApp_NwkState == DEV_ZB_COORD)
||(SampleApp_NwkState == DEV_ROUTER)
||(SampleApp_NwkState == DEV_END_DEVICE) )
{
// Update the LCD’s network indicator
// Start sending "the" message in a regular interval.
osal_start_timer( SAMPLEAPP_SEND_PERIODIC_MSG_EVT,
SAMPLEAPP_SEND_PERIODIC_MSG_TIMEOUT );
}
break;

這里就是前面介紹的設(shè)備狀態(tài)改變事件處理了。

只要網(wǎng)絡(luò)狀態(tài)發(fā)生改變,那么通過ZDO_STATE_CHANGE事件通知所有的任務(wù)。注意:在這個(gè)例子中,一旦設(shè)備成功加入網(wǎng)絡(luò),是通過定時(shí)運(yùn)行的方式運(yùn)行的。一旦網(wǎng)絡(luò)狀態(tài)為加入”JOINED”,那么它可能不需要任何的認(rèn)為操作就能綁定其他設(shè)備,因?yàn)樵O(shè)置為自動(dòng)發(fā)現(xiàn)并綁定的。
// Release the memory
osal_msg_deallocate( (uint8 *)MSGpkt );
釋放存儲(chǔ)空間。
if ( events & SAMPLEAPP_SEND_PERIODIC_MSG_EVT )
{
// Send "the" message
SampleApp_SendPeriodicMessage();
// Setup to send message again
osal_start_timer( SAMPLEAPP_SEND_PERIODIC_MSG_EVT,
SAMPLEAPP_SEND_MSG_TIMEOUT );
// return unprocessed events
return (events ^ SAMPLEAPP_SEND_PERIODIC_MSG_EVT);
}
這里檢測事件是否為周期發(fā)送信息事件。

在SampleApp.h中定義了:

#define SAMPLEAPP_SEND_PERIODIC_MSG_EVT 0x0001
在這個(gè)應(yīng)用中,調(diào)用了osal_start_timer()函數(shù)來定時(shí)產(chǎn)生發(fā)送周期信息事件。而定時(shí)器的運(yùn)行是設(shè)備一旦加入網(wǎng)絡(luò)就不停的在運(yùn)行。從上面可以看到,用函數(shù)SampleApp_SendPeriodicMessage()發(fā)送周期信息,而用函數(shù)osal_start_timer( SAMPLEAPP_SEND_PERIODIC_MSG_EVT,SAMPLEAPP_SEND_MSG_TIMEOUT )來繼續(xù)運(yùn)行定時(shí)器定時(shí)發(fā)送這個(gè)周期信息。關(guān)于這個(gè)osal_start_timer可以多了解下,第一個(gè)參數(shù)SAMPLEAPP_SEND_PERIODIC_MSG_EVT四信息時(shí)間,也就是事件到了產(chǎn)生一個(gè)什么事件。第二各參數(shù)SAMPLEAPP_SEND_MSG_TIMEOUT是需要定時(shí)的時(shí)間,這里就是發(fā)送周期信息的時(shí)間周期。
1.3、消息流程

通過OSAL定時(shí)器,這個(gè)應(yīng)用定時(shí)發(fā)送一個(gè)周期信息:
void SampleApp_SendPeriodicMessage( void )
{
afAddrType_t dstAddr;
dstAddr. addrMode = afAddrBroadcast;
dstAddr.addr.shortAddr = 0xFFFF; // 廣播發(fā)送
dstAddr. endpoint = SAMPLEAPP_ENDPOINT;
if ( AF_DataRequest( & dstAddr, &SampleApp_epDesc,
SAMPLEAPP_PERIODIC_CLUSTERID,
(uint8)sampleAppPeriodicCounter++,
(uint8 *)&sampleAppPeriodCounter,
&SampleApp_TransID,
AF_DISCV_ROUTE,
AF_DEFAULT_RADIUS ) == afStatus_SUCCESS )
{
// Successfully requested to be sent.----發(fā)送成功處理
}
else
{
// Error occurred in request to send.---發(fā)送失敗處理
}
}

在這里調(diào)用了AF_DataRequest()函數(shù)用來發(fā)送數(shù)據(jù)。關(guān)于發(fā)送數(shù)據(jù)的具體過程這里就不做深入研究,不外乎就是把數(shù)據(jù)從應(yīng)用層傳到網(wǎng)絡(luò)層,在傳到MAC,在傳到無力層,最后通過OTA發(fā)送出去。接收數(shù)據(jù)就是相反的過程了,那么接收之后,在應(yīng)用層有什么反應(yīng)呢,最直觀的反應(yīng)就是會(huì)發(fā)送一個(gè)AF_INCOMING_MSG_CMD消息事件。
case AF_INCOMING_MSG_CMD:
SampleApp_MessageMSGCB( MSGpkt );
break;
這里表示收到某個(gè)信息,然后在里面調(diào)用了收到信息的信息處理函數(shù)SampleApp_MessageMSGCB( MSGpkt )。
void SampleApp_MessageMSGCB( afIncomingMSGPacket_t *pkt )
{
switch ( pkt->clusterId )
{
case SAMPLEAPP_PERIODIC_CLUSTERID:
// Display and increment a counter on the LCD in the periodic space
break;
case SAMPLEAPP_FLASH_CLUSTERID:
flashTime = BUILD_UINT16(pkt->cmd.Data[1], pkt->cmd.Data[2] );
HalLedBlink( HAL_LED_4, 4, 50, (flashTime / 4) );
break;
}
}

這里判斷了兩種信息:

周期信息

閃燈信息

不同的信息就相當(dāng)于收到了不同的命令,然后根據(jù)不同的命令做出了不同的處理。是個(gè)會(huì)寫程序都明白?。。?!

到這里,我就基本上把這個(gè)應(yīng)用文檔看完了,至于理解了多少我迷糊,理解正確了多少我更加迷糊,反正我按照我自己的方式理解了!

 

學(xué)Z-Stack5

前面雖然寫了不少,但是回頭看看大多都是廢話,不過也沒辦法,沒有廢話的潤色就太枯燥了,太技術(shù)化了,這個(gè)不是我的本意。不知道前面寫的怎么樣,技術(shù)含量肯定是不高的。這個(gè)本人是相當(dāng)清楚,但是我最大的期望就是錯(cuò)誤不要太多!

突然想起來前面有個(gè)問題沒有解決,我想很多人看到那里都很郁悶的。就是設(shè)備類型的選擇,在TI原裝系統(tǒng)上是通過板載跳線來選擇的,但是我這里不是采用原裝,那么就需要通過程序來修改其設(shè)備類型,然后編譯下載。具體程序段如下:
#if defined ( SOFT_START )
if ( readCoordinatorJumper() )
 zgDeviceLogicalType = ZG_DEVICETYPE_COORDINATOR;
else
 zgDeviceLogicalType = ZG_DEVICETYPE_ROUTER;
#endif // SOFT_START
這里有個(gè)條件編譯,其條件編譯設(shè)置如圖5-1。
 
圖5-1
既然這里設(shè)置了SOFT_START,那么上段程序就要被編譯。那么第一句程序
if ( readCoordinatorJumper() )
就是檢測跳線,其實(shí)稍微知道編程的都了解怎么修改了,哈哈!
屏蔽:
if ( readCoordinatorJumper() )
  zgDeviceLogicalType = ZG_DEVICETYPE_COORDINATOR;
else

這3句,那么就只剩下:zgDeviceLogicalType = ZG_DEVICETYPE_ROUTER;了

那么編譯自然該設(shè)備就為路由器了。簡單吧?。。。???!

協(xié)調(diào)器我就不想多說怎么做了哈?。。。。。。。。。。?!

還有一個(gè)問題需要說下,就是Ti原裝的EM板子用到了LCD,所以在程序中可能在某個(gè)地方要對LCD初始化,那么如果沒有液晶的板子或者與TI那個(gè)不完全一樣的LCD就有可能運(yùn)行不走,通俗的解決辦法是禁止LCD初始化等操作,Ti在這個(gè)方面做的很人性化,禁止LCD功能沒有必要在程序中找到LCD相關(guān)程序刪除,而是僅僅需要通過條件編譯來禁止。顯得相當(dāng)簡單,如5-2圖就是禁止LCD的條件編譯。
 
圖5-2

解決這個(gè)問題后一般都能夠運(yùn)行程序了。也就是說到這里如果還把Demo程序運(yùn)行不起來的話,那就證明我所有的東西都白寫了,反正我到這里我的Demo程序已經(jīng)運(yùn)行如飛了。

那么接下來就是來看看Z-Stack具體的一些東西了,我打算先這樣看起:

1、Z-Stack的結(jié)構(gòu),因?yàn)榇蜷_Z-Stack的目錄可以看出還是比較復(fù)雜的,只有比較清楚了解其結(jié)構(gòu)之后呢,在程序運(yùn)行或者修改中才能順利的找到自己想要的部分。

2、Z-Stack的應(yīng)用建立。就是怎么在TI提供的協(xié)議(裸協(xié)議)上建立一個(gè)應(yīng)用。這個(gè)層次要求就比較高了,我初步的設(shè)想是希望能分析完SAMPLE例子的應(yīng)用就能自己建立,而不需要太多的去了解下層的協(xié)議。但是往往希望與現(xiàn)實(shí)是有偏差的,走一步算一步了。

3、了解硬件相關(guān)設(shè)定、驅(qū)動(dòng)。也就是說把例子跑通了,畢竟是基于TI的硬件,或者說基于開發(fā)系統(tǒng)的硬件,如果要做自己的應(yīng)用,那么必須要開發(fā)自己的硬件。怎么把自己的硬件驅(qū)動(dòng)加入?yún)f(xié)議,這個(gè)我想也是需要解決的問題。

4、接下來可能就要深入分析協(xié)議了,這個(gè)目前我還不清楚從什么地方看起,因?yàn)楫吘箤IGBEE這個(gè)協(xié)議本身就不太了解,但是在學(xué)習(xí)過程中應(yīng)該會(huì)慢慢對它有認(rèn)識。所以到了這一步的時(shí)候說不定我就已經(jīng)摸索出一條方法了---畢竟俺是相當(dāng)?shù)穆斆髀铮?/span>

5、需要解決的問題,需要了解的東西很多,對于不太了解這個(gè)東西的我來說,不可能非常有計(jì)劃并統(tǒng)籌安排這些事,走彎路是必然的,但是我一致認(rèn)為走彎路才是經(jīng)驗(yàn)的積累!

學(xué)習(xí)Z-Stack6
--------------Z-Stack指導(dǎo)

首先來看看Z-Stack的結(jié)構(gòu)。

第一次打開工程印象最深刻的就是左邊一排文件夾,如圖6-1所示。
 
其實(shí)這個(gè)還是很容易理解的:

APPApplication Programming):應(yīng)用層目錄,這是用戶創(chuàng)建各種不同工程的區(qū)域,在這個(gè)目錄中包含了應(yīng)用層的內(nèi)容和這個(gè)項(xiàng)目的主要內(nèi)容,在協(xié)議棧里面一般是以操作系統(tǒng)的任務(wù)實(shí)現(xiàn)的。

HALHardware (H/W) Abstraction Layer):硬件層目錄,包含有與硬件相關(guān)的配置和驅(qū)動(dòng)及操作函數(shù)。

MACMAC 層目錄,包含了MAC 層的參數(shù)配置文件及其MAC LIB 庫的函數(shù)接口文件。

MTMonitor Test):實(shí)現(xiàn)通過串口可控各層,于各層進(jìn)行直接交互。

NWKZigBee Network Layer):網(wǎng)絡(luò)層目錄,含網(wǎng)絡(luò)層配置參數(shù)文件及網(wǎng)絡(luò)層庫的函數(shù)接口文件,APS層庫的函數(shù)接口

OSALOperating System (OS) Abstraction Layer):協(xié)議棧的操作系統(tǒng)。

ProfileAFApplication work)層目錄,包含AF層處理函數(shù)文件。

Security:安全層目錄,安全層處理函數(shù),比如加密函數(shù)等。

Services:地址處理函數(shù)目錄,包括著地址模式的定義及地址處理函數(shù)。

Tools:工程配置目錄,包括空間劃分及ZStack 相關(guān)配置信息。

ZDOZigBee Device Objects):ZDO 目錄。

ZMac MAC 層目錄,包括MAC 層參數(shù)配置及MAC LIB 庫函數(shù)回調(diào)處理函數(shù)。

ZMain:主函數(shù)目錄,包括入口函數(shù)及硬件配置文件。

Output:輸出文件目錄,這個(gè)EW8051 IDE 自動(dòng)生成的。

那么知道各個(gè)文件夾大概是什么功能,分布在ZIGBEE的哪一層,那么在以后的工作中無論是查詢某些功能函數(shù)還是修改某些功能函數(shù),甚至是添加或刪除某些功能函數(shù)就能順利的找到在什么地方了,當(dāng)然要想真的順利還需要花更多的時(shí)間熟悉這個(gè)協(xié)議棧了!

了解Z-Stack結(jié)構(gòu)后那么就能看看它的功能。

不用問,這個(gè)是針對ZIGBEE無線網(wǎng)絡(luò)寫的協(xié)議棧,呵呵!那么就要先大概了解下ZIGBEE這個(gè)技術(shù)。我這里就不介紹理論了,就從Z-Stack實(shí)際的角度介紹些實(shí)用的概念。
1、Zigbee網(wǎng)絡(luò)中的節(jié)點(diǎn)

ZB網(wǎng)絡(luò)中,每個(gè)節(jié)點(diǎn)都有指定的配置參數(shù),從而確定其設(shè)備類型,不同的設(shè)備類型,在網(wǎng)絡(luò)中有著不一樣網(wǎng)絡(luò)任務(wù)。在屬于多跳網(wǎng)絡(luò)的ZB網(wǎng)絡(luò)中,兩個(gè)節(jié)點(diǎn)需要完成數(shù)據(jù)傳輸,可能需要經(jīng)過其他中間節(jié)點(diǎn)的協(xié)助,所以節(jié)點(diǎn)的類型參數(shù)配置是非常必要的。
對每個(gè)節(jié)點(diǎn)有兩個(gè)任務(wù):
i)執(zhí)行指定的網(wǎng)絡(luò)功能函數(shù)
ii)配置確定的參數(shù)到指定的值。
網(wǎng)絡(luò)功能的設(shè)置確定了該節(jié)點(diǎn)的類型,參數(shù)配置和指定的值確定了堆棧的模式。
節(jié)點(diǎn)類型

ZB中,設(shè)備類型分為三類:協(xié)調(diào)器,路由器和終端設(shè)備。

6-2就是這三種設(shè)備類型組成的一個(gè)典型網(wǎng)絡(luò)。


其中黑色節(jié)點(diǎn)為協(xié)調(diào)器
紅色節(jié)點(diǎn)為路由器
白色節(jié)點(diǎn)為終端設(shè)備
那么這個(gè)就是一個(gè)典型的網(wǎng)狀網(wǎng)絡(luò)MESH。

協(xié)調(diào)器

協(xié)調(diào)器是一個(gè)ZB網(wǎng)絡(luò)的第一個(gè)開始的設(shè)備,或者是一個(gè)ZB網(wǎng)絡(luò)的啟動(dòng)或建立網(wǎng)絡(luò)的設(shè)備。協(xié)調(diào)器節(jié)點(diǎn)選擇一個(gè)信道和網(wǎng)絡(luò)標(biāo)志符(也叫PAN ID),然后開始建立一個(gè)網(wǎng)絡(luò)。協(xié)調(diào)器設(shè)備在網(wǎng)絡(luò)中還可以有其他作用,比如建立安全機(jī)制、網(wǎng)絡(luò)中的綁定的建立等等。
注意:協(xié)調(diào)器主要的作用是建立一個(gè)網(wǎng)絡(luò)和配置該網(wǎng)絡(luò)的性質(zhì)參數(shù)。一旦這些完成,該協(xié)調(diào)器就如同一個(gè)路由器,網(wǎng)絡(luò)中的其他操作并不依賴該協(xié)調(diào)器,因?yàn)?/span>ZB是分布式網(wǎng)絡(luò)。
路由器

一個(gè)路由器的功能有(1)作為普通設(shè)備加入網(wǎng)絡(luò)(2)多跳路由(3)輔助其它的子節(jié)點(diǎn)完成通信。

一般來說,路由器需要一直處于工作狀態(tài),所以需要主干線供電(區(qū)別于電池供電)。但是在某指定的網(wǎng)絡(luò)結(jié)構(gòu)中可以采用電池供電,如串樹型網(wǎng)絡(luò)模式中,允許路由器周期的運(yùn)行操作,所以可以采用電池供電。
終端設(shè)備

為了維持網(wǎng)絡(luò)最基本的運(yùn)行,對于終端設(shè)備沒有指定的責(zé)任。也就是說,在一個(gè)基本網(wǎng)絡(luò)中,終端設(shè)備沒有必不可缺少性。所以它可以根據(jù)自己功能需要休眠或喚醒,因此為電池供電設(shè)備。一般來說,該設(shè)備需要的內(nèi)存較少(特別是內(nèi)部RAM
堆棧模式(Stack Profile

需要被配置為指定值的堆棧參數(shù),連同這些值被稱為堆棧模式。這些堆棧模式參數(shù)被ZB聯(lián)盟定義指定。在同一個(gè)網(wǎng)絡(luò)中的設(shè)備必須符合同一個(gè)堆棧模式(同一個(gè)網(wǎng)絡(luò)中所有設(shè)備的堆棧模式配置參數(shù)必須一致)。

為了互操作性,ZB聯(lián)盟為06協(xié)議棧定義了一個(gè)堆棧模式,所有的設(shè)備只要遵循該模式的參數(shù)配置,即使在不同廠商買的不同設(shè)備同樣可以形成網(wǎng)絡(luò)。

如果應(yīng)用開發(fā)者改變了這些參數(shù)配置,那么他的產(chǎn)品將不能與遵循ZB聯(lián)盟定義模式的產(chǎn)品組成網(wǎng)絡(luò),也就是說該開發(fā)者開發(fā)的產(chǎn)品具有特殊性,我們稱之為關(guān)閉的網(wǎng)絡(luò),也就是說它的設(shè)備只有在自己的產(chǎn)品中使用,不能與其他產(chǎn)品通信。

該協(xié)議模式標(biāo)志符在設(shè)備通信的信標(biāo)傳輸中被匹配,如果不匹配,那么該設(shè)備將不能加入網(wǎng)絡(luò)。關(guān)閉網(wǎng)絡(luò)的堆棧模式有一個(gè)0ID,而06協(xié)議棧模式有一個(gè)1ID。該堆棧模式被配置在nwk_globals.h文件中的STACK_PROFILE_ID參數(shù)。如:

#define STACK_PROFILE_ID   HOME_CONTROLS。
2、Zigbee網(wǎng)絡(luò)中的地址
地址類型

ZB設(shè)備有兩種地址類型,一個(gè)是64IEEE地址(也可以叫MAC地址或擴(kuò)展地址),一個(gè)是16位網(wǎng)絡(luò)地址(也可以叫邏輯地址或短地址)。

64位地址是全球唯一的,作為設(shè)備(產(chǎn)品)的終生地址被分配。它通常被開發(fā)商或安裝的時(shí)候被指定。該地址由IEEE分配指定,該地址的信息和獲得該地址的方法見:http://standards.ieee.org/regauth/oui/index.shtml

16位地址在設(shè)備加入網(wǎng)絡(luò)的時(shí)候被分配,由這個(gè)網(wǎng)絡(luò)自動(dòng)分配。該地址只能用與本網(wǎng)絡(luò)中,標(biāo)志不同的設(shè)備間傳遞信息。
網(wǎng)絡(luò)地址分配

ZB分布式網(wǎng)絡(luò)中地址分配是唯一的。為了不使網(wǎng)絡(luò)中設(shè)備混亂,為每個(gè)設(shè)備指定確定的地址是非常必要的。

在分配地址之前,一些參數(shù)必須被設(shè)置:MAX_DEPTH, MAX_ROUTERS MAX_CHILDREN 。

這些參數(shù)都是ZB協(xié)議模式的一部分,在06ZS模式中這些參數(shù)設(shè)置為: (MAX_DEPTH = 5, MAX_CHILDREN = 20, MAX_ROUTERS = 6).
參數(shù)設(shè)置

MAX_DEPTH決定了網(wǎng)絡(luò)的最大深度。協(xié)調(diào)器的深度是0,它的子設(shè)備的深度是1,他們的子設(shè)備的深度是2,依次類推。所以MAX_DEPTH參數(shù)限制了網(wǎng)絡(luò)物理上的長度

MAX_CHILDREN參數(shù)決定了一個(gè)路由器(或一個(gè)協(xié)調(diào)器)能承載子設(shè)備的最大數(shù)目。

MAX_ROUTERS參數(shù)決定了一個(gè)路由器(或一個(gè)協(xié)調(diào)器)能承載路由器的最大數(shù)目。這個(gè)參數(shù)實(shí)際上是MAX_CHILDREN參數(shù)的一個(gè)子集,剩下的(MAX_CHILDREN-MAX_ROUTERS)地址空間屬于終端設(shè)備。
開發(fā)者自定義

如果開發(fā)者想改變這些值,那么需要做如下幾步:

首先得保證這些參數(shù)新的值是合法的。既然整個(gè)地址空間被限制在2-16內(nèi),那么這些參數(shù)的大小就已經(jīng)有了限制。分布在release(在文件夾Projects\zstack\Tools中)的Cskip.xls文件能校驗(yàn)這些參數(shù)是否合法。在鍵入這些參數(shù)的值后大概這個(gè)電子表格,如果非法,一個(gè)錯(cuò)誤信息將給出。

之后選擇合法的值,開發(fā)者需要確保不使用標(biāo)準(zhǔn)的協(xié)議棧模式,而用指定的協(xié)議棧模式代替(用NETWORK_SPECIFIC替換STACK_PROFILE_ID當(dāng)前的值)。然后在“nwk_globals.h”文件中的MAX_DEPTH參數(shù)根據(jù)需要設(shè)置為適當(dāng)?shù)闹怠?/span>

另外,nwk_globals.c文件中排列的CskipChldrnCskipRtrs必須被設(shè)置,這些排列是
z-stack中的尋址

為了在網(wǎng)絡(luò)中發(fā)送數(shù)據(jù)到一個(gè)設(shè)備,應(yīng)用層一般用AF_DataRequest()函數(shù)。而被發(fā)送的目的設(shè)備的地址類型afAddrType_t被定義在“ZComDef.h”中:
typedef struct
{
union
{
uint16   shortAddr;
ZLongAddr_t extAddr;
} addr;
byte addrMode;
} zAddrType_t;
地址模式參數(shù)
注意:除這個(gè)網(wǎng)絡(luò)地址之外,地址模式參數(shù)也需要被指定。目的地址模式可能是如下值之一(AF地址模式被定義在“AF.h”中):
typedef enum
{
 afAddrNotPresent = AddrNotPresent,
 afAddr16Bit = Addr16Bit,
 afAddrGroup = AddrGroup,
 afAddrBroadcast = AddrBroadcast
} afAddrMode_t;

地址模式參數(shù)是需要的,因?yàn)樵?/span>ZB中,數(shù)據(jù)包能被點(diǎn)傳輸、多點(diǎn)傳輸或者廣播傳輸。點(diǎn)傳輸被發(fā)送到單個(gè)設(shè)備,多點(diǎn)傳輸一定發(fā)送到一組設(shè)備,廣播傳輸一般被發(fā)送到網(wǎng)絡(luò)中的所有設(shè)備。如下是更詳細(xì)的說明。
點(diǎn)到傳輸 Unicast

這是標(biāo)準(zhǔn)地址模式,被用于發(fā)送一個(gè)數(shù)據(jù)包到網(wǎng)絡(luò)中單個(gè)已知地址的設(shè)備。這個(gè)addrMode參數(shù)被設(shè)置為Addr16Bit,目的網(wǎng)絡(luò)地址在數(shù)據(jù)包中一同被發(fā)送。
間接尋址

數(shù)據(jù)包中的最終目的地址不識別的時(shí)候使用。該模式被AddrNotPresent設(shè)置,而且目的地址沒有被指定。代替目的地址的是:一個(gè)存儲(chǔ)在發(fā)送設(shè)備協(xié)議棧的綁定表格,該表格中有被綁定設(shè)備的地址。這個(gè)特性被調(diào)用是源于綁定。(看后面關(guān)于綁定部分)
當(dāng)被發(fā)送的信息包下載到協(xié)議棧時(shí),從這個(gè)綁定表格中尋找使用的目的地址。然后該信息包被有規(guī)則的處理為點(diǎn)對點(diǎn)數(shù)據(jù)包。如果有多個(gè)(大于1)目的地址在綁定表格中被發(fā)現(xiàn),那么該數(shù)據(jù)包將被拷貝成對應(yīng)的份數(shù)分別發(fā)送給他們。

(ZigBee04)版本之前,在協(xié)調(diào)器中有一個(gè)存儲(chǔ)綁定表格的選項(xiàng)。因此,發(fā)送設(shè)備發(fā)送數(shù)據(jù)包到這個(gè)協(xié)調(diào)器,然后協(xié)調(diào)器在它的綁定表格中查找最終的目的地址,對數(shù)據(jù)包進(jìn)行在一次發(fā)送。該選項(xiàng)特性在協(xié)調(diào)器綁定被調(diào)用
廣播傳輸

該模式在應(yīng)用層想發(fā)送一個(gè)數(shù)據(jù)包到所有網(wǎng)絡(luò)中的所有設(shè)備時(shí)被使用。該地址模式被AddrBroadcast被設(shè)置,目的地址被設(shè)置為下列值之一:
NWK_BROADCAST_SHORTADDR_DEVALL (0xFFFF)-
信息將被發(fā)送到網(wǎng)絡(luò)中的所有設(shè)備(包括休眠的設(shè)備)。對于休眠的設(shè)備,這個(gè)信息將被保持在它的父節(jié)點(diǎn),直到該休眠設(shè)備獲得該信息或者該信息時(shí)間溢出(在f8wConfig.cfg 中的NWK_INDIRECT_MSG_TIMEOUT選項(xiàng))。
NWK_BROADCAST_SHORTADDR_DEVRXON (0xFFFD) –
該信息將被發(fā)送到網(wǎng)絡(luò)中有接收器并處于IDLE(RXONWHENIDLE)狀態(tài)下的所有設(shè)備。也就是說,除了休眠模式設(shè)備的所有設(shè)備。
NWK_BROADCAST_SHORTADDR_DEVZCZR (0xFFFC) –
該信息被發(fā)送到所有路由器(包括協(xié)調(diào)器)。
組地址

該模式用于應(yīng)用層想發(fā)送一個(gè)數(shù)據(jù)包到一個(gè)設(shè)備組的時(shí)候。該地址模式被afAddrGroup設(shè)置這個(gè)組標(biāo)志符。

用該特性之前,在網(wǎng)絡(luò)中,組不得不被定義[ZStack API文檔中的] aps_AddGroup()
注意:組能與間接尋址一起結(jié)合使用。該目的地址在綁定表格中發(fā)現(xiàn),可以作為點(diǎn)對點(diǎn)或一個(gè)組地址。也要注意廣播地址可以當(dāng)作是組被提前設(shè)置,一個(gè)簡單的組尋址的特例,。
例子代碼對于一個(gè)設(shè)備添加它自己到一個(gè)組標(biāo)志符1
aps_Group_t group;
// Assign yourself to group 1
group.ID = 0x0001;
group.name[0] = 0; // This could be a human readable string
aps_AddGroup( SAMPLEAPP_ENDPOINT, &group );
重要設(shè)備地址

一個(gè)應(yīng)用可以能想知道它自身和父節(jié)點(diǎn)的地址,用下面的函數(shù)可以得到設(shè)備的地址(被定義在ZStack API文檔中):
NLME_GetShortAddr() –
返回該設(shè)備的 16 位網(wǎng)絡(luò)地址
 NLME_GetExtAddr() –
返回該設(shè)備的64 位擴(kuò)展地址.
用下面的函數(shù)可以得到該設(shè)備的父節(jié)點(diǎn)的地址(被定義在ZStack API文檔中)。注意該函數(shù)在協(xié)調(diào)器中不被涉及到,但是被設(shè)備父節(jié)點(diǎn)代替(MAC協(xié)調(diào)器):
 NLME_GetCoordShortAddr() – returns this device’s parent’s 16 bit short address.
  NLME_GetCoordExtAddr() – returns this device’s parent’s 64 bit extended address.
先介紹這兩個(gè)概念:節(jié)點(diǎn)和地址。其余的就改天繼續(xù)!

學(xué)習(xí)Z-Stack7
--------------Z-Stack
指導(dǎo)2

上節(jié)介紹了很大一部分Z-Stack的基礎(chǔ)知識,這里接著忽悠。雖然說的不是很專業(yè)也不是很通俗,但是我盡力了,希望有人能看明白!本人英文水平有限,翻譯的不好請諒解!
3、綁定

綁定是控制信息從一個(gè)應(yīng)用層到另一個(gè)應(yīng)用層流動(dòng)的一種機(jī)制。在ZB06版本中,綁定機(jī)制在所有的設(shè)備中被執(zhí)行。

綁定允許應(yīng)用層發(fā)送信息不需要帶目的地址,APS層確定目的地址從他的綁定表格中,然后在信息前端加上這個(gè)目的地址或組。

注意:在ZB1.0版本中,所有綁定條目存儲(chǔ)在協(xié)調(diào)器中。現(xiàn)在所有綁定條目存儲(chǔ)在發(fā)送數(shù)據(jù)的設(shè)備中。
3.1綁定一個(gè)綁定表格

有三種方式建立一個(gè)綁定表格:

ZDO 綁定請求 – 一個(gè)試運(yùn)轉(zhuǎn)工具能告訴這個(gè)設(shè)備制作一個(gè)綁定報(bào)告。

ZDO 終端設(shè)備綁定請求 – 2設(shè)備能告訴協(xié)調(diào)器他們想建立綁定表格報(bào)告。該協(xié)調(diào)器將使協(xié)調(diào)并在這兩個(gè)設(shè)備上創(chuàng)建綁定表格條目

設(shè)備應(yīng)用 – 在設(shè)備上的應(yīng)用能建立或管理一個(gè)綁定表格 。

任何一個(gè)設(shè)備或應(yīng)用能在網(wǎng)絡(luò)中發(fā)送一個(gè)ZDO信息到另一個(gè)設(shè)備()建立一個(gè)綁定報(bào)告。這是調(diào)用綁定幫助并且它將建立一個(gè)綁定條目為發(fā)送設(shè)備。
3.1.1 ZDO 綁定請求

通過調(diào)用函數(shù)ZDP_BindReq()發(fā)送一個(gè)綁定請求。第一個(gè)參數(shù)(dstAddr)是綁定的源地址的短地址。這之前應(yīng)該確定允許綁定,在ZDConfig.h 文件中有參數(shù)[ZDO_BIND_UNBIND_REQUEST]允許綁定。能用同樣的參數(shù)調(diào)用函數(shù)ZDP_UnbindReq()移除綁定。

目標(biāo)設(shè)備將調(diào)用函數(shù)ZDApp_BindRsp()或 ZDApp_UnbindRsp(),反饋綁定或移除綁定的響應(yīng),返回其操作狀態(tài)為ZDP_SUCCESS, ZDP_TABLE_FULL或ZDP_NOT_SUPPORTED.
3.1.2 ZDO 終端設(shè)備綁定請求

該機(jī)制是用一個(gè)按鈕按下或其他類似的動(dòng)作來選擇設(shè)備在指定時(shí)間內(nèi)被綁定。在規(guī)定時(shí)間內(nèi),該終端設(shè)備綁定請求信息被收集到協(xié)調(diào)器,并創(chuàng)建一個(gè)基于模式(profile) ID 和串(cluster) ID的規(guī)定的綁定表格條目。默認(rèn)的終端設(shè)備綁定超時(shí)時(shí)間(APS_DEFAULT_MAXBINDING_TIME)為16S(定義在nwk_globals.h中),但是能被改變
發(fā)送綁定請求

在所有的應(yīng)用例子中有一個(gè)處理鍵盤事件的函數(shù)[例如在TransmitApp.c文件中的TransmitApp_HandleKeys()函數(shù)]。在該函數(shù)中,調(diào)用了函數(shù)ZDApp_SendEndDeviceBindReq()[在ZDApp.c中],它將收集應(yīng)用的終端設(shè)備的所有信息并調(diào)用函數(shù)ZDP_EndDeviceBindReq() [ZDProfile.c],發(fā)送一個(gè)綁定信息到協(xié)調(diào)器?;蛘?,在SampleLight 和 SampleSwitch例子中,直接調(diào)用ZDP_EndDeviceBindReq()函數(shù)就實(shí)現(xiàn)點(diǎn)亮/關(guān)閉燈的功能。
接收綁定請求

協(xié)調(diào)器將接收[ZDP_IncomingData() 在 ZDProfile.c]這些信息并分析處理[ZDO_ProcessEndDeviceBindReq() 在 ZDObject.c]這些信息并調(diào)用函數(shù)ZDApp_EndDeviceBindReqCB() [in ZDApp.c],它將調(diào)用ZDO_MatchEndDeviceBind() [ZDObject.c]處理這個(gè)請求

當(dāng)協(xié)調(diào)器接收到2個(gè)匹配終端色后備的綁定請求時(shí),它將啟動(dòng)在綁定設(shè)備上創(chuàng)建源綁定條目的處理過程。該協(xié)調(diào)器有如下處理過程:
解除綁定

1. 發(fā)送一個(gè)ZDO解除綁定請求到第一個(gè)設(shè)備。終端設(shè)備綁定切換處理,所以解除綁定首先被發(fā)送到移除一個(gè)存在的綁定條目。

2. 等待ZDO解除綁定響應(yīng),如果響應(yīng)狀態(tài)為ZDP_NO_ENTRY, 發(fā)送一個(gè)ZDO綁定請求,在源設(shè)備上制作一個(gè)綁定條目 。如果該響應(yīng)為ZDP_SUCCESS, 為第一個(gè)設(shè)備繼續(xù)到move on to the cluster ID for the first device (the unbind removed the entry – toggle).

3. 等待ZDO綁定響應(yīng). When received, move on to the next cluster ID for the first device.

4. 當(dāng)?shù)谝粋€(gè)設(shè)備完成時(shí),對第二個(gè)設(shè)備做同樣的處理。

5. 當(dāng)?shù)诙€(gè)設(shè)備完成時(shí),發(fā)送ZDO 終端設(shè)備綁定響應(yīng)信息到第一個(gè)和第二個(gè)設(shè)備
3.1.3設(shè)備應(yīng)用綁定管理

在設(shè)備上其他進(jìn)入綁定條目的方式是應(yīng)用層管理綁定表格。

意思是說,應(yīng)用層將調(diào)用下列函數(shù)進(jìn)入和移除綁定表格條目:
bindAddEntry() –增加綁定表格條目
bindRemoveEntry() – 從綁定表格中移除條目
bindRemoveClusterIdFromList() – 從一個(gè)存在的綁定表格項(xiàng)目中移除一個(gè)串 ID 。
bindAddClusterIdToList()——向一個(gè)已經(jīng)存在的綁定記錄中增加一個(gè)群ID
bindRemoveDev()——?jiǎng)h除所有地址引用的記錄
bindRemoveSrcDev()——?jiǎng)h除所有源地址引用的記錄
bindUpdateAddr()——將記錄更新為另一個(gè)地址
bindFindExisting()——查找一個(gè)綁定表記錄
bindIsClusterIdInList()——在表記錄中檢查一個(gè)已經(jīng)存在的群ID
bindNumBoundTo()——擁有相同地址(源或者目的)的記錄的個(gè)數(shù)
bindNumEntries()——表中記錄的個(gè)數(shù)
bindCapacity()——最多允許的記錄個(gè)數(shù)
bindWriteNV()——在NV中更新表
3.2 配置源綁定

允許綁定源的編譯選項(xiàng)REFLECTOR在f8wConfig.cfg文件中。在文件f8wConfig.cfg,中查看這兩個(gè)綁定配置參數(shù)(NWK_MAX_BINDING_ENTRIES & MAX_BINDING_CLUSTER_IDS)。NWK_MAX_BINDING_ENTRIES綁定表格中最大的綁定實(shí)體數(shù)量參數(shù);MAX_BINDING_CLUSTER_IDS 是在每個(gè)綁定實(shí)體中最大的串ID數(shù)量。

綁定表在靜態(tài)RAM中(未分配),因此綁定表中記錄的個(gè)數(shù),每條記錄中群ID的個(gè)數(shù)都實(shí)際影響著使用RAM的數(shù)量。每一條綁定記錄是8字節(jié)多(MAX_BINDING_CLUSTER_IDS * 2字節(jié))。除了綁定表使用的靜態(tài)RAM的數(shù)量,綁定配置項(xiàng)目也影響地址管理器中的記錄的個(gè)數(shù)。
4、路由
4.1 預(yù)覽

在MESH網(wǎng)絡(luò)中,為了使分布的節(jié)點(diǎn)間能夠很好的通信,路由是非常重要的一個(gè)環(huán)節(jié)。

在應(yīng)用層上路由是完全透明的。一個(gè)簡單的應(yīng)用數(shù)據(jù)發(fā)送到任意設(shè)備,下至協(xié)議棧,協(xié)議棧將負(fù)責(zé)發(fā)現(xiàn)一個(gè)路由路線。這個(gè)方式,應(yīng)用層是不知道該操作在多跳網(wǎng)絡(luò)中完成的事實(shí)。

路由使ZB網(wǎng)絡(luò)具有“自動(dòng)復(fù)原”的特性。如果一個(gè)無線連接斷了,路由功能將自動(dòng)的發(fā)現(xiàn)一個(gè)新的路由路線,該路線是避開(繞過)壞了的那個(gè)連接節(jié)點(diǎn)。這就提高了無線網(wǎng)絡(luò)的可靠性,這也是ZB關(guān)鍵特點(diǎn)之一。
4.2 路由協(xié)議

ZB執(zhí)行的路由協(xié)議是基于AODV(Ad hoc On demand Distance Vector)的路由協(xié)議。作為一個(gè)簡單的應(yīng)用---傳感器網(wǎng)絡(luò),ZB路由協(xié)議支持環(huán)境中的移動(dòng)節(jié)點(diǎn),連接失敗和丟包功能。

當(dāng)一個(gè)路由器接收到一個(gè)點(diǎn)對點(diǎn)信息包時(shí),從他的應(yīng)用或者從其他設(shè)備,NWK層將繼續(xù)向前依照下面的進(jìn)程。如果目的是路由器鄰節(jié)點(diǎn)(包括它的子設(shè)備)之一,該信息包將直接傳輸?shù)侥康脑O(shè)備。另外的就是,路由器將檢查它的路由表格,檢查相應(yīng)的信息包目的條目。如果在路由表格中有一個(gè)活躍的路由路線到該目的設(shè)備,那么該信息包將被轉(zhuǎn)播到下一跳節(jié)點(diǎn)地址存儲(chǔ)依照路由條目。如果沒有活躍的條目發(fā)現(xiàn),那么一個(gè)路由發(fā)現(xiàn)被啟動(dòng)并且該信息被緩存直到該過程完成。
ZB終端設(shè)備路由

ZB終端設(shè)備不能執(zhí)行任何路由功能。一個(gè)終端設(shè)備想發(fā)送一個(gè)信息包到任何設(shè)備都要向前到它的父設(shè)備,然后在由其父設(shè)備進(jìn)行路由操作。類似的,任何設(shè)備想發(fā)送信息包到終端設(shè)備,都將發(fā)起一個(gè)路由發(fā)現(xiàn)操作,當(dāng)然該操作都由終端設(shè)備的父設(shè)備響應(yīng)。

注意:ZB地址分配方案使基于它的地址發(fā)起一個(gè)路由到任何目的成為可能。在Z-Sstack,這個(gè)機(jī)制被用于萬一正規(guī)的路由程序不能被啟動(dòng),作為一個(gè)自動(dòng)退卻(一般情況是由于路由表格空間不夠)。
z-stack路由

在z-stack,執(zhí)行的路由是已經(jīng)被優(yōu)化的路由存儲(chǔ)表格。一般情況,對于每一個(gè)目的設(shè)備路由表格條目是需要的。但是通過綜合攜帶父節(jié)點(diǎn)所有條目的特定父節(jié)點(diǎn)的終端設(shè)備的所有條目,沒有任何功能丟失的存儲(chǔ)已經(jīng)被優(yōu)化。

ZB路由器,包括協(xié)調(diào)器,執(zhí)行如下路由功能 (i)路由發(fā)現(xiàn)和選擇 (ii) 路由維護(hù)(iii)
4.2.1路由發(fā)現(xiàn)和選擇

路由發(fā)現(xiàn)是網(wǎng)絡(luò)設(shè)備協(xié)作發(fā)現(xiàn)和建立路由的一個(gè)過程。一個(gè)路由操作總是針對某個(gè)目的,通過任何一個(gè)路由器啟動(dòng)。該路由發(fā)現(xiàn)機(jī)制在源設(shè)備和目的設(shè)備間搜尋所有可能的路由并試圖選擇最好的路由路線。
? 路由選擇通過選擇最小消耗的路由路線。每個(gè)設(shè)備在連接到鄰節(jié)點(diǎn)幾乎保持不變的“連接消耗”。該連接消耗是接收信號的強(qiáng)度的一個(gè)典型功能。沿著路由路線加起所有的連接消耗,就是整個(gè)路由的“連接消耗”。路由算法試圖選擇這個(gè)路由最小的“路由消耗”。
路由請求

路由通過請求/響應(yīng)信息包被發(fā)現(xiàn)。一個(gè)源設(shè)備為了一個(gè)目的地址,通過發(fā)送一個(gè)廣播路由請求(RREQ)信息到它的鄰設(shè)備請求一個(gè)路由。當(dāng)一個(gè)節(jié)點(diǎn)接收到一個(gè)RREQ信息時(shí),它將依次轉(zhuǎn)播這個(gè)RREQ信息。但是在做這個(gè)之前,它更新RREQ信息的消耗域,通過增加連接消耗為了最后的連接。這樣,RREQ信息將攜帶向前傳輸?shù)乃械倪B接消耗。這個(gè)重復(fù)過程直到RREQ到達(dá)這個(gè)目的設(shè)備。RREQ的一些復(fù)制可能經(jīng)過不同的路徑重復(fù)到達(dá)目的設(shè)備。該目的設(shè)備選擇最好的RREQ信息并發(fā)送一個(gè)路由答復(fù)(RREP)返回到源設(shè)備。
路由響應(yīng)

RREP是沿著唯一的相反的路徑返回到最初的請求節(jié)點(diǎn)。

作為RREP信息傳播回源節(jié)點(diǎn),中間的節(jié)點(diǎn)更新他們的路由表格,指出路由路線到目的設(shè)備。

一旦一個(gè)路由被創(chuàng)建,數(shù)據(jù)包能被發(fā)送。當(dāng)一個(gè)節(jié)點(diǎn)丟失到它下一個(gè)節(jié)點(diǎn)的連通性時(shí)(發(fā)送數(shù)據(jù)包時(shí),它不能接收一個(gè)MAC應(yīng)答ACK),這個(gè)節(jié)點(diǎn)通過發(fā)送一個(gè)RERR到所有潛在的接收它RREP的節(jié)點(diǎn),使該路由無效。在接收一個(gè)RREQ,RREP或RERR之上,這些節(jié)點(diǎn)都將更新他們的路由表格
4.2.2路由維護(hù)

MESH網(wǎng)絡(luò)提供路由維護(hù)和自動(dòng)修復(fù)。中間節(jié)點(diǎn)保持沿著連接傳輸失效的路徑。如故一個(gè)連接被確定壞了,逆流的節(jié)點(diǎn)將啟動(dòng)路由修復(fù)那些連接的所有路由路線。這些工作通過啟動(dòng)路由重新發(fā)送被做,為了路由下一次數(shù)據(jù)包接收。如果路由重新發(fā)現(xiàn)不能啟動(dòng),或者由于某些原因失敗了,一個(gè)路由錯(cuò)誤(RERR)信息被發(fā)送到這個(gè)數(shù)據(jù)包的源設(shè)備,然后重新啟動(dòng)新的路由發(fā)現(xiàn)。任意方式都使得該路由得到重新自動(dòng)建立。
4.2.3路由終結(jié)

為了建立路由,路由表格條目要被維護(hù)。如果一段時(shí)間沒有數(shù)據(jù)包沿著路由路線發(fā)送,該路由將被做終結(jié)記號。終止路由不是刪除直到空間需要時(shí)。因此沒有被刪除直到它完全需要時(shí)。自動(dòng)路由終結(jié)時(shí)間能被配置“在f8wconfig.cfg"文件中”。設(shè)置ROUTE_EXPIRY_TIME參數(shù)為終結(jié)時(shí)間(秒)。設(shè)置0為了關(guān)閉路由終結(jié)。
4.3 表格存儲(chǔ)

路由功能需要路由器維護(hù)一些表格:

路由表格

路由發(fā)現(xiàn)表格
4.3.1路由表格

每一個(gè)路由器包括協(xié)調(diào)器都包含一個(gè)路由表。設(shè)備在路由表中保存數(shù)據(jù)包參與路由所需的信息。每一條路由表記錄都包含有目的地址,下一級節(jié)點(diǎn)和連接狀態(tài)。所有的數(shù)據(jù)包都通過相鄰的一級節(jié)點(diǎn)發(fā)送到目的地址。同樣,為了回收路由表空間,可以終止路由表中的那些已經(jīng)無用的路徑記錄。

路由表的容量表明一個(gè)設(shè)備路由表擁有一個(gè)自由路由表記錄或者說它已經(jīng)有一個(gè)與目標(biāo)地址相關(guān)的路由表記錄。在文件“f8wConfig.cfg”文件中配置路由表的大小。將MAX_RTG_ENTRIES設(shè)置為表的大小(不能小于4)。
4.3.2路由發(fā)現(xiàn)表格

路由器設(shè)備致力于路徑發(fā)現(xiàn),保持維護(hù)路徑發(fā)現(xiàn)表。這個(gè)表用來保存路徑發(fā)現(xiàn)過程中的臨時(shí)信息。這些記錄只在路徑發(fā)現(xiàn)操作期間存在。一旦某個(gè)記錄到期,則它可以被另一個(gè)路徑發(fā)現(xiàn)使用。這個(gè)值決定了在一個(gè)網(wǎng)絡(luò)中,可以同時(shí)并發(fā)執(zhí)行的路徑發(fā)現(xiàn)的最大個(gè)數(shù)。這個(gè)可以在f8wConfig.cfg文件中配置MAX_ RREQ_ENTRIES。
4.4、路徑設(shè)置快速參考

設(shè)置路由表大小MAX_RTG_ENTRIES,這個(gè)值不能小于4 (f8wConfig.cfg文件)
設(shè)置路徑期滿時(shí)間ROUTE_EXPIRY_TIME,單位秒。設(shè)置為零則關(guān)閉路徑期滿(f8wConfig.cfg文件)

設(shè)置路徑發(fā)現(xiàn)表大小 MAX_RREQ_ENTRIES,網(wǎng)絡(luò)中可以同時(shí)執(zhí)行的路徑發(fā)現(xiàn)操作的個(gè)數(shù)

 

 

 

學(xué)習(xí)ZStack8

近段時(shí)間比較忙,幾乎都快荒廢了Z-Stack的學(xué)習(xí)了,把以前學(xué)的都快忘記了,這就是非專業(yè)技術(shù)的痛苦?。?!學(xué)習(xí)剛好有點(diǎn)眉目,突然意外中斷停下,當(dāng)再一次學(xué)習(xí)的時(shí)候突然發(fā)現(xiàn):以前學(xué)的都忘了8成了!郁悶??!今天真不知道從什么地方下手學(xué)習(xí)了,所以就針對最近客戶比較關(guān)心的問題做點(diǎn)介紹,這樣有針對性、有目的性的學(xué)習(xí)可能最適合現(xiàn)在的我了,不然從頭把以前那些所謂的筆記看一遍,可能今天晚上又沒了,指不定明晚以及后晚以及后后晚…都沒時(shí)間,不然老是看以前的筆記沒有進(jìn)展就麻煩了!呵呵!

今天只解決1個(gè)問題:TI提供的例子程序的表演及功能介紹。

因?yàn)樽罱鼏栠@些的客戶比較多,特別又是剛?cè)胧值呐笥?,對Z-Stack非常迷糊的時(shí)期,如果能夠跑通幾個(gè)例子、看幾個(gè)演示,那么可以大大提高學(xué)習(xí)興趣;另外如果知道某個(gè)例子的大致功能及實(shí)現(xiàn),那么在去看具體實(shí)現(xiàn)過程目的性就非常明確。
首先來看看TI究竟有哪些例子:
 
可以看出其例子是非常豐富的。
GenericApp,Location,SampleApp,SimpleApp,HomeAutomation,SerialApp,Transmit,
ZLOAD。這樣看來還是不少的。其中SampleApp例子已經(jīng)在前面的學(xué)習(xí)中有所涉及,可以說前面的所有學(xué)習(xí)都是基于這個(gè)例子的,所以這里就不測試它了。Location是定位的測試?yán)?,這里我的硬件是不夠的,所以也不做測試。其他我都做點(diǎn)測試,能成功的就成功,不能成功的就失敗,這個(gè)我也沒辦法,呵呵!?。。。。。?!
1、GenericApp

工程打開等我就不多說了,自己去找,如果連這些我都還說,那么我以前的東西是白學(xué)了。硬件連接中

當(dāng)我用兩個(gè)節(jié)點(diǎn)分別燒寫入DB的協(xié)調(diào)器和路由器,從我的經(jīng)驗(yàn)看來,他們分別能建立網(wǎng)絡(luò)和加入網(wǎng)絡(luò),但是從表象上幾乎看不見數(shù)傳現(xiàn)象,盡管我按了每個(gè)節(jié)點(diǎn)的按鍵,也僅僅是本節(jié)點(diǎn)的LED在改變。唯獨(dú)有點(diǎn)數(shù)傳感覺的是:按鍵右鍵對方有反應(yīng)就是了,至于具體什么反映我覺得沒必要說明白,大家試試就知道了。

所以還決定看看程序來判斷這個(gè)例子的功能。

大約瀏覽了下,這個(gè)例子似乎還與設(shè)備的綁定有關(guān)系,因?yàn)樵诎唇ㄌ幚沓绦蛑邪l(fā)現(xiàn):
if ( keys & HAL_KEY_SW_2 )
    {
      HalLedSet ( HAL_LED_4, HAL_LED_MODE_OFF );

      // Initiate an End Device Bind Request for the mandatory endpoint
      dstAddr.addrMode = Addr16Bit;
      dstAddr.addr.shortAddr = 0x0000; // Coordinator
      ZDP_EndDeviceBindReq( &dstAddr, NLME_GetShortAddr(),
                            GenericApp_epDesc.endPoint,
                            GENERICAPP_PROFID,
                            GENERICAPP_MAX_CLUSTERS, (cId_t *)GenericApp_ClusterList,
                            GENERICAPP_MAX_CLUSTERS, (cId_t *)GenericApp_ClusterList,
                            FALSE );
}
很明顯這里按鍵2(右鍵)是發(fā)送綁定請求的命令。
if ( keys & HAL_KEY_SW_4 )
    {
      HalLedSet ( HAL_LED_4, HAL_LED_MODE_OFF );

      // Initiate a Match Deion Request (Service Discovery)
      dstAddr.addrMode = AddrBroadcast;
      dstAddr.addr.shortAddr = NWK_BROADCAST_SHORTADDR;
      ZDP_MatchDescReq( &dstAddr, NWK_BROADCAST_SHORTADDR,
                        GENERICAPP_PROFID,
                        GENERICAPP_MAX_CLUSTERS, (cId_t *)GenericApp_ClusterList,
                        GENERICAPP_MAX_CLUSTERS, (cId_t *)GenericApp_ClusterList,
                        FALSE );
    }
顯然按鍵4(左)是初始化一個(gè)匹配描述符請求,也就是發(fā)現(xiàn)服務(wù),或者叫自動(dòng)尋求匹配設(shè)備。
這就不怪我按鍵有反映了!
而且在發(fā)送數(shù)據(jù)和接收數(shù)據(jù)處理函數(shù)發(fā)現(xiàn):
void GenericApp_SendTheMessage( void )
{
  char theMessageData[] = "Hello World";

  if ( AF_DataRequest( &GenericApp_DstAddr, &GenericApp_epDesc,
                       GENERICAPP_CLUSTERID,
                       (byte)osal_strlen( theMessageData ) + 1,
                       (byte *)&theMessageData,
                       &GenericApp_TransID,
                       AF_DISCV_ROUTE, AF_DEFAULT_RADIUS ) == afStatus_SUCCESS )
  {
    // Successfully requested to be sent.
  }
  else
  {
    // Error occurred in request to send.
  }
}
居然發(fā)送的是一個(gè)字符串“Hello World”。
void GenericApp_MessageMSGCB( afIncomingMSGPacket_t *pkt )
{
  switch ( pkt->clusterId )
  {
    case GENERICAPP_CLUSTERID:
      // "the" message
#if defined( LCD_SUPPORTED )
      HalLcdWriteScreen( (char*)pkt->cmd.Data, "rcvd" );
#elif defined( WIN32 )
      WPRINTSTR( pkt->cmd.Data );
#endif
      break;
  }
}
接收數(shù)據(jù)處理函數(shù)里居然要通過液晶顯示,本人這里的液晶暫時(shí)沒有移植過來,因?yàn)闀簳r(shí)還不具備那個(gè)實(shí)力,怪不得看不到發(fā)送數(shù)據(jù)的狀況!
這里本人就自作聰明的把以前SampleApp例子里面的一句話加過來了:
void GenericApp_MessageMSGCB( afIncomingMSGPacket_t *pkt )
{
  switch ( pkt->clusterId )
  {
    case GENERICAPP_CLUSTERID:
      // "the" message
      HalLedBlink( HAL_LED_4, 4, 50, (500) );
#if defined( LCD_SUPPORTED )
      HalLcdWriteScreen( (char*)pkt->cmd.Data, "rcvd" );
#elif defined( WIN32 )
      WPRINTSTR( pkt->cmd.Data );
#endif
      break;
  }
}
麼想到啊,這么一加居然就有反應(yīng)了,o(∩_∩)o…!我不愧是天才的接班人??!
其實(shí)這里很簡單的了,就是接收到數(shù)據(jù)后閃爍4下燈,間隔0.5S。因?yàn)閺模?/span>
if ( events & GENERICAPP_SEND_MSG_EVT )
  {
    // Send "the" message
    GenericApp_SendTheMessage();
    // Setup to send message again
    osal_start_timerEx( GenericApp_TaskID,
                        GENERICAPP_SEND_MSG_EVT,
                        GENERICAPP_SEND_MSG_TIMEOUT );
    // return unprocessed events
    return (events ^ GENERICAPP_SEND_MSG_EVT);
  }
這里可以看出,這個(gè)例子很明顯僅僅是個(gè)發(fā)送周期信息的例子。所以LED4就周期性的閃爍4下,當(dāng)然是協(xié)調(diào)器發(fā)送,路由器閃爍,路由器發(fā)送,協(xié)調(diào)器閃爍。
但是這例子里體現(xiàn)了綁定的概念,應(yīng)該說是從基本功能上很齊全的一個(gè)例子,而且在ZSTACK上實(shí)現(xiàn)無線網(wǎng)絡(luò)數(shù)傳,沒有任何多余的功能。所以該例子是一個(gè)典型的ZSTACK模板,也就是為用戶提供了一個(gè)通用模板可以通過這個(gè)建立自己的應(yīng)用。關(guān)于如何在這個(gè)例子上建立、修改成自己的工程和應(yīng)用項(xiàng)目詳細(xì)見文檔:
Create New Application For The CC2430DB_F8W-2005-0033_.pdf
這個(gè)例子就到此結(jié)束了,否則不然就很難把下面的弄玩了!
2、SimpleApp
這個(gè)例子我基本跑通了,可是鑒于時(shí)間的關(guān)系,沒有來得及打字了,所以就留到下一次了,時(shí)間真是如流水啊-------------------快!

 

 

學(xué)習(xí)Z-Stack9


接到昨天的繼續(xù)忽悠,話說:
2、SimpleApp
“這個(gè)例子我基本跑通了,可是鑒于時(shí)間的關(guān)系,沒有來得及打字了,所以就留到下一次了,時(shí)間真是如流水啊-------------------快!….”
這個(gè)例子里面有兩個(gè)演示:一個(gè)是燈與開關(guān)的控制實(shí)驗(yàn),一個(gè)溫度傳感器實(shí)驗(yàn)。咱一個(gè)個(gè)來,不忙。
燈與開關(guān)實(shí)驗(yàn)

在這個(gè)例子中燈對應(yīng)的工程名字為:SimpleControllerDB;開關(guān)對應(yīng):SimpleSwitchDB。嚴(yán)重需要注意的地方,這里選用的是DB。因?yàn)閺膹牧汩_始學(xué)習(xí)Z-Stack之1上可以看到DB與EB的區(qū)別,而這里用DB的硬件就足以應(yīng)付。
編譯下載我就不繼續(xù)羅嗦了。

咱關(guān)心的幾個(gè)問題不外乎就是表演過程和表演結(jié)果,以及初步看看為什么會(huì)有這樣的結(jié)果產(chǎn)生,當(dāng)然就得從程序上簡單了解下。

首先打開Controller(也就是燈設(shè)備)的電源,那么LED2就會(huì)不停的閃爍,這個(gè)時(shí)候是設(shè)備正在初始化,讓您選擇設(shè)備以哪種類型啟動(dòng),從程序可以看出:
   if ( keys & HAL_KEY_SW_1 )
    {
      if ( myAppState == APP_INIT  )
      {
        // In the init state, keys are used to indicate the logical mode.
        // Key 1 starts device as a coordinator
        zb_ReadConfiguration( ZCD_NV_LOGICAL_TYPE, sizeof(uint8), &logicalType );
        if ( logicalType != ZG_DEVICETYPE_ENDDEVICE )
        {
          logicalType = ZG_DEVICETYPE_COORDINATOR;
          zb_WriteConfiguration(ZCD_NV_LOGICAL_TYPE, sizeof(uint8), &logicalType);
        }

        // Do more configuration if necessary and then restart device with auto-start bit set
        // write endpoint to simple desc...dont pass it in start req..then reset
        zb_ReadConfiguration( ZCD_NV_STARTUP_OPTION, sizeof(uint8), &startOptions );
        startOptions = ZCD_STARTOPT_AUTO_START;
        zb_WriteConfiguration( ZCD_NV_STARTUP_OPTION, sizeof(uint8), &startOptions );
        zb_SystemReset();
      }
如果按下S1(UP),那么作為協(xié)調(diào)器啟動(dòng)。
   if ( keys & HAL_KEY_SW_2 )
    {
      if ( myAppState == APP_INIT )
      {
        // In the init state, keys are used to indicate the logical mode.
        // Key 2 starts device as a router
        zb_ReadConfiguration( ZCD_NV_LOGICAL_TYPE, sizeof(uint8), &logicalType );
        if ( logicalType != ZG_DEVICETYPE_ENDDEVICE )
        {
          logicalType = ZG_DEVICETYPE_ROUTER;
          zb_WriteConfiguration(ZCD_NV_LOGICAL_TYPE, sizeof(uint8), &logicalType);
        }
        zb_ReadConfiguration( ZCD_NV_STARTUP_OPTION, sizeof(uint8), &startOptions );
        startOptions = ZCD_STARTOPT_AUTO_START;
        zb_WriteConfiguration( ZCD_NV_STARTUP_OPTION, sizeof(uint8), &startOptions );
        zb_SystemReset();
      }
如果按下S2(RIGHT),設(shè)備作為路由器啟動(dòng)。

這里由于是第一個(gè)啟動(dòng)的設(shè)備,所以作為協(xié)調(diào)器啟動(dòng),就按下UP,此時(shí)燈會(huì)有狀態(tài)變化,最終結(jié)果是:LED2常亮,標(biāo)示建立網(wǎng)絡(luò)成功。如果您還有另外的燈設(shè)備就可以按下RIGHT讓他們都作為路由器啟動(dòng),由于本人這里只有兩個(gè)節(jié)點(diǎn),所以就只能有個(gè)協(xié)調(diào)器。

現(xiàn)在就來啟動(dòng)開關(guān)設(shè)備的電源,同樣LED2會(huì)閃爍讓您選擇設(shè)備,但是在ZIGBEE中除了協(xié)調(diào)器和路由器就剩下終端設(shè)備了,所以開關(guān)就只能作為終端被啟動(dòng),但是也需要通過按鍵來控制,從程序中可以看出:
if ( keys & HAL_KEY_SW_1 )
    {
      if ( myAppState == APP_INIT )
      {
        // In the init state, keys are used to indicate the logical mode.
        // The Switch device is always an end-device
       logicalType = ZG_DEVICETYPE_ENDDEVICE;
        zb_WriteConfiguration(ZCD_NV_LOGICAL_TYPE, sizeof(uint8), &logicalType);
        // Do more configuration if necessary and then restart device with auto-start bit set
        zb_ReadConfiguration( ZCD_NV_STARTUP_OPTION, sizeof(uint8), &startOptions );
        startOptions = ZCD_STARTOPT_AUTO_START;
        zb_WriteConfiguration( ZCD_NV_STARTUP_OPTION, sizeof(uint8), &startOptions );
        zb_SystemReset();
      }
      else
      {
        // Initiate a binding with null destination
        zb_BindDevice(TRUE, TOGGLE_LIGHT_CMD_ID, NULL);
      }
    }
    if ( keys & HAL_KEY_SW_2 )
    {
      if ( myAppState == APP_INIT )
      {
        // In the init state, keys are used to indicate the logical mode.
        // The Switch device is always an end-device
        logicalType = ZG_DEVICETYPE_ENDDEVICE;
        zb_WriteConfiguration(ZCD_NV_LOGICAL_TYPE, sizeof(uint8), &logicalType);
        zb_ReadConfiguration( ZCD_NV_STARTUP_OPTION, sizeof(uint8), &startOptions );
        startOptions = ZCD_STARTOPT_AUTO_START;
        zb_WriteConfiguration( ZCD_NV_STARTUP_OPTION, sizeof(uint8), &startOptions );
        zb_SystemReset();
      }
      else
      {
        // Send the command to toggle light
        zb_SendDataRequest( 0xFFFE, TOGGLE_LIGHT_CMD_ID, 0,
                        (uint8 *)NULL, myAppSeqNumber, 0, 0 );
      }
    }

無論是按下S1還是S2(UP或者RIGHT),開關(guān)設(shè)備均作為終端設(shè)備啟動(dòng)。
啟動(dòng)之后呢,燈的狀態(tài)同樣會(huì)發(fā)生一些變化,最終結(jié)果是:LED2快速閃爍,表明此時(shí)開關(guān)已經(jīng)成功加入剛才燈設(shè)備建立的那個(gè)網(wǎng)絡(luò)了。

那么接下來就要看這個(gè)例子的核心部分----------綁定!

首先按下燈設(shè)備(這里為協(xié)調(diào)器,如果有路由器也可以)的UP,那么程序中調(diào)用了:
        zb_AllowBind( myAllowBindTimeout );

函數(shù),允許綁定,這個(gè)允許的時(shí)間據(jù)說只有10S,當(dāng)然這個(gè)時(shí)間是可以調(diào)整的,因?yàn)檫@里的參數(shù)為:static uint8 myAllowBindTimeout = 10;至于這個(gè)時(shí)間怎么計(jì)算的就需要到某個(gè)函數(shù)zb_AllowBind里去分析了。zb_AllowBind規(guī)定這個(gè)參數(shù)為1~64,如果為0,表示為假,就是不允許綁定的意思。如果大于64的話,就一直為真,就是一直都允許綁定。好像似乎是這個(gè)意思。至于這個(gè)10S是怎么制定的呢,在這個(gè)函數(shù)內(nèi)部調(diào)用了:
osal_start_timerEx(sapi_TaskID, ZB_ALLOW_BIND_TIMER, timeout*1000);
因?yàn)閛sal_start_timerEx定時(shí)函數(shù)最小單位為mS,所以*1000就表示S了。
而在SAPI_ProcessEvent事件處理函數(shù)中ZB_ALLOW_BIND_TIMER事件處理如下:
  if ( events & ZB_ALLOW_BIND_TIMER )
  {
    afSetMatch(sapi_epDesc.simpleDesc->EndPoint, FALSE);
    return (events ^ ZB_ALLOW_BIND_TIMER);
  }

也就是定時(shí)取消綁定狀態(tài)!??!

如果有人看著這些看不明白,那就把這個(gè)例子多看幾遍,多跑幾遍。一般如果您每天花費(fèi)4個(gè)小時(shí)看這個(gè)例子,那么只需要一周事件,我想到時(shí)比我還精通明白的!

所以在10S之內(nèi),開關(guān)必須發(fā)起綁定,此時(shí)同樣按下開關(guān)設(shè)備的UP,那么開關(guān)設(shè)備就調(diào)用了函數(shù):zb_BindDevice(TRUE, TOGGLE_LIGHT_CMD_ID, NULL);發(fā)送一個(gè)綁定請求去尋求綁定設(shè)備。

一個(gè)設(shè)備允許綁定,一個(gè)設(shè)備發(fā)起綁定請求,兩個(gè)是您情我愿的,所以就一拍即合,相當(dāng)?shù)牡菍?!?dāng)然沒有這么簡單的哈,就如同兩個(gè)人談戀愛,至少也需要是一男一女啊,兩個(gè)都是男或女那就太不正常了,ZIGBEE是個(gè)國際化的標(biāo)準(zhǔn),當(dāng)然不能有這種變態(tài)行為,所以也需要兩個(gè)命令的屬性是相反的,就例如這里的控制燈開關(guān)的命令,對于燈來說這個(gè)命令為輸入,而對于開關(guān)來說這個(gè)命令是輸出。所以一入一出剛好就登對。呵呵?。?/span>
綁定成功的表象是:開關(guān)設(shè)備的LED1快速閃爍。
void zb_AllowBindConfirm( uint16 source )
{
  // Flash LED
  HalLedSet( HAL_LED_1, HAL_LED_MODE_BLINK );
}
綁定成功了就可以發(fā)送燈控制命令了。按下RIGHT,調(diào)用了函數(shù):
zb_SendDataRequest( 0xFFFE, TOGGLE_LIGHT_CMD_ID, 0,
                        (uint8 *)NULL, myAppSeqNumber, 0, 0 );
可以看出發(fā)送了一個(gè)數(shù)據(jù)請求,顯然是廣播發(fā)送的,而命令為切換燈狀態(tài)的TOGGLE_LIGHT_CMD_ID。當(dāng)燈收到這命令,就有處理函數(shù)了:
void zb_ReceiveDataIndication( uint16 source, uint16 command, uint16 len, uint8 *pData  )
{
  if (command == TOGGLE_LIGHT_CMD_ID)
  {
    // Received application command to toggle the LED
    HalLedSet(HAL_LED_1, HAL_LED_MODE_TOGGLE);
  }
}
所以LED1顯示狀態(tài)發(fā)生改變。
此時(shí)這個(gè)例子已經(jīng)接近尾聲了,因?yàn)榻壎ǔ晒﹂_關(guān)能夠控制燈了,但是既然可以綁定那么也可以接觸綁定的,如果按下開關(guān)的DOWN,那么同樣調(diào)用了發(fā)送綁定請求函數(shù):
zb_BindDevice(FALSE, TOGGLE_LIGHT_CMD_ID, NULL);
只是這里第一個(gè)參數(shù)為FALSE,所以就能解除綁定。如果某個(gè)開關(guān)被解除了綁定,那么此時(shí)就不能控制燈了。
在這個(gè)例子最后做個(gè)小結(jié)------綁定的好處。
綁定了之后,發(fā)送數(shù)據(jù)或者命令,就不需要設(shè)備的地址,因?yàn)檫@個(gè)命令只能在建立綁定間的設(shè)備中傳輸。------------絕對是我的理解!

還有,一個(gè)開關(guān)可以綁定多個(gè)燈,同樣,一個(gè)燈可以同時(shí)與多個(gè)開關(guān)發(fā)生綁定。這個(gè)不代表本人觀點(diǎn),本人強(qiáng)力反對腳踏N只船!?。。。?!

現(xiàn)在來簡單分析下傳感器的例子,由于前面燈的例子說的比較多,這里我就說少點(diǎn)。

中心節(jié)點(diǎn)對應(yīng)SimpleCollectorEB ,傳感器節(jié)點(diǎn)對應(yīng)SimpleSensorEB。這里用到了EB,主要是因?yàn)镈B沒有串口硬件,而EB有,這個(gè)例子需要用到串口。
傳感器的例子效果是:協(xié)調(diào)器可以收集傳感器節(jié)點(diǎn)的溫度信息并通過串口傳輸?shù)絇C機(jī),如下圖所示:
 
可以看到能夠看到節(jié)點(diǎn)的溫度和電源電壓。
具體實(shí)現(xiàn)與燈的例子稍區(qū)別,但是本質(zhì)的原理是一樣的,先選擇設(shè)備類型,然后建立綁定,最后收集信息。這里建立綁定的區(qū)別在于,只要中心節(jié)點(diǎn)允許綁定(與前面操作一樣),然后傳感器節(jié)點(diǎn)是自動(dòng)發(fā)送綁定請求的:
  osal_start_timerEx( sapi_TaskID, MY_FIND_COLLECTOR_EVT, myBindRetryDelay );
定時(shí)去產(chǎn)生發(fā)MY_FIND_COLLECTOR_EVT事件:
if ( event & MY_FIND_COLLECTOR_EVT )
  {
    // Find and bind to a collector device
    zb_BindDevice( TRUE, SENSOR_REPORT_CMD_ID, (uint8 *)NULL );
  }
這個(gè)事件就是發(fā)送綁定請求的。
至于綁定后的現(xiàn)象與前面一樣了。
最后通過串口調(diào)試工具就能看到前面那個(gè)圖的效果了?。。。。。。。。。。。?!
這里的溫度為42,這個(gè)肯定不可能的,不然我就被蒸發(fā)掉了哈!因?yàn)椴捎玫氖切酒瑑?nèi)部集成的溫度傳感器,這個(gè)傳感器做實(shí)驗(yàn)還可以,因?yàn)榭梢钥匆姕囟鹊淖兓瞧錅?zhǔn)確性是在不敢恭維。TI也是的,做了溫度傳感器,還超級不準(zhǔn)確,還不如不做,只有還可以降低硬件成本,幾乎沒有任何使用價(jià)值!??!

 

 

 

 

 

 

 

 

 

 

 

 

 

 


東莞市德峰智能科技有限公司 版權(quán)所有 @ Copyright 2013 【百度統(tǒng)計(jì)】 【網(wǎng)站管理
地址:東莞市塘廈鎮(zhèn)環(huán)市西路258號信達(dá)商務(wù)大廈B502 訪問量: [網(wǎng)站地圖] [sitemap]
*本站相關(guān)網(wǎng)頁素材及相關(guān)資源均來源互聯(lián)網(wǎng),如有侵權(quán)請速告知,我們將會(huì)在24小時(shí)內(nèi)刪除 技術(shù)支持:東莞網(wǎng)站建設(shè)粵ICP備2022123063號
關(guān)鍵詞:藍(lán)牙耳機(jī)、防水電視 、教學(xué)會(huì)議一體機(jī)、氮化鎵電源、PD快充電源?
好吊色国产在线视频| 公交车被吃奶吃到高潮| 在线播放侵犯中出| 码国产在线播放性爱综合网| 26uuu国产成人图片| 国产精品亚洲精品日韩已满十八小| 亚洲va久久久噜噜噜久久一| 国产一区二区在线观看影院| 五月婷婷在线人妻偷情视频 | 丝瓜视频看污片更新国产| 亚洲欧美人成网站综合在线| 好看的av在线不卡| 国产永久一区二区三区| 伊人久久大香线蕉成人网| 综合一区二区三区av老鸭窝| 日韩欧美视频免费| 中文字幕无码视频专区| 久久久天天躁狠狠躁av| 综合欧美日韩中文字幕| 精品久久亚洲中国一级a| 日本一区二区三区视频免费观看| 精品人妻中文字幕浪潮AⅤ| 亚洲不卡久久久久久| 亚洲午夜精品一区二区麻豆色欲| 99精品国产乱码久久久| 无码精品国产一区二区免费| gay高潮痉挛哭叫失禁男小说| 亚洲午夜精品一区二区麻豆色欲| 午夜不卡视频在线播放| 色欲va一区二区三区香蕉| 中文字幕先锋av资源| 国产一三级片高清字幕| 成人免费网站视频ww| 午夜免费专区免费| 亚洲国产欧美国产第三区| 人阁色第四影院在线观看| 欧美午夜精品久久久| 国产成人久久精品二区三区s| 中文字幕无码最新视频| 四虎国产高清永久免费| 国产三级无码av在线影院色欲| 成人电影中文字幕小说在线| 免费在线观看小黄片视频| 韩国一级特黄大片在线观看| 日本在线区日| 亚洲 激情 中文| 级a一级a爰片免费久久| 在线播放第一页无码| 午夜视频国产二区一区| 超在线观看免费视频| 91情国产l精品国产亚洲区| 国产精品无码a∨片在线观看播 | 欧美久久亚洲中文| 日本乱码伦视频在线观看| 久久精品国产亚洲av电影| 伊人一区视频| 久久成人综合亚洲精品欧美小说| 一区二区三区欧美激情视频| 污污污欧美黄片在线免费观看| 亚洲美女视频黄网站| 久久电影第一页精品| 国产一级毛片久久av| 色多多高清在线观看视频www| 自在巨亚洲乳线拍av| 人人妻人人澡人人爽久久av| 欧美超清视频在线观看| 熟妇色xxxx欧美老妇多毛| 被反复爆炒的恶毒反派| 中文字幕成人毛片| 久久午夜福利视频| 欧美精品aaa久久久影院| 高清视频亚洲美臀写真小电影在线观看 | 91av视频在线免费观看| 中国片婬乱一级吃奶毛片| 午夜在线播放网站| 性欧美13处14处破在线观看| 国产亚洲AV综合| 国产网红视频种子链接| 少妇让男人桶视频| 十大禁用软件app大全免费下载大全安装七客分享 | 黄色一级片免费网站| 精品国产电影99| 久久国产一区二区不卡| 日韩at免费无码毛片视频| 亚洲综合日韩无码久久| 无码一级毛片一区二区视频r区| 含着她的花蒂啃咬高潮| 综合高清日本中文| av天堂中av世界中文在线播放| 中文字幕一区二区在线观看一区二区在线观 | 成人a一级三级片免费看| 新91精品中综合久久久久| 日本在线一区二区三区直播| 亚洲一级黄色大片| 久久久aⅤ极品无码动态图| 欧美婷婷综合网| 欧美一级特黄淫片在线观看| 蜜桃传媒果冻星空传媒视频| 国产卡1卡2卡三乱码在线| 成人无码无删减电影| 亚洲AⅤ无码一区二区不卡| 久青草国产手机在线视频| 成人在线日韩欧美| 日本成人影院在线视频观看| 国产日韩不卡综合AⅤ电影| 热99re久久精品国产99热| 又硬又粗又大又黄太爽了在线观看| 九九精品网址| 91精品在线视频观看| a√天堂在线资源库| 免费一级毛片私人影院a行| 9191成人精品久久| 日韩亚洲精品国产第二页| 亚洲欧洲中日韩在线观看| 一区二区粉嫩高清AV| 抽插视频啊啊啊啊啊啊好疼死| 国产熟女自拍挑逗| 国产农村乱人伦精品视频色欲麻豆国产福利精品 | 女优av一区二区三区| 毛片国产一区二区三区| 伊人七七久久桃花精品影院| 一日本道不卡高清在线观看| 十八禁网站在线观看免费视频| 每日在线更新久草| 动漫久久国产视频网站| 欧美人与禽交片欧美| 岛国黄色毛片在线免费观看| 国产一区二区三区妓女| 国产人成中文字幕| 秋霞影院电视剧在线观看全集免费| 欧洲美洲国产综合首页| 久久人妻中文字幕乱码午夜久久| 国产大片7777www免费| 国产成人精品视频A片免费观看| 亚洲青青草原| 国产非洲一区二区三区久久久久久 | Av动漫H肉在线观看| 一区日本亚洲视频国产精品| 精品亚洲免费播放| 亚洲天堂中文网| 在线播放亚洲国产| 中文字幕在线观看第页| 羞羞视频免费观| 岛国av天堂女人| 国产欧美日韩精品在线一区| 人妻系列中文字幕无码专区| 一区二区三区欧美激情视频| 污视频解禁在线xxxx| 在线无码不卡 高清影院| 国产普通话对白刺激| 日产国产欧洲一道不卡| 4399国语免费播放| A级毛片毛片免费观着久| 波多野结衣影音先锋在线播放| 久久青青草原精品国产蜜臀| 不卡在线观看一区二区三区 | 亚洲日本中文字幕视频| 狼友视频国产精品首页| 人人爽人人看| 欧美在线观看中文少妇| 蜜桃视频网站在线观看| 缘分五月手机在线视频观看| 国产亚洲日韩AV在线播放不卡| 中文人妻精品一区二区| 亚州黄色一级电影| 白嫩极品女粉嫩喷水视频软件| 国产亚洲精品网| 九九热精品视频免费| 国产免费久久精品99resw| 中文字幕黄色三级片| 一级做a爰片久久毛片人呢| 全国亚洲黄区在线观看| 日本韩国免费观看高清电视剧| 國產在視頻線在精品視頻2020 | 日韩无码免费网址| 国产粉嫩一区二区三区| 亚洲一日韩中文字幕视频| 亚洲无码在一一线| 五月丁欧美国产高清视频| 在线黄色毛片观看| 91精品在线视频观看| 国产麻豆剧传媒精品国产?V精品| 精品一区二区三区高清免费观看| 亚洲美女作爱视频日韩不卡| 了解最新久久一区二区精品| 白嫩极品女粉嫩喷水视频软件| 精品国产电影在线看免| 综合亚洲伊人午夜激情网 | 免费大片免费观看| 国产成人无码??精品一区| 色多多福利网站| av在线播放我不卡| 无码播放毛片免费| 網友分享欧美在线亚洲心得| 岛国av天堂女人| 久操五月天综合网| 女兵人3未删减版在线观看| 一区二区三区欧美激情视频| 99精品国产乱码久久久| 蜜桃av成人午夜视频| 亚洲伊人成综合人影院青青青| 亚洲无人区编码国产激情| 中文字幕无线码一区日产六区| 深夜视频污APP下载| 欧美高清一本大道道香蕉a| 亚洲国产成人片在线观看直播| 国产视频久久三级久久15| 又大又粗又爽A级频片| 高清无码小视频婷婷丁香五月伊人| 国模大尺度炮交视频免费看| 日韩午夜福利尤物在线观看| 国产精品桃色国产自愉自愉免费第一区 | 久久精彩久久看香蕉| 国产a级综合区毛片久久久久久 | 韩国资源国产精品| 99re这里只有是精品| 69SEX久久精品国产麻豆| 日韩精品第51页| 日韩A一区无码视频| 色欲久久久天天天综合网久久国产精品无码网站 | 亚洲av日韩av欧v在线天堂| 2017欧美伦理片一页| 天天看片在线观看免费高清能免费看片 | 忘忧草香漫七区亚洲www潮!| 亚洲国产揄拍厕所视频| 久久午夜无码鲁丝片精品久久久AV麻豆一区乱码 | 精品韩国免费视频一区二区| 久久久久久影院观看 | 日韩亚洲精品国产第二页| 久久精彩久久看香蕉| 老外一级片久久久久久}| 成人免费无码婬片在线| 国产91麻豆精品成人区| 禁18免费网站在线观看| 97影院国产精品| 欧美巨胸喷奶水视频WWW| 成人不卡视频在线观看| 亚洲 欧美 唯美 国产 伦 综合| 日韩at免费无码毛片视频| 中文字幕一区二区三区不卡| 天天干天天操AV| 精品久久亚洲中国一级a| 国产农村妇女特级毛片| 久久久精品国产亚洲A∨无码看三级成人蜜 | 白洁被五个人玩一夜| 亚洲Aⅴ无码成人网站久久| 五月天国产无码在线| 欧美国产猛干| 日韩高清小免费在线观看| 亚洲欧洲日产国产最新| 2022免费在线视频| 日韩欧美在线一区二区三区| 成h在线观看免费观看| 久久亚洲AV无码精品狼群| 粗暴肉开荤高H文农民工电影| 不卡在线观看一区二区三区| 久操五月天综合网| 久久久久久影院观看| 伦理电影飘花网2| 一级毛片一级真人| 一级毛片无码免费不卡直接看| 国产三级片一区二区三区不卡免费观看 | 麻豆国产天美传媒AV性色 | 成人久久毛片免费| 嫩草影视入口永久一二三区| 亚洲精品久久久鸭子| 91美女在线观看| 青春荷尔蒙在线观看免费| 国产亚洲一级精品电影| 精品亚洲人妻一区二区| 无码一二三四精品无码视频 | 久久做夜夜爱天天人人揉| 特黄特色三级在线看视| 日韩欧美视频免费| 一级黄色Av网址| 欧美三级中文字幕乱码| 国产精品不卡av在线观看| 西西444www大胆视频| 九九久久一区二区福利AV片| 日韩电影一区| 好看的av在线不卡| 欧美一区二区三区性爱视频| 国产亚洲精品影视在线| 為您日本不卡中文字幕精品| 麻豆AV免费观看网站| 亚洲日产综合欧美在线| 国产AV秘 无码一区区三区| 欧美成人A片免费全部规观看| 妖精视频成年人在线观看| 精品亚洲免费播放| 国产性爱在线观看亚洲第一黄片| 日本xxxx高清视频| 无码国产成人午夜视频在线播放| 国产三级无码av在线影院色欲| 4480中文字幕乱码私人影院| 欧美熟女视频一区| 五月天国产无码在线| 為您日本不卡中文字幕精品| 在线超碰观看互动交流| 国内自拍理论片在线播放| 美国人妻久久久一区二区无码| 抽插视频啊啊啊啊啊啊好疼死| 欧美一区二区三区性爱视频 | 国语自产精品视频一区二区| 亚洲精品无码?V天堂久久| 欧美h视频在线免费观看| 国内自拍理论片在线播放| 日韩精品中文字幕新版| 免费a级毛片大全| 五月天久久久噜噜噜久久| 亚洲一级黄色片毛片| 黄色网站免费无遮挡毛片a| 播放的黄色大片在线看一区二区| 国产精品sm捆绑调教视频| 麻豆精品久久精品色综合| 先锋影音资源精品| 日韩精品重口另类一区| 国产一区二区三区在线伊人| 久久99热狠狠色精品一区二区三区| 欧美巨胸喷奶水视频WWW| 黄色毛片精品一级| 成品网站源码入口隐藏通道| 极品人妻手机视频在线| 欧美日韩在线四区| 久久综合五月天婷婷丁香| 欧美人成老熟女强奸视频网站 | 欧美精品午夜一区二区三区| 免费亚洲中文欧美| 99久久伊人精品综合| 久久人妻少妇偷人精品综合| 超碰亚洲精品在线无码| 奶头好大让老子摸摸的动态图| 国产人妻777人伦精品hd| 日本伦精品一区二区三区免费| a√天堂在线资源库| 亚洲裸男自慰gy网站| 蜜臀av欧美精品日韩偷拍综合| 国产亚洲精品一本第四区| 91av在线视频观看| 高潮添下面视频免费看| 人人爽人人爽人人片A∨| 亚洲一级成人黄片| 成人一区一区三区四区| 精品无码性爱视频网站| 亚洲人体视频| 迪丽热巴国产精品无套内射| 曰本人一级毛片免费完整视频在线a| 在线播放亚洲国产| 一级毛片国产的对白叫床| 日韩欧美a片在线观看| 久久午夜无码鲁丝片精品久久久AV麻豆一区乱码 | 制服丝袜在线蜜臀| 欧美精品a三v视频一级片在线观看 | 777AⅤ无码乱码精品| 三级影片在线观看免费的| (愛妃視頻)亚洲 欧美 综合 另类 中字| 中文精品无码高潮在线| 一区二区三区在线中文视频| 精品亚洲91在线无码播放| 国产一区美女视频| 5?毛片高清无码在线观看| 亚洲图片另类图片激情动图| 97人妻无码一区二区精品免费 | 中文人妻精品一区二区| 亚洲AV无码二区三区在线| 琪琪网午夜理论手机在线播放 | 丰满少妇被猛烈进入无码久久| 色综合久久蜜芽国产精品 | 亚洲Aⅴ无码成人网站久久| 欧美精品日韩一区二区| 久热香蕉在线视频免费大| 日本深夜福利在线观看不卡高清| 视频在线观看免费网址你懂的| 极品熟妇大蝴蝶20P| 欧美专区亚洲专区日韩专区| 巨爆乳无码视频在线观看| 狠狠躁18三区二区一区99| 日韩at免费无码毛片视频| 狠狠躁18三区二区一区99| 国产午夜视频在线播放观看| 香蕉视频成人在线观看| 久久精品中文字幕第一页蜜臀| 2023国产一区二区三区| 成人性视频在线三级| 精品久久人妻av| 韩国三级大全久久网站中文字幕| 久久午夜无码鲁丝片精品久久久AV麻豆一区乱码| 久久久精品亚洲中文字幕| 亚洲蜜桃无码一区二区三区久久午夜无码鲁丝片午夜精品 | 99热精品日韩经典| 岛国av动作片中文字幕不卡| 免费三级网站av| 日韩成人精品二级图区| 日本一区二区三区视频免费观看| 日韩中文字幕亚洲| 噜噜噜综合亚洲| 精品人妻久久久久无码av| 久久综合五月天婷婷丁香| 香蕉视频免费| 麻豆精品久久精品色综合| wwjizz国产旧版本| 一区二区三区欧美日韩国产 | 日韩精品一区二区三区中文麻豆| 日产国产欧洲一道不卡| 亚洲产在线精品亚洲第一站首页| 亚洲天堂在线观看不卡视频| 美国黄色毛片| 国产第一免费视频| 97在线观看视频资源| 国产男女猛烈无遮掩免费观看呢 | a级国产乱理片在线观看| 日本免费人成视频播放120秒 | 香蕉视频ios下载| 亚洲AV无码精品一二三区在线| 一级欧美精品黄片| 欧美性开放大片在线观看| 一区二区三区四区欧美日本| 青春荷尔蒙在线观看免费| 亚洲女同毛片一区二区三区| 性知音久久最新地址发布页| 久久99欧美激情| 欧美主播一区二区三区美女| 日韩欧美91热久久噜噜| 歐美精品免費一區歐美久久優播| 忘忧草香漫七区亚洲www潮!| 国产精品久久一区二| 天天视频黄色在线观看完整| 草莓视频app深夜福利| 不卡?V中文字幕在线观看| 精品婷婷久久久久| 国产亚洲精品网| 国产熟女精品视频大全| 日韩少妇一级 片内射视频| 在线免费观看淫片| 无码久久精品国产亚洲A影片| 国产又粗又长又猛又爽在线看| 绯色av麻豆一区二区三区| 夜夜躁狠狠躁2021a| 91午夜一区二区| 一级性a级黄片| 精品国产乱码一区二区三区aa| 18+动漫www+日韩毛片| 91精品国产乱码久久久久久| 美女牲交视频| av在线观看+网站免费| 国产精品久久青青7777| 欧美精品人爱C欧美精品四虎| 伊人久久大香线蕉免费视频| 久久久无码精品亚日韩精东传媒 | 一级仑乱免费视频| 欧美东京热不卡视频分三区| 国产精品另类一区| 国产做a爱免费视频互動交流| 亚欧一区在线播放| 亚洲av永久精品放毛片小说| 色综合久久蜜芽国产精品 | 亚洲区日韩精品mv| 欧美日韩另类精品一区二区| 在线看亚洲福利中文字幕| 亚洲欧美日韩中文综合视频| 亚洲女优免费一区在线观看| 日欧美亚洲女人一级黄片| 国产男女猛烈无遮掩免费观看呢 | 久久这里只有视频精品| 99草草国产熟女视频在线| 国产片婬乱一毛片a最熱門最齊全電影!| 国产在线观看麻豆| 久久久美日韩黄色片| 噼里啪啦在线看免费观看视频| 少妇高潮喷水无码久久影院| 一本大道色卡1卡2卡3| 99午夜福利视频| 阿娇视频国产精品久久| 亚洲国产首页在线播放| 啊v免费在线观看| 免费黄片看亚州乱伦| 久久伊人亚洲伊人色欲综合| 新91精品中综合久久久久| 国产AV无码专区久久精品品尚网| 一区二区久久精品35国产精品| 色婷婷婷丁香综合不卡亚洲| 午夜在線播放視頻在線觀看視頻 | 亚洲第一页中文字幕| 亚州一区二区三区a级片免费观看| 天堂av无码一区二区三在线播放 | 久久夜色精品国产高清不卡| 妖精视频永久网站网址| 在线观看69视频| 少妇欲求不满| 高压监狱满天星美版免费观看 | 午夜歐美福利視頻| 亚洲欧美国产另类91综合| 含着她的花蒂啃咬高潮| 亚洲.国产.欧美一区二区三区久久| 97影院国产精品| 欧美中文字幕欧美在线播放 | 丝袜美女被出水视频一区| 亚洲中文无码专区在线| 日韩三级在线观看中文| 精品人妻中文字幕浪潮AⅤ| 亚洲欧洲视频网址在线观看| 麻豆传媒司徒丹妮代表作| 欧美Ⅴ?日韩Ⅴ?人妻Ⅴ?| 欧美日韩另类国产精品| 中文字幕 欧美激情| 欧美专区亚洲专区日韩专区| 亚洲特级毛片AAAAA| 精品欧美久久少妇| 女人扒开腿让男人桶到爽免费视频| 欧美性爱黄色网址| 综合亚洲伊人午夜激情网| 特黄特色三级在线看视| 精品卡一卡二卡3卡高清乱码| 成人国产精品视频网站| 在线播放国产不卡无毒视频| 91男女性爱在线观看视频| 国产精品丝袜av| 无码人妻AⅤ一区二区三巨| 亚韩精品中文字幕无码| 草莓视频app深夜福利| 一区二区久久精品35国产精品| 中文自拍三级国产| 国产日韩91一区二区三区欧美| 亚洲一区在线播放视频| 欧美性视频XXX18禁| 曰本毛片va看到爽不卡| 亚洲精品无码?V天堂久久| ss99亚洲成人精品在线| 亚洲乱码A∨一区二区三区| 国产网站日韩一区| 国产专区日韩精品欧美色| 含羞草实验研所传媒网站进入| 超碰在线免费渣男av| 黄网站色年片在线观看| 欧美在线电影| 成人免费毛片熟女| 自在巨亚洲乳线拍av| 熟妇色xxxx欧美老妇多毛| 蜜臀91丨九色丨丝祙黑料| 一级又爽又黄的免费毛片| 国产2018精品在线| 亚洲qingse中文字幕| 日韩国产欧美久久一区| 国产最爽的乱婬视频国语对白A级| 午夜精品一区久久| 澳洲美妇人妻真人无码永久| 亚洲欧美高清在线一区二区三区| 国产看在线观看免费视频| 好看的av在线不卡| 日韩国产高清在线| 在线香蕉国产视频| 精品久久久无码中文字幕廣大網友最新影片 | 国模国产精品嫩模大尺度视频| 福利中文字幕最新永久日本欧美| 国产精品亚洲精品影院| 日本人xxxxx視頻在線| 青柠在线观看免费高清电视剧| 精品国产情侣高潮对白| 最近的中文字幕免费完整| 欧美日韩精品一二区| 成人国产亚洲日本在线| 一级特黄录像在线观看| 日产国产精品久久久久久| 亚洲天堂中文网| 天天操天天干天天搞天天日| 欧美午夜精品久久久久久久久| 日韩国产色色色色| 说服娇妻尝试其他男人粗大| 久久久四虎成人永久免费网站| 一级毛片一级黄片| 欧美巨胸喷奶水视频WWW| 精品无码视屏一区二区在线观看| 超碰亚洲精品在线无码| 日韩精品图区专区在线观看| 国产精品国产?v无码麻豆| 五月天国产无码在线| 又大又长又粗又爽色网视频| 女人色国产a精品| 国产网红视频种子链接| 日韩欧美在线一区二区三区| 少妇搡BBBB搡BBB搡造水多| 欧美激情狂野高潮抽搐在线 | 蜜桃av成人午夜视频| 5566av资源网影音先锋| 欧美激情在线观看手机视频| 国产精品一久久久久| 18+动漫www+日韩毛片| 国产我不卡午夜伦理| 欧美一级婬片AAAAAAA| 2019年国产精品自拍不卡| 免费观看在线一级毛片| 男女猛插小穴视频在线观看| 日韩一级大黄片| 无人区乱码区1卡2卡三卡网站| 美女扒开双腿露出尿口无内裤图片| 亚洲综合精品高清无码| 亚州av高清无码在线| 在线播放国产欧美日韩| 国产亚洲一区欧美| 中文自拍三级国产| 亚洲日韩欧美美女综合热精品| 男人天堂欧美亚洲| 97影院国产精品| 在线观看AV黄网站永久簧| 国产女主播三级在线观看| 日韩一级大黄片| 一区二区国产无码| 1024手机看片免费观看| 歐美精品免費一區歐美久久優播| 精品午夜?成人v无码| 久久这里只有视频精品| 欧美ay亚洲ay日韩ay| 一级婬片试看15分钟| 欧美三級片黃色三級9片黃色| 国产69成人免费视频观看| 欧美性色A级欧美| 黄视频网站大全| 亚洲成人电影免费在线观看| 每日更新不卡av首页| 免费a级日韩毛片| 一本大道色卡1卡2卡3| 国产精品久久青青7777| 亚洲国产高清无码自拍| 欧美一级特黄淫片在线观看| 国内精品人妻无码短视频| 熟女高潮爽嗷嗷嗷嗷嗷大叫| 国产亚洲一级精品电影| 日韩欧美亚洲在精品| gogo国模私拍大尺度| 国产成人精品久久二区三区色俗| 男女啪啪久久精品亚洲a| 欧美日韩一区二区短视频| 一级黄黄色片| 欧美成人三级国产在线| 好紧好爽水真多18p真人| 在线看片在线播放| 91精品国产乱码久久久久久| 草莓视频app深夜福利 | 一级性a级黄片| 荒野2翡翠牧场女儿| 东京熟视频在线观看视频| 亂倫人妻無碼中文字幕电影| 国产成人精品久久二区三区色俗 | 亚洲精品国产情侣?V在线| 国产午夜激无码毛片不卡十第1集| 亚洲国产欧美乱码| 伊人丁香狠狠色综合久久| 亚洲午夜精品在线看| 婷婷丁香五月面费| 草莓视频app污色版| 久久国产激情| 亚洲国产v二区在线观看| 成人啪精品视频免费国产| 操逼软件免费| 四虎影院一级片| 久久国产精品一区二区三| 久草免费在线视频| 含羞草国产精品视频免费看 | 精品欧美大臿香蕉在线视频| 久久精品国产99国产精2020丨| 日日摸日日碰夜夜爽免费中文字幕| 国产抖阴小视频全集在线观看| 一级国产交换配乱淫| 国内自拍理论片在线播放| 国产男女做爰猛烈叫床小说| AV高清毛片免费| 国产av亚洲aⅴ一区二区| 日韩视频一区欧美在线 | 交换的一天中汉字晋通话| 十六一下岁女子毛片免费| 女人叉开腿让男人捅| 欧美日韩在线另类| H视频在线观看免费的| 刺激的欧美三级| 国产一区二区精品成人av| 国产免费a∨国片精品| 精品国产亚洲av未满十八| 久久综合日韩人妻| 亚洲 欧美 日韩 综合aⅴ图片| 麻花天美影视免费观看电视| 免费黄网在线| 激情的少妇大片免费视频还看 | 4399日本韩国电影高清完整版免费| 91大神人妻论坛性趣| 一级毛片一级毛片一级毛片看一下| 中文字幕永久精品国产| 日本不卡一二三区在线观看 | 琪琪色在线观看| 亞洲精品中文字幕久久久久久 | 国产另类丝袜欧美在线| 久久99精品久久只有精| 亚洲欧美日韩黄视频| 国产与丰满岳交尾乱免费视频| 亚洲国产高清自拍| 黄色免费av电影| 女的被到色情免费看| 久久久久久国产综合精品| 日本道精品一区二区三区| 激情的少妇大片免费视频还看| 久久成人午夜影片| 免费在线观看黄网站| 久久99久久99小草精品免视看| 丝袜长腿aⅴ在线播放| 日韩另类国产丝袜福利| 深夜视频99二区| 最新小视频国产福利| 一级特一级特色生活片| 国产非洲一区二区三区久久久久久| 在线看黄网址| A级成人精品91欧美一区二区| 果冻视频传媒在线播放| 大黑吊无码在线观看| 亚洲欧美丝袜清纯另类| 香蕉视频成人在线观看| 国产综合成人亚洲区网站| 人妻少妇久久毛片| 988好吊妞的视频这里只有精| 人人爽人人爽人人片A∨| 国产精品天干天干在线澳门| 久久精品国产99国产精2020丨| 女的被到色情免费看 | 日韩无码视频一区二三区| 欧美日韩一二三级在线播放| 日韩欧美91热久久噜噜| 欧美一级在线免费| 久久精品国产综合一区亚洲欧美| 尤物yw193国产精品| 天天噜日日噜| 亚洲精品大片免费看| 欧美精品高清视频| 日韩高清小免费在线观看| 国产卡1卡2卡三乱码在线| 国产乱人在线视频| 精品国产又粗又大又黄又硬| 久久亚洲AV无码精品狼群| 久久影视亚洲一区| 精品一区二区三区高清免费观看 | 成人免费网站视频ww| 91高清免费视频| 美女被内全过程视頻| 蜜臀免费在线观看网址| 国产午夜精品丝袜熟女| 一边脱一边摸一边插免费视频| 九九久久国产高清视频| 精品日韩欧美久久久久久| k频道国产网红精品视频| 高清无码在线不卡| 亚洲国产成人女人| 国内精品大屁股白浆一区二区| 国产精品免费观看在线网站| 免费手机看片1024在线观看| 久久婷婷激情一级免费视频| 中文字幕在线中…av| 91大神在线精品播放| 日日摸夜夜添夜夜无码国产| 在线看亚洲福利中文字幕| 在线播放国产不卡无毒视频| av在线播放我不卡| 果冻视频传媒在线播放| 最美情侣视频免费观看完整版高清| 综合久青草视频| 色欲av一区二区| 亚洲一区二区三区91| 91精品秘入口白丝| 国产9一级a爱看片免费观看| ?级毛片免费观看在线播放| 免费黄色国产网站| 精品国产高清毛片a| 在线观看亚洲中文字幕| 日本成人久久精品| 国产TS三人妖大战直男| 日韩在线成人精品视频| 国产电影一区二区在线观看| 国产乱弄免费视频在线播放| 亚洲欧美国产精品综合| 亚洲 欧美 日韩 综合aⅴ图片 | 精品中文乱伦国产| 亚洲中文无码专区在线| 91精品人妻一区二区三区综合| www.一区二区三区| 2021年最新最全的国产新品| 日韩a级无码免费| 国产特黄激情AAAAAA视频| 韩国电影爱人未删除完整高清版| 亚洲欧美日韩黄视频| 国产福利一区二区精品免费| 夜夜高潮夜夜爽精彩免费视频| 亚洲国产区男人本色vr| 成年人爱视频亚洲| 热情的邻居做爰BD| 黄片超刺激在线看在线| 高清无码小视频婷婷丁香五月伊人 | 亚洲欧美日韩精品变态另类重囗| 欧美Ⅴ?日韩Ⅴ?人妻Ⅴ?| 网国产图片视频在线观看| 久久综合日韩人妻| 免费欧美成人一级片在线观看 | 亚洲AV永久无码精品的| 午夜精品自在自拍| 无码动漫av永久免费专区| 级a一级a爰片免费久久| 久操五月天综合网| 国产小视频在线播放一区| 91免费精品国自产拍在线电影| 无码人妻精品www久久久| 国内精品wwwwwww视频高清免费| 三级久久无码综合| 高清一区二区三区日本久高大丰满肥熟妇丰满大白屁股 | 精品多毛少妇人妻av免费久久| 久久精品免费视频影院观看| 99偷拍亚洲精品| 国产成人aⅤ男人的天堂| 欧美天堂在线| 美女福利在线观看| 一区二区三区女人作爱| 任我鲁精品视频精品| 99午夜福利视频| 欧美三级中文字幕乱码| 福利国产免费观看0855影视| 在线观看亚洲精品福| 国产女人十八毛片水真多| 久久成人午夜影片| 青柠视频在线播放| 在线观看成人日韩一区| 在线午夜福利网| 亚洲国产中文精品高清在线电影 | 国产色欲AV无码专区亚洲AV| 国产精品三区第二页| 97国产精品一区二区视频| 最新国产精品视频综合区| 日韩特一大黄a毛片| 九九久久国产高清视频| 国产美女一级做受视频| 国内精品少妇毛片| 亚洲日韩国产新品| 国产久热情品无码激情| 新91精品中综合久久久久 | 亚洲天堂制服诱惑| 黄片免费在线观看毛片| 国产色婷婷久久久| 很黄很黄的视频网站| 日本系列有码字幕中文字幕| 久久99热狠狠色精品一区二区三区| 高清视频亚洲美臀写真小电影在线观看| 在线看亚洲福利中文字幕| 亚洲综合精品看片| 99ri精品视频视频在线观看| 欧美亚洲国产成| 一级仑乱免费视频| 曰本毛片va看到爽不卡| 国产性爱在线观看亚洲第一黄片| 国偷自产91中文字幕婷婷在线不卡一区二区三区高清 | 日韩午夜福利尤物在线观看| 亚洲精品国偷拍自产电影| 特级西西人体444WWW高清大| 欧美视频一二区在线观看| 亚洲国产精品va在线观看无| 免费的小蝌蚪网站看v片在线| 野花日本大全免费观看中文7| 久久亚洲欧洲日本韩国欧美| 欧美亚洲国产成| 国产精品sm捆绑调教视频| 日日摸夜夜添夜夜无码国产| 福利国产免费观看0855影视| av天堂中av世界中文在线播放| 粗暴肉开荤高H文农民工电影| 国产精品久久久蜜臀AV| 青青草原无码在线| 131美女爽爽爽爱做视频| 丰满少妇一区二区| 亚洲国产欧美国产第三区| 乱码国产丰满人妻www69| 蜜桃成人午夜精品| 国产又粗又大又爽视频| 一级黄黄色片| 日本在线区日| 极品少妇高潮在线观看| 使劲别停好大好深好爽| 看人妻仑乱a级毛片| 日本av在线观看中文字幕| 亚洲国产精品一区视频| 亚洲国产精品成人在线观看| 高潮添下面视频免费看| 男女啪啪久久精品亚洲a| 人与动人物a级毛片在线| 女s调教羞辱女m视频VK| 草溜免费电影伊人电影伊人影院| 一成年人视频免费网站2| 超在线观看免费视频| 强奸搞鸡app视频免费看网黄羞羞 日本一区二区二区免费国产 | 亚洲欧美成人在线| 亚洲人成在线影院播放| 69SEX久久精品国产麻豆| 中国一级无码av毛片| 女同一区二区| 久久精品國產亞洲AV成人| 日韩视频一区欧美在线| 国产免观看在线视频| 国产在线第一区第二区| 日韩美女蜜桃AV在线播放| 香港aV特一级毛片| 妖精视频永久网站网址| 国产与丰满岳交尾乱免费视频| wwjizz国产旧版本| 动漫人物桶动漫人物免费动画软件| 草莓成视频人app污片| 91精品在线视频观看| 自拍日韩看高清中文字幕 | 久久国产精品一区二区三| 亚洲五月天色色色视频| 夜夜躁狠狠躁日日躁孕妇| 女教师波多野结衣高清在线| 国产av亚洲aⅴ一区二区| 国产美女一级a作爱播放免费| 久久 国产 综合| 国产一级免费网站| 70岁熟女熟妇伦Av| 国产人妻无码一区二区三区免费| 国产福利区一区二区三区四| 日本xxxx高清视频| 99久久伊人精品综合| 亚洲麻豆精品一区二区综合Av| 疯狂做受XXXX高潮不断| 乱女乱爱高清视频大全| 1024手机看片免费观看| 在线欧美亚洲一区| 中文字幕先锋av资源| 自拍日韩看高清中文字幕 | 99精品日韩欧美在线观看| 欧美超清视频在线观看| 中文字幕乱码天天综合| 直人实女处被破www免费| 精品国产AV无码专区亚洲精品| 好紧好爽水真多18p真人| 午夜在線播放視頻在線觀看視頻 | 一级黄色欧美在线免费观看| 9999精品国产高清一区二区| 天堂在线观看免费视频| 琪色色欧美番号大全| 伊人久久大香线蕉va五月天| BL年下猛烈顶弄H| 日韩?v网址在线免费观看 | 一区国产二区久久| 大地资源免费中文第二页| 超碰熟女久久熟女| 麻豆久久成人av电影天堂| 色婬91麻豆剧蜜桃传媒| 超碰熟女久久熟女| 大萫蕉伊久久综合| 欧美日韩一二三级在线播放| 囯产精品无码一区二区三区AV| 久久久一本精品久久久久久毛片 | 蜜臀av岛国片在线观看| 午夜福利视频1000| www国产福利一区二区| 亚洲一级片在线视频| 一边脱一边摸一边插免费视频| 日本ab视频在线观看AAv| vvvv99日韩精品亚洲| 出租房里的交互高康张| 久久99精品久久只有精| 亚洲国产第一区二区| 久久超碰caoporen97人人| 99视频在线精品这里观看| 女同久久精品国产99国产精品网站| 女人18一级特级三级片免费看| 污草莓视频免费下载| 久久综合精品国产| 久久久网中文字幕| 精品欧美久久少妇| 国产成人亚洲综合91精品浪| 欧美AN成片在线| 亚洲av一级黄片在线免费观看| 欧美一级免費网站| 亚洲一区二区三区簧片| 岛国av动作片中文字幕不卡| 免费综合久久亚洲| 痉挛高潮喷水视频在线观看| 视频毛片免费二区| 日韩美女一级免费毛片| 久久伊人精品热在75| 久久亚洲AV无码专区成人 | 尤物在线视频免费国产| 亚洲国产精品看片在线观看电影| 动漫美女吸乳舌吻羞羞视频| 欧美日韩人妻精品一区二区| 欧美成人精品在线观看| 国产熟女自拍挑逗| 先锋影音资源精品| 国产黄色免费一级| 久久国产精品亚洲AⅤ三区色最新| 成人中文不卡黑人在线| 无码专区亚洲精| 亚洲日韩欧美一区久久久我| 日本一卡 亚洲精品| 在线免费观看理论片| 正在播放的国产A一片| 欧美午夜免费一级看片| 一级在线观看黄色片| 中文字幕亚洲国产剧情| 草莓视频免费网站看| av最新在线免费播放| 欧美一级在线免费| 一级少妇a在线播放| 国产欧美日韩大片| 超碰在线免费渣男av| 性生交大片免费观看a片动态图| 亚洲国产成人女人| 久久综合五月天婷婷丁香| 欧美激情狂野高潮抽搐在线| 午夜福利片国产精品无码中文字在线| 久草资源在线色网视频| 国产乱子伦视频观看| 91偷拍亚洲精品| 久久综合狠狠综合久久综合92| 乱码国产丰满人妻www69| 欧美日韩亚洲第四页| 欧美涩涩久久丁香| 亚洲一级黄色片毛片| 一级片精品视频在线| 日韩欧无码一二三区免费不卡| 欧美一线免费http| 日韩at免费无码毛片视频| 9999精品国产高清一区二区 | wwjizz国产旧版本| 99久久露脸精品视频| 日韩另类国产丝袜福利| 国产无码高清视频| 诱惑美女一区二区| 精品熟女少妇av久久免费| 国产小视频在线播放一区| 国产精品久久久久久免费观看| 变态另类在线观看| 久久免费一级特黄录像| 欧美熟女视频一区| 日本在线一区中文在线69| 91av在线免费视频| 丁度R级露器官电影| 午夜福利美女一区| 日韩精品视频在线免费观看| 被反复爆炒的恶毒反派| 东京热免费一级毛片视频 | 好色先生TV在线下载| 国产一卡二卡三卡四卡无卡乱码视频| 码国产在线播放性爱综合网| 亚洲AV永久无码精品的| 日韩美女观看成人片在线| 亚洲熟妇无码99精品| 暖暖免费中文高清日本三区| 国产亚洲女在线线精品| 青草亚洲国产欧美一区二区| 日韩av中文无码影院AV大片免费看| 亚洲欧美日韩一区中文天国 | 加勒比视频亚洲无码| 影音先锋无码AV片| 天天躁狠狠躁狠狠躁夜夜躁68| 国产免费va在线观看视频| 十八禁网站在线观看免费视频| 久久精品国产久精最新章节| 亚洲国产日韩精品女日日骚 | 在线播放第一页无码| 一区二区三区国产高清在线播放 | 亚洲精品日本精品国产精品| 国产精品免费线观看你懂的| 久久人人爽人人爽人人片AV麻烦| 亚洲色图国产91| 不卡在线观看一区二区三区| 亚洲AV秘无码一区二在线观看| 大萫蕉伊久久综合| 麻豆果冻传媒精品国产av| 无套內谢丰满少妇中文字幕| 成人黄色免费网站大香蕉| 亚洲不卡久久久久久| 免费又黄又爽做受视频在线观看 | 欧美性色A级欧美| 91高清免费视频| 国产抖阴小视频全集在线观看| 美女公安一级毛片高清| 国产美女在线免费观看| 亚洲一区二区三区四区黄色| 99午夜福利影院一区二区三区| 国产真人无码作爱免费 | 99热视热频这里只有精品| 色老板免观视频在线看| 天堂av无码一区二区三在线播放 | 老肥婆做爰xxxⅹ性爽| 无码少妇A片一区二区三区| 九九精品网址| 日日摸日日碰夜夜爽免费中文字幕| 无套內谢丰满少妇中文字幕| 亚洲av日韩av欧v在线天堂| 亚洲国产精品日韩高清秒播| 在线免费观看理论片| 污草莓视频免费下载| 白丝喷白浆一区二区在线观看| 欧美孕妇极端喷潮视频| 国产 无码 高清| 亚洲综合国产在不卡在线首映| 精品女生爽爽爽免费中文毛片 | 无码东京热国产| 黄片无码在线免费观看| 亚洲第一区欧美国产综| 久久精品国产精品亚洲小电影 | 国产一级普通话对白刺激毛片 | 亚洲中文无码综合| 色多多福利网站| 91久久国产福利自产拍| 99视频在线精品这里观看| 欧美特黄色一级片| 97碰碰碰人妻无码免费看| k频道国产网红精品视频| 欧美日韩人妻精品一区二区| 黄视频网站大全| 国产午夜精品在人线播放| 亚洲A V无码国产丝袜在线观看| 粉嫩av网站在线观看| 亚洲大香伊人蕉在人依线| 日韩中文字幕亚洲| Av动漫H肉在线观看| 亚洲国产精品热久久久| 日本在线一区二区三区四区| k频道国产网红精品视频| 国产精品午夜啪啪啪| 私人影院在线观看亚洲| 成人黄色看片软件下载| 日韩?v网址在线免费观看| 欧美精产国品一二三产品工艺| 成人国产欧洲一区二区| 麻豆AV免费观看网站| 国产在线第一区第二区| 中文字幕亚洲国产剧情| 久久久国产精品成人一区二区| 可以在线观看的毛片网站| 大萫蕉伊久久综合| 久久 国产 影音先锋| 真人做爰视频免费观看视频| 亚洲AV无码国产精品色午友情连| 狠狠躁18三区二区一区99| 青青青青久在线视频免费观看| 国产午夜精品一区| 一成年人视频免费网站2| 欧美毛码aⅴ高清在线观看| 久久夜夜骚国产精品| 成人毛片视频免费播放| 精品一区二区三区免费毛片爱欲 | 天天夜夜久久| 秋野千寻在线无码观看| 久久综合日韩人妻| 国产一三级片高清字幕| 国产亚洲AV一二三区在线观看 | 988好吊妞的视频这里只有精| 色欲色欲蜜桃麻豆| 亚洲欧美日韩污在线观看| 免费无码AV电影在线观看| 精品多毛少妇人妻av免费久久| 男女猛插小穴视频在线观看| 欧美黑吊深喉hd| 亚洲欧美日韩黄视频| 日韩在线一二三四区第一页| 亚洲一本大道无码av天堂| 一级欧美精品黄片| 国产日韩欧美在线视频免费观看| 综合久青草视频| 最新的欧美精品一区二区在线观看| 久草色在线AⅤ无遮挡性爱| 一区二三区四区中文字幕| 久久中文成人免费观看精品久久久 | 国产小视频在线播放一区| 最新的欧美精品一区二区在线观看| 国产小视频在线播放一区| 国产喷水在线资讯| 亚欧一区在线播放| 色欲一区不卡| 亚洲五月天色色色视频| 欧美一级特黄级aaa片| 最新国产の精品合集bt伙计| 果冻传媒在线观看免费版下载| 欧美亚洲中文精品在线| 亚洲 国产 视频一区 | 手机看片国产一区二区三区| 高清免费无码毛片| 日本毛片高清免费视频 | 欧美日韩激情一区三区| 51午夜精品午夜电影| 一级真人片在线观看| 久青青在线观看视频国产 | 欧美巨胸喷奶水视频WWW| 国产精品sm捆绑调教视频| 亚洲国产高清自拍| 日韩无码免费网址| 亚洲av一级黄片在线免费观看 | 欧美性视频XXX18禁| 麻花天美影视免费观看电视| 极品熟妇大蝴蝶20P| 洲伊人丝袜精品久久| 丝袜国产在线观看免费视频 | 丁香五月亚洲中文字幕| 亚洲国产精品一线二线三线| 国产91精品免费视频| 伊人久久大香线蕉成人网| 少婦人妻互換不帶套| re九九热精品视频在线观看| 亚洲日本国产精品无| 办公室诱惑漂亮女上司| 欧洲AV成人片无码精品| 国产精品开放小视频| 中文字幕乱码视频91| 日本一区二区三区视频免费观看| 久久久无码一区精品亚洲日韩| 国产普通话对白刺激| 久久精品免费久精品蜜桃| 午夜一級毛片免費視頻| 99午夜福利影院一区二区三区 | 亚洲中文字幕免费视频| 欧美AN成片在线| 午夜在线看片国产不卡| 亚洲夜夜欢一区二区无码综合网| 夜夜爽精品视频| 亚洲av无码近親相姦| 精品一区二区三区在线网站| 日韩A一区无码视频| 限制级无码在线观看| 成人91 污污污在线观看| 国产愉拍91九色国产愉拍| 日本黄色激情视频网站| 麻豆国产尤物AV尤物在线| 国产大学生A片视频播放| 美女被黑人猛烈进出高潮视频 | 亚洲另类精品无码在线一区| 美丽姑娘视频在线观看免费高清版| 亚洲色在线V中文字幕| 亚洲精品一线二线三线| 中文字幕无线码一区二区| 成人国产精品视频国产| 亚洲综合精品看片| 国产亚洲一区欧美| 人人妻人人澡人人爽精品日本| 一区二区三区欧美日韩国产 | 宅男入口亚洲一区二区 | 星巴克一键去除衣物| 麻豆精品国产自产在线| 亚洲有码无码精品一区二区| 亚洲色大成网站77WWW久久久| 色免费视频在线观看| 国产精品无码a| 免费人妻无码不卡中文字幕18禁| 中文人妻精品一区二区| 色天使综合婷婷国产日韩A∨| 少妇中文字幕无码av| 天堂av无码一区二区三在线播放 | 欧美网站午夜激情| 日韩va在线观看| 色视频网站在线观看| 丰满少妇被猛烈进入无码久久| a欧美特黄日韩大片免费观看| 热99re久久精品2久久久| 一级性a级黄片| 一区二区三区在线中文视频| 日产欧美一区二区三区不上| 在线观看AV免费网站| 免费高清a级毛片在线播放| 欧美老妇人与小伙子作爱| 久久成人综合亚洲精品欧美小说| 日韩国产高清在线| 国产男女猛烈无遮掩免费观看呢| 午夜福利美女一区| 美女被黑人猛烈进出高潮视频| 国产无套护士bd高清| 欧美精品日韩一区二区| 一级做a爰片性色毛片成人久久久| 可以免费无限次数看黄的网站| 少妇让男人桶视频| 亚洲va久久久噜噜噜久久一| 岛国在线成人福利| 久久天天躁夜夜躁狠狠躁2015| 国产免费三级a淫色| 国内精品wwwwwww视频高清免费| 波多野结衣家庭教师good| 久久电影第一页精品| 国产欧美一区二区精品秋霞影院 | 亚洲vα国产日韩欧美精品| 一区二区三区四区永久中文字幕| 男同gay自慰网站| 污污的网站在线看免费| 夜夜躁狠狠躁日日躁孕妇| 美女动作一级毛片| 性猛交XXXX乱大交孕妇印度| 人妻少妇偷精品无码洋洋av| 亚洲A V无码国产丝袜在线观看| 亚洲美女精品一区二区| 小笛视频在线观看免费| 亚洲中文字幕乱码第二中文| 国产精品亚洲精品影院| 成人免费无码婬片在线| 国产片婬乱一毛片a最熱門最齊全電影! | 丝瓜视频看污片更新国产| 中文字幕在线观看第页| 久久人人97超碰精品忘忧草| 亚洲 国产 视频一区| 美女动作一级毛片| vvvv99日韩精品亚洲| 黄色视频在线观看网址| 91大神人妻论坛性趣| 亚洲高清无码在线免费观看| 黄色视频在线观看网址| 国产盗摄91精品一区二区| 日本道在线一区二区内射| 日本在线区日| 免费网站看SM调教视频| 99青草国产精品视频无码一区| 任我鲁精品视频精品| 夜夜躁狠狠躁2021a| 东京热无码中文字幕AV专区| 老熟妇乱子伦中文字幕| 日本一区二区二区免费国产| 免费人成激情视频观看| 国产毛片一级大全| 亚洲欧美高清在线一区二区三区| 国产av 无码 高潮网站| 中国91视频日本不卡视频网站| 天天干天天操AV| 国产午夜精品在人线播放| 二区久久国产乱子伦免费精品| 亚洲av一级黄片在线免费观看| 中国熟妇内谢人妻xxxxx| 西西偷拍亚洲妖精视频| 电影久久激情一区二区| 一区二区国产无码| 年轻的姐妹在线观看| 1024手机看片免费观看| 国产黄色午夜影院| 亚洲午夜综合福利| 中文字幕无码综合在线视频资源站| 欧美成人h亚洲综合在线观看| 亚洲精品国产91| 欧美日韩特黄一级免费| 午夜福利视频1000| 国产高清美女丝袜a毛片| 一区二区三区四区欧美日本| 久久精品无码国产āV| 清纯白嫩初高生免费观看| 免费看美女抠逼软件| 两个人免费完整版在线观看视频| 中文有码字幕日本第一页| 正在播放久久| 欧美人与禽交片欧美| 青草亚洲国产欧美一区二区| 缘分五月手机在线视频观看| {国产在线精品一区二区不卡| 精品亚洲国产一区二区三区| 久久夜夜无片无码| 久久久噜噜噜久久中文| 亚洲色图精品录音| 2023国产a天堂性生活久久久 | 无码专区亚洲精| 在线观看一区二区欧美日韩| 超碰98在线一级a性色生活片| 一级在线观看黄色片| 18 无码 高潮 蜜臀| 边做饭边被躁我和邻居的视频| 男女免费下载观看黄色日逼| 91精品国产乱码久久久久久| ss99亚洲成人精品在线| 欧美小视频在线观看| 精品婷婷久久久久| 老头在厨房添下面很舒服 | 国产白浆视频在线播放| 丝袜国产在线观看免费视频| 国内精品自在自线视频香蕉伦伦影院精品一区| 秋野千寻在线无码观看| 精品三级av无码一区色臀AV| 国产一级黄片人人操| 国产又爽又粗又硬又适应| 4480中文字幕乱码私人影院 | 亚洲一日韩中文字幕视频| 青青青青青手机在线播放 | 中文字幕亲子入浴交尾| 黄片超刺激在线看在线| 欧美AN成片在线| 日韩精品无码自拍第2页| 国产AV精选久久久| 亚洲亚洲人成网站网址| 狠狠色综合久久| 亚洲一级黄色片毛片| 中国av一级毛片| 丰满少妇被猛烈进入无码久久| 国产在线不卡视频| 99久久婷婷国产综合| 日产国产欧洲一道不卡| 久久久久久又大又猛| 欧美精品成人a在线观看牌| 亚洲国产精品V?在线看黑人| 国产在线不卡爆乳视频| 久久久久人妻精品水蜜桃| 日本乱人伦片中文字幕三区| 性欧美13处14处破在线观看| 免看一级a一级久久| 亚洲午夜大片网站| 亚洲区不卡顿区在线观看| 一级做a爰片性色毛片成人久久久 欧欧美玩弄白嫩少妇XXⅩ | 成人精品国产一区二区| 亚洲日韩欧美一区久久久我| 国产视频三区亚洲国产99| 中文字幕精品第一区二区三区 | 成人久久久精品综合色区| 奶头好大让老子摸摸的动态图| 国产精品不卡av在线观看| 三级影视欧美中文| 131美女爽爽爽爱做视频| 国产精品久久久久久久白浊| 深夜激情高潮观看亚洲| 成人免费一区二区播放| 日韩欧美视频免费| 久久精品国产黑森林| 免费高清a级毛片在线播放| 国产大胆露出在线视频| 人妻系列中文字幕无码专区| 国产片婬乱一毛片a最熱門最齊全電影!| 午夜福利视频网站永久| 米奇888在线播放欧美| 特级特黄囗交免费视频| 欧美 日产 国产成人免费| 精品国产乱码一区二区三区aa| 精品国产?Ⅴ一区二区三区4区| 亚洲阿v天堂在线| 欧美日韩一卡二卡3卡四卡| 乱伦小说与照片电影一区二区三区| 天美果冻女儿的梦想票房成绩| 国产一级免费网站| 一二三区无码在线视频| 日产无人区一线二线三线新版| 欧美小视频在线观看| 亚洲欧洲日产国产最新| 秋霞午夜限制电影在线| 2017欧美伦理片一页| 亚洲一区二区三区四区在线观看 | 爆乳无码中出在线播放| 一级片欧美日韩| 国产激情午夜福利| 免看一级a一级久久| 在线国产黄色毛片| 国产乱人在线视频| 在线播放侵犯中出| 成人免费视频一区二| 国产成人精品视频A片免费观看 | 青春草在线观看视频| 欧美日韩一卡二卡3卡四卡| 久久久一本精品久久久久久毛片 | 黄色视频污在线观看| 97性潮 久久久久| 亚洲一区二区三区91| 日本少妇欲高潮视频| 无码性中文字幕| 亚洲成ā∨人片在线观看无码 | 白浆白浆av找av导航| 岛国av天堂女人| 中文字幕无码最新视频| 午夜在线播放网站| 久久成人综合亚洲精品欧美小说| yy6080午夜理论大片一级| 最新的欧美精品一区二区在线观看| 欧美一级在线免费| 日产国产欧洲一道不卡| 亚洲A∨无码精品色午夜果冻| 亚洲狼人综合| 在线观看AV黄网站永久簧| 国产超级ⅴa在线观看视频 | 亚洲mv国产mv在线mv综合观看| 99草草国产熟女视频在线| 国产一区二区三区在线伊人| 欧美精品人爱C欧美精品四虎 | 亚洲AV无码精品午夜福利久久| 国产一区二区三区在线伊人| 亚洲精品久久久鸭子| 不卡无在线一区二区202| 书房含乳尖h调教笔趣阁| 国产精品无码久久蜜臀av| 欧美亚洲日韩四虎影视91| 亚洲无码三级综合| 国产精品成人午夜视频| 欣赏毛片黄以性生大片| 成人在线日韩欧美| 手机国产小视频在线播放| 欧美老妇人与小伙子作爱| 在房间打扑克又疼又叫又开心| 成人国产精品视频国产| 五月婷婷无码影视| 免费欧美成人一级片在线观看| 中文字幕黄色三级片| 日韩欧美一区二区三区不卡在线| 黄色片国产黄色片| 在线观看精品国产大片| 黄色视频污在线观看| 欧美日韩一区二区短视频| 香蕉欧美在线观看| 国产黄色午夜影院| 久青青视频在线观看久| 中日韩欧美男人的天堂| 亚洲一区日韩电影在线观看| 久草综合在线视频| 亚洲中文字幕免费视频| 欧美女人天堂视频在线观看| 欧美中文字幕永久免费| 亚洲日韩国产新品| 中国一区视频在线观看| 丝袜美女被出水视频一区| 色老头国产AV一区二区三区| 99青草国产精品视频无码一区| 亚洲一本大道无码av天堂| 日韩av在线一区二区三区四区| 国产男女猛烈无遮掩免费观看呢| 绯色av麻豆一区二区三区| 亚洲mv在线无码mp4| 影音先锋影院| 女的被到色情免费看| 久久亚洲?v无码精品色午夜麻豆| 最新国产精品视频综合区| 欧美韩国人成网站中文字幕| 办公室撕开奶罩揉吮奶漫画| 日本伦精品一区二区三区免费| 妖精视频永久网站网址| 超碰熟女久久熟女| 白白高清日本黄色一区二区| 深夜偷弄裸睡的小丹| 国产av亚洲aⅴ一区二区| 日韩人妻视频一区二区| 色婷婷国产精品视频久久欧洲成人精品无码区 | 国产福利区一区二区三区四| 4399日本韩国电影高清完整版免费| 亚洲av美女夜夜| 好看的av在线不卡| 欧美性色A级欧美| 欧美一区二区视频福利| 色片在线免费看| 免费av在线无码| 国产91高清三级久国产| 爆乳无码中出在线播放| 国产精品一久久久久| 亚洲乱码A∨一区二区三区| 最好看免费中文字幕2018| 欧美涩涩久久丁香| 在线观看视频黄页| 中国av一级毛片| 欧美人成老熟女强奸视频网站| 五月天影院丰满熟妞区| 伊人久久大香线蕉成人网| 色婷婷国产精品综合在线观看| 国产一区二区激情视频| 91精品国产一区国产二区久久| 天海翼一区二区三区四区 | 欧美人与动性行为精品| 国产成人精品视频A片免费观看| 人妻 色综合网站| 欧美中文字幕欧美在线播放 | 国产av亚洲aⅴ一区二区| 一区二三区四区中文字幕| 性爱在线观看网址| 精品久久久无码中文字幕廣大網友最新影片 | 日韩欧美a片在线观看| 久久久久亚洲av无码本人本人 | 不卡在线观看一区二区三区| 欧美网站午夜激情| 亚洲中国妓女毛茸茸| 亚洲一区二区久久噜| 欧美一级特黄淫片在线观看| 久久成人AV一区二区大全| 欧美人与禽交片欧美| 亚洲嫩模一区二区三区| 综合一区二区三区av老鸭窝 | 福利网无码视频在线观看| 131美女爽爽爽爱做视频| 天天综合国产中文日韩直播综合| 精品国产av无码久久久百度| 精品女生爽爽爽免费中文毛片| 国产免费三级a淫色| 亚洲成人电影免费在线观看| 爽爽影院国产| 成人性生交片无码免费30年老片 | 少妇高潮太爽了在线观看图片 | 99免费视频精品| 激情综合色五月丁香六月| 18禁超污无遮挡无码网址极速| 精品中文字幕无码在线| 为你收集色天天天综合网色天天 | 中文字幕亲子入浴交尾| 国产精品3p视频| 国产美女一级做受视频| 在线播放国产欧美日韩| 国产主播微拍在线播放| 国产一三级片高清字幕| 福利视频香蕉免费一区二区在线| 處女開苞大合集毛片视频| 国产大胆露出在线视频| 蜜桃传媒果冻星空传媒视频| 欧美黑人福利在线导航 | 国产毛片高清视频| 韩国电影爱人未删除完整高清版| 污污污欧美黄片在线免费观看| 日本久久精品免费一区| 国产毛片人妻人伦人人澡| h漫在线一区二区成人| 亚洲不卡久久久久久| 国产欧美午夜久久| 豆奶短视频黄色| 亚洲国产日韩精品女日日骚| 国产野精品久久久不卡| 24小时欧美在线视频www| 欧美又黑又大又长又硬| 欧美激情在线观看手机视频 | 打开这个网站你会感谢我的| 午夜歐美福利視頻| 青青河边草免费观看完整版高清| A级毛片毛片免费观着久| 国产亚洲一级精品电影| 106人妻人人澡人人爽人人精品| 久悠悠a亚洲美女中文字幕| 国产精品国产三级国产av播| 公交车被脱了内裤进入动漫| 久久亚洲AV无码专区成人| 欧美黄A不卡免费欣赏| 日本韩国免费观看高清电视剧| 亞洲第一第二第三第四第五第六| 欧美日韩最新中文字幕| 中文字幕高清不卡免费| 中文有码字幕日本第一页| 无码精品国产一区二区免费| 亚洲AV无码二区三区在线| 极品人妻手机视频在线| 99精品免费久久久久久久久蜜桃| 成人羞羞漫画免费观看网| 久久成人AV一区二区大全| 亚洲小说欧美中文在线| 亚洲欧美日韩综合在线观看不卡顿| 亚洲精品欧美精品午夜精品| 高h肉肉免费全部视频观看| 中日韩成人免费精品一二三区 | 性色av成人免费观看国产一区| 九九精品网址| 人妻 色综合网站| 荒野2翡翠牧场女儿| 亚洲天堂在线观看不卡视频| 国产福利区一区二区三区四| 疯狂做受XXXX高潮不断| 中文字幕在线中…av| 禁漫H天堂免费A漫| 黄色网在线观看国产| 女人18一级特级三级片免费看| 中文字幕亚洲国产剧情| 精品国产亚洲亚洲一级毛片| 亚洲精品中文字幕在线观看| 日韩性爱AV一区二区在线看| 国产亚洲欧美在线观看精品不卡| 国产在线无码播放不卡视频| 国产成人三级视频在线播放播| 最好看免费中文字幕2018| 久久精品一级大片| 成人a一级三级片免费看| 国产美女精彩视频勾搭| 爆乳无码中出在线播放| 欧美一级在线国产| 熟妇高潮精品区一区二区三| 女同一区二区| 国内一级a爱片在线观看| 99热国产在线观看不卡| 国产精品久久青青7777| 国产日韩不卡综合AⅤ电影| 亚洲日韩Aⅴ无码精品放毛片| 手机在线观看日本Aa| 磁力链bt磁力种子天堂| 国产亚洲精品影视在线| 久久久久AV免费看| 欧美视频在线观看一区全国| 国产成人综合精品久久高清| 伊人七七久久桃花精品影院| 国产91高清三级久国产| 黄色网站在线观看视频免费| 国产a理论视频| 国产高清美女丝袜a毛片| 久久午夜福利视频| 日本极品人妻videossex| 青青青青久在线视频免费观看| 高清视频亚洲美臀写真小电影在线观看| 不卡日本免费A∨片免费| 精品中文字幕无码在线| 日本一本正道久久综合高清| 风流老太婆大bbwbbwhd视频| 韩国一级特黄大片在线观看| 任我鲁精品视频精品| 宅男视频app安卓下载| 97在线观看视频资源| 国产三级片一区二区三区不卡免费观看| 4399国语免费播放| 色综合视频一区二区三区在线观看| 国产日韩黑人午夜在线观看| 国内精品少妇毛片| 私人影院在线观看亚洲| 强奸搞鸡app视频免费看网黄羞羞 日本一区二区二区免费国产 | 在线播放国产欧美日韩| 荒野2翡翠牧场女儿| 国产中文字幕第一页伊人网综合在线视频| 色婷婷婷丁香综合不卡亚洲| 日本最新高清不卡一区二区| 日韩黄中文字幕不卡在线| 亚洲一区二区国产观看| 久久久久久国产综合精品| 国产最污午夜三级福利电影| 二区久久国产乱子伦免费精品 | 国产真实伦对白精彩视频8| 日韩三四级大白午夜| 青青青青久在线视频免费观看| 双腿大开被绑到椅子扶手上| 成人涩涩涩视频在线观看| 人人爽人人爽人人片A∨| 日韩中文字幕无码人妻不卡| 欧美亚洲桃色五婷婷| ss99亚洲成人精品在线| 99精品国产乱码久久久| 国产成人无码??精品一区| 亚洲妓女综合995| 视色4se影院在线观看| 一级国产交换配乱淫| 草草浮力影视| 欧美一区二区三区性爱视频| 亚洲中文字幕乱码第二中文| 欧美日韩中文电影| 国产亚洲日韩AV在线播放不卡| 日本视频在线观看亚洲免费| 欧美肥老师交性视频| 青草伊人久久综在合线亚洲观看| 亚洲区欧美区日韩区| 精品一区二区三区在线网站| 夜夜爽精品视频| 国产特黄激情AAAAAA视频| 国产 无码 高清| 国产免费福利网站在线观看| 级a一级a爰片免费久久| 99久久人妻精品免费一区色| 国产又爽又粗又硬又适应| 人妻斩久久综合一区二区| 成人福利视频直播| 2020年国产精品自线在拍| 最新的欧美精品一区二区在线观看| 无码人妻精品一区二区不卡| 91熟女精品视频| 国内精品wwwwwww视频高清免费| 久热这里只有精品91| 久久久国产电影精品| 亚洲精品国产91| 国内揄拍高清国内精品对白| 国产av亚洲aⅴ一区二区| 2019年在线精品国产| 色老头在线一区二区三区| 亚洲?V无码潮喷在线观看| 日本体内she精2汇编| 91综合在线视频观看| 国产精品久久青青7777| 99久久精品国产高潮杨幂| 日韩av免费观看久久| 伊人久久香线蕉综合| 国产奶水小视频在线观看| 码专区天堂8中文| 日本高清色视频在线观看免费| 亞洲成色www久久網站夜月| 人人妻人人澡人人爽精品日本 | 日日摸夜夜添夜夜无码国产| 国产大学生视频在线观看| 最新亚洲av综合网址| 欧洲亚洲 视频一区亚洲视频一区在线视频观看 | 日本高清动作片www| 久久久久久国产综合精品| 国产精品性奴在线播放| 陪读性事乱(第40部分小说| 成h在线观看免费观看| 一二三区视频| yw亚洲精品尤物在线观看| a级老女人毛片免费完整视频| 日韩在线一二三四区第一页| (愛妃視頻)亚洲 欧美 综合 另类 中字 | 日韩欧美在线一区二区三区| 日韩欧美人妻少妇| 张开双腿狠狠的c男男h| 亚韩精品中文字幕无码| 最新中文字幕无码视频在线| 开心色婷婷色五月激情| 国产特黄激情AAAAAA视频 | av毛片三级久久久| 精品99re66一区三区| 欧美一级内射国产| a国产三级级在线电影大学生| 五月天国产无码在线| 黄网站色年片在线观看| 18禁亚洲深夜福利人口| 久久久午夜精品福利内容| 免费观看区三区二区一日本| 日韩欧美视频免费| 免费a级毛片大全| 国产精品无卡无 在线播放| 日韩精品重口另类一区| 久久夜夜骚国产精品| 国产亚洲乱伦综合| jk白丝在线观看国产| 亚洲人成影院午夜网站| 久久久亚洲综合网站| 亚洲日韩黑人精品一区| 日本高清视频色www在线观看| 欧美人与动交tv| 国产91麻豆精品成人区| 国内女主播白浆视频久久婷婷| 在线免费自拍| 好男人资源网在线影院| 校园全肉高h湿一女多男| 国产av一级美女毛片| 欧美精品手机在线观看视频 | 探花视频国产在线观看免费高清网站| 日本熟妇厨房美熟bbw| 亚洲熟妇无码99精品| 国产在线观看一区二区三上| 亚洲蜜桃无码一区二区三区久久午夜无码鲁丝片午夜精品 | 野花日本大全免费观看中文7| 婷婷成人无码| 免费三级现频在线观看播放| 131美女爽爽爽爱做视频| 久久亚洲午夜| 国产免费AV片在线观看国语| 国产片在线观看18女人| 国产在线观看麻豆| 亚洲国产欧美91资源| 日本道在线一区二区内射| 性饥渴XXXXⅩHD孕妇69式| yy6080午夜理论大片一级 | 久久精品—区二区| 亚洲麻豆精品一区二区综合Av| 水蜜桃视频午夜爽爽爱| 亚洲∧v日韩无码∧v毛片| 人人爽人人看| 亚洲中文字幕va毛片在线| 国模国产精品嫩模大尺度视频 | 色婷婷国产精品视频久久欧洲成人精品无码区 | 亚洲AV秘无码一区二在线观看| 美女又大又粗又爽一级毛片| 水蜜桃视频午夜爽爽爱| 国模娜娜一区二区三区 | 最大免费国产色片网址| 少妇爆乳无码免费专区| 日本乱码片中文字幕www| 精品熟女少妇av久久免费| 狮王的巨大挺进体内h| 亚洲精品国产呦系列性爱一级 | 欧美性爱黄色网址| 在线观看不卡的无码视频| 摸进她的内裤里疯狂揉她明星| 亚洲国产高清无码自拍| 91情国产l精品国产亚洲区| 亚洲天堂一级av| 在线看黄网址| 国内精品久久久久影院欧美91| 少妇人妻无码高清精品| 亚洲欧美日韩在线精品一区二区| 国产18无遮挡无码三级网站不卡 | 日韩欧美a片在线观看| 日本一区二区精品不卡在线| 国产激情午夜福利| 亚洲成人黄色片片| 欧美日韩一卡二卡3卡四卡| 国产精品免费线观看你懂的| 曰韩内射六十七十老熟女影视| 欧美精品人爱C欧美精品四虎| 人妻少妇nc18嫩草| 久久精品国产99国产精2020丨| 亚洲成a人片在线观看的电影手机版| 免费的小蝌蚪网站看v片在线| 亚洲国内综合网国产精品v日韩精品v| 亚洲mv在线无码mp4| 日本黄色激情视频网站| 日韩在线一二三四区第一页| 成人久久久精品综合色区| 欧美精品口爆一区二区| 欧美亚洲中文精品在线| 久久精品国产99国产精2020丨| 日本免费久久高清| 日韩在线成人精品视频| 日韩免费av一区| 免费手机看片1024在线观看| 91粉嫩萝控精品福利网站| 中国丰满熟妇乱XXXX视频| 亚洲AV秘无码一区二在线观看| 无码少妇av无码专区 | 精品成人在线视频| 精品成人在线视频| 国产精品久久久久久久久午夜福利| 国产老熟女91pom| 精品欧美大臿香蕉在线视频| 天堂种子在线www网资源 | 白白高清日本黄色一区二区| 久青草国产手机在线视频| 少妇露脸无套高潮无套视69| 九九热在线免费观看视频| 亚洲午夜大片网站| 色婷婷激婷婷深爱五月小说| 永久黄色免费网站| 一级做a爰片性色毛片成人久久久| 少妇人妻无码精品视频app| 欧美在线日韩在线观看| 无码三级久久中文| 国产农村妇女高潮大叫| 国产精品与欧美交牲久久久久 | 人妻少妇nc18嫩草| 在线播放国产欧美日韩| 成年人爱视频亚洲| 国产女人十八毛片水真多| 99精品国产乱码久久久| 亚洲欧美精品图片区小说区| 亚洲欧美伊人一区| 不卡免费网站在线观看| 大丰满爆乳精品一区二区| 久久精品免费久精品蜜桃| 国产精品三区第二页| 国产中文视频无码成人| 夫上司人妻秘书ol中文有码| 国产日韩91一区二区三区欧美 | 高清无码视频网站| 国产精品性奴在线播放| 欧美韩国人成网站中文字幕| 成人性视频在线三级| 亚洲精品一线二线三线| 网国产图片视频在线观看| 国产精品不卡av在线观看| 熟妇高潮一区二区精品午夜无码| 久久这里只有精品最新6| 欧美东京热不卡视频分三区| 亚洲AV永久无码精品的| 成人羞羞漫画免费观看网| 未满十八18禁止午夜免费网站| 青青草成人五月天| 迪丽热巴国产精品无套内射| 欧洲美洲国产综合首页| 欧美日韩影视在线| 狠狠色噜噜狠狠狠777米奇888| k频道国产网红精品视频| 日韩精品一九区熟女中文字幕 | 国产激情午夜福利| 三级精品国产成人国产三级| 蜜桃久久综合亚洲| 精品中文字幕在线| 成人电影中文字幕小说在线| 欧美日韩亚洲一区在线观看| 成人一区二区无码不卡视频| 中日韩欧美男人的天堂| 久久久精品国产天天| 播放的黄色大片在线看一区二区| 国产成人久久精品二区三区s| 男人天堂欧美亚洲| 免费无码刺激性a片完整版| 中国一级无码av毛片| 日本不卡一二三区在线观看| 韩国精品一区二区三区四区| 免费的小蝌蚪网站看v片在线 | 国产精品久久九九片| 2019年国产精品自拍不卡| 亚洲成人一区二区三区三州| 亚洲中文字幕免费视频| 又大又粗又爽A级频片| 18禁亚洲深夜福利人口| 日韩视频亚洲欧美偷| 女教师波多野结衣高清在线| 色综合久久精品国产| 国产免费高清视频一区二区三区| er这里只有久久| 国产一级黄片人人操| 高h肉肉免费全部视频观看| 亚洲国产精品一区视频| 三级毛片国产一区| 美女又大又粗又爽一级毛片| 国产超碰人人爽人人做av| 日韩精品久久久久久久影视| 欧美一级二级视品 | 国产精品嫩草久久久久软件| 成人在线日韩欧美| 国产欧美在线日韩不卡第一页| 国产欧美日韩高清专区| 亚洲午夜精品久久| 亚洲欧洲日韩91| 性生活视频网站免费不卡无码| 亚洲日韩高清在线一区二区三区| 日韩黄中文字幕不卡在线| 欧美老妇人与小伙子作爱 | 日本道在线一区二区内射| 免费αV一区二区三区无码| 一级仑乱免费视频| 成年午夜视频在线观看131| 2021年最新最全的国产新品| 韩国av无码一区二区二三区| 国产黄片亚洲第一区欧美国产综合| 香蕉视频国产在线观看互動交流| 亚洲色无码国产精品不卡| 欧美日韩影院| 久久久久亚洲av无码本人本人| 久青青视频在线观看久| 日韩精品视频在线免费观看| 九九插九九干| 无遮挡h肉动漫在线观看免费资源| 日韩综合nv一区二区在线观看| 亚洲AV无码国产精品色午友情连| 伊人丁香狠狠色综合久久| 亚洲区日韩精品mv| 亚洲一区二区三区91| 青柠在线观看免费高清电视剧 | 國產成人精品午夜視頻| 日本系列有码字幕中文字幕| 免费人成激情视频观看| 中文字幕永久精品国产| 一区二区国产无码| 不卡日本免费A∨片免费| 欧美一区二区三区性爱片| 野花日本大全免费观看中文7| 香蕉视频国产在线观看互動交流| 陪读性事乱(第40部分小说| 国产好吊看视频在线观看| 少妇之白洁被三人玩| 毛片免费看网站| 国产男女做爰猛烈叫床小说| 2022免费在线视频| 欧美精品午夜一区二区三区| 天堂种子在线www网资源| 女人扒开腿让男人桶到爽免费视频 | 在线观看视频黄页| 日本不卡免费高清一级视频| 国产黄色靠逼视频网站| 中文字幕少妇被按摩难受出水| 亚洲日韩黑人精品一区| 国产与丰满岳交尾乱免费视频 | 久久久免费不卡av二三| 国产精品麻豆免费观看| 国产三级交换夫妻电影| 中日韩成人免费精品一二三区| 免费播放大地资源高清日本| 日韩国产一区二区无码| 日韩丰满熟妇A毛片视频播放| 日韩av在线一区二区三区四区| 四虎4hutv永久在线影院| 最色的最黄的美女视频| 摸进她的内裤里疯狂揉她明星| 奶头好大让老子摸摸的动态图| 少婦人妻互換不帶套| 国产精品sm捆绑调教视频| 国产精品亚洲精品日韩已满十八小| 亚洲国产精品丝袜在线观看| 羞羞软件APP下载| 亚洲精品不卡中文字幕| 韩国资源国产精品| 香蕉视频在线观看免费国产婷婷| 國產成人精品視頻一區二區不卡| 国产精品亚洲羞羞羞app| 羞羞软件APP下载| 免费无码真人十八禁网站| 欧美一级毛一区二区三区| 亚洲中文字幕在线麻豆| 国产AⅤ码专区亚洲AⅤ| 八重神子被×哭还不断流东西网站游戏| 无码毛片一区二区视频免费播放| 空少被机长狂躁俩小时的故事| 久久99欧美激情| 9久久99看黄毛片免费| 打开这个网站你会感谢我的| 99久久婷婷国产综合| 欧美天堂在线| 成年黄页网站大全免费视频| 手机看片久久观看免费| 亚洲v视频日韩一区二区在线| 欧美最新免费三区| 色午夜综合精品视频在线看| 嫩草影视入口永久一二三区| 97超碰人人爱百度| 欧美涩涩久久丁香| 十六一下岁女子毛片免费| 日本ab视频在线观看AAv| 国产小视频在线播放一区| 蜜臀91丨九色丨丝祙黑料| 国产精品高清久久久| 色婷婷播五月开心五月综合| 国产无套护士bd高清| 欧美第一视频| 精品国产高清久久久久久| 国产中文字幕第一页伊人网综合在线视频 | 一区二区三区女人作爱| {国产在线精品一区二区不卡| 乱码1乱码2美美哒| 中文字幕在线亚洲无码| 久久久久国内精品免费观看 | 91美女在线观看| 免费大片免费观看| 日韩美女一级免费毛片| 久久亚洲综合中文字幕无码| 欧美韩国人成网站中文字幕| 亚洲无人区编码国产激情| 人人摸人人操天天爽| 亚洲亚洲成在人线影视| 深夜视频99二区| 黄网站在线观看免费白丝| 日韩成人综合久久久| 亚洲一区二区三区91| 91欧美精品日本在线一区| 国产亚洲乱伦综合| 尤物在线视频免费国产| xp123欧美亚洲国产日韩| 97人妻人人爽人人爽天天| 亚洲日韩经典乱论视频| 日本久久久久久久久| 一级欧美精品黄片| 操逼软件免费| 久久久四虎成人永久免费网站| 深夜视频污APP下载| 国产精品开放小视频| 国产农村妞女一级| 中日韩一区二区三区| 久久人妻少妇偷人精品综合| 91精品人妻一区二区三区综合| 水蜜桃视频午夜爽爽爱| 久久99欧美激情| 国产a级综合区毛片久久久久久| 视频一区亚洲欧美清纯制服| 久久中文成人免费观看精品久久久| 给我播放片在线观看| 成在人线?V无码免观看麻豆| 欧美激情亚洲一区中文字幕| 亚洲v视频日韩一区二区在线| 九九啪啪视频| 东京热加勒比hezyo久久| 黄色网站免费无遮挡毛片a| 三级影片在线观看免费的| 国产成人免在线观看| 成人免费毛片熟女| 日韩丰满熟妇A毛片视频播放| 久久国产亚洲欧美日韩| 国产美女精彩视频勾搭| 最新国产欧美日韩一页| 五月天影院丰满熟妞区| 在线播放国产不卡无毒视频 | 国产91精品免费专区| 欧美一区二区三区性爱片| 国产电影一区二区在线观看| 蜜桃av成人午夜视频| 亚洲国产一区二区三区视频| 亚洲国产欧美二区在线播放| 99久久精品国产高潮杨幂| 国产精品久久久99不卡| 亚洲日韩天堂AV在线网| 婷婷伊人五月天色综合激情网| 日韩欧无码一二三区免费不卡| 久久久精品国产天天| 国产免费牲交视频变态天堂 | 含羞草国产精品视频免费看| av中文字幕一区二区| 免费手机看片你懂得精品国产三级av在线 | 一区二区三区一级黄片| 亚洲精品中文幕一区二区| 女的被到色情免费看| 18crdh打造最全面的福利网址导航 | 牛牛影院一区二区三区四区| 欧美怡红院手机在线看视频| 中文字幕少妇被按摩难受出水| 欧美一区二区视频福利| 卡通动漫综合图区第一页| 欧美日韩精品一二区| 一级黄片无码在线| 视频一区二区三区日日骚| 狠狠久久亚洲欧美专区不卡| 久久香蕉性爱视频| 亚洲综合精品高清无码| 日韩无码AV一区| 无码另类丝袜专区| 国产成人综合免费看| 欧美激情性A片在线观看| 香蕉视频日本| 亚洲国产成人av在线播放一本| 色五月激情五月综合网五月天| 看全色黄大色黄大片毛片| 亚洲天堂日本成人| 极品av一线天五月天| 日韩欧美在线一区二区三区| 一二三四日本手机高清视频| 亚洲欧美国产小姐a一级| 国产午夜精品一区| 亚洲国产精品七区八区| 欧美一级毛一区二区三区| 久久人人爽人人片浪潮a| 日韩欧美在线一区二区三区| 99午夜福利影院一区二区三区| 深夜在线电影| 亚洲AV秘无码一区二在线观看| 日本一区二区三区视频免费观看| 午夜亚洲国产理论秋霞| 国产精品久久久久久免费观看 | 日韩精品亚洲专区第一页| 99视频在线精品这里观看| 欧美一级婬片AAAAAAA| 抽插视频啊啊啊啊啊啊好疼死| 网国产图片视频在线观看| 久久人妻中文字幕乱码午夜久久| 欧美AN成片在线| 高清影视国产亚洲| 国产欧美日韩传媒| 韩国电影爱人未删除完整高清版 | 国产成人免费高清直播下载| 亚洲 欧美在线视频| 无码三级久久中文| 成人精品日韩电影在线| 性无码国产一区在线观看99国产精品无码专区 | 午夜视频国产二区一区| 亚洲欧美日韩污在线观看| AV影音先锋天堂网| 午夜不卡视频在线播放| 国产精品亚洲精品影院| 丁香网站欧美亚洲校园| 亚洲精品大片免费看 | 亚洲欧美精品日韩专区| 麻豆久久免费观看| 成人性视频在线三级| 国内精品大屁股白浆一区二区| 日本高清动作片www| 日韩一级无码毛片大片| xp123欧美亚洲国产日韩| 日韩视频亚洲欧美偷| 免费三级现频在线观看播放| 久久久精品国产天天| 一区二区三区四区欧美日本| 日产欧美一区二区三区不上 | 中国一级无码av毛片| 日韩永久免费视频| 国产av 无码 高潮网站| 亚洲 国产 视频一区| 欧美巨胸喷奶水视频WWW| 日本高清色视频在线观看免费| 日韩欧美一区二区三区不卡在线| 毛片国产一区二区三区| 国产v欧美v亚洲v精品| 黄色视频在线观看网址| 国产美女一级a作爱播放免费 | 91情国产l精品国产亚洲区| 97在线观看视频资源| 国产精品三区第二页| 106人妻人人澡人人爽人人精品| 超碰在线超碰在线在公开| 一级毛片男女做受| 丁香五月亚洲中文字幕| 亚洲一级片在线视频| 主人调教憋尿高潮锁| 热99re久久精品国产99热| 日韩主播在线视频一区二区| 思思热免费视频播放| 69式国产真人视频| 国产AV无码专区亚洲AⅤ蜜芽| 国产性爱在线观看亚洲第一黄片| 亚洲精品中文幕一区二区| 在线观看日本国产一区| 国内精品自在自线视频香蕉伦伦影院精品一区 | 日韩精品一区二区三区中文麻豆| 超碰国产农村AⅤ| 免费一级无码午夜精品福利| 老头在厨房添下面很舒服| 欧美在线观看中文少妇| 精品国产电影在线看免| 新99视频有精品视频高清| 午夜精品福利一区| 精品久久久无码中文字幕廣大網友最新影片 | 欧美三级中文字幕乱码| 亚洲 激情 在线| 色婷婷大香蕉超碰| 香蕉视频免费| 含羞草国产精品视频免费看| 高清无码小视频婷婷丁香五月伊人| 乱伦小说与照片电影一区二区三区| 亚洲大片永久精品免费| 国产网曝门亚洲综合在线| 福利国产免费观看0855影视| 欧美丰满熟妇久久久96喷水| 码国产在线播放性爱综合网| 国产毛片高清视频| h漫在线一区二区成人| 国产精品成人午夜视频| 激情六月天婷婷| 暖暖国语免费观看高清完整版中文| 蜜臀av欧美精品日韩偷拍综合| 永久免费无码中文字幕| 久久人人97超碰精品忘忧草| 欧美黑吊深喉hd| 成人精品一区二区三区免费视频 | 久久蜜桃精品无码一区二区| 无码三级久久中文| 国产欧美日韩传媒| 亚洲 激情 在线| 亚洲五月天色色色视频| 老鸭窝在线观看视频的网址| 亚洲国产精品看片在线观看电影 | 91极品国产尤物| 少妇中文字幕无码av| 国产成本人片无码| 久久久久久影院观看| 天堂va视频在线免费观看| 国内精自品线一区91制片| 国产成人综合精品久久高清| 成人精品一区二区三区免费视频 | 午夜剧场免费无码A片| 痉挛高潮喷水视频在线观看| 91美女在线观看| 亚洲日韩欧美一区、二区| 可以免费观看的黄页| 韩国资源国产精品| 日韩无码免费网址| 亚洲国产精品成人在线观看| 美国黄色毛片| 超在线观看免费视频| 亚洲中国妓女毛茸茸| 91精品啪在线观看国产91 | 国产第一免费视频| 各类熟女熟妇真实广东视频| 欧美黑吊深喉hd| 中国孕妇变态孕交xxxx| 國產精品國三級國產AV| 成人a一级三级片免费看 | 日本体内she精2汇编| 香蕉视频成人在线观看| 97人妻无码一区二区精品免费| 久久久久人妻精品系列| 亚洲成人一区二区三区三州| 女的被到色情免费看 | 国产一级真人视频三区| 91久久久久无码| 无码性中文字幕| k频道国产网红精品视频| 91视频在线观看网址| 国产日韩91一区二区三区欧美 | 男女刺激高清视频在线观看| 免费亚欧在线视频观看| 激情国语在线一区二区图片| 日本成人久久精品| 狠狠躁东京热无码专区| 成人啪精品视频免费国产| 亚洲欧美丝袜清纯另类| 永久黄色免费网站| 国产亚洲日本不卡一区| 久久免费看精品直播| 国产无码在线观看视频网站 | 污污污网站免费观看| 成人无码秒福利天堂一区| 91蜜桃精品国产91久久久久| 國產成人精品午夜視頻| 国产在线观看按摩会所| 欧美 日产 国产成人免费| 99热在线观看精品| 国产欧美日韩传媒| 变态另类在线观看| 精品推荐欧美三级超级碰少妇| 精品欧美大臿香蕉在线视频| av在线不卡无码区| 97色色不卡视频| 欧美激情亚洲一区中文字幕| 国产精品亚洲精品日韩已满十八小 | 免费的小蝌蚪网站看v片在线| 超碰98在线一级a性色生活片| 草草浮力影视| 国产精品无卡无 在线播放| 欧美激情亚洲一区中文字幕| 安徽妇搡BBBB搡BBBB按摩| 97人妻夜夜人妻夜夜爽一区二区| 国产精品制服丝袜第一第二区三区| 任我鲁精品视频精品| 少妇之白洁被三人玩| 国产成人无码视频一区二区三区| 国产在线不卡爆乳视频| 缘分五月手机在线视频观看| 公交车被脱了内裤进入动漫| 了解最新久久一区二区精品| 国产黄色午夜影院| 思思精品视频视频在线观看| AV午夜久久蜜桃传媒软件 | 直人实女处被破www免费| 国产一区二区不卡高清更新| 国产一区福利在线观看| 免费无码国产免费| 一本大道色卡1卡2卡3| 国产免费久久精品99resw| 十八禁网站在线观看免费视频| 欧美巨胸喷奶水视频WWW| 一级特一级特色生活片| 先锋影音资源精品| 国产精品久久国语| 亚洲欧美国产另类91综合| 不卡在线观看一区二区三区| 久久久久久国产精品无码下载| 少妇搡BBBB搡BBB搡造水多| 2024天天躁狠狠燥| 亚洲国产一区二区三区视频 | 国产中文字幕第一页伊人网综合在线视频| 国产中文字幕第一页伊人网综合在线视频 | 国产精品久久一区二| www国产福利一区二区| 免费无码真人十八禁网站| 成人中文不卡黑人在线| 亚洲精品亚洲人成年| 亚洲美女视频黄网站| 在线中文字幕日韩亚洲欧美| 免费黄网在线| 久久久aⅤ极品无码动态图| 成年午夜视频在线观看131| 久久国产精品一区二区三| 无码国产成人午夜视频在线播放| 99久久综合狠狠综合久久免费观看 | 高中生国产AV网站| 男人日女人视频免费观看大吊日逼| 亚洲色欲色欲www在线看无码| 51午夜精品午夜电影| 久久成人综合亚洲精品欧美小说| 国产无码在线观看视频网站| 亚洲日本欧美在线中文字幕| 亂倫人妻無碼中文字幕电影| 欧美熟妇性XXXx交朝喷| 兰一区二区三区四区免费视频黄片| 18禁网站禁片免费观看| 国产一区二区三区在线伊人| 国产成人a大片大片在线播放| 欧美亚洲国产人成aaa| 日韩欧美精品有码在线播放免费| 挺进成熟人妻的雪白翘臀视频| 亚洲欧美精品日韩专区| 国产亚洲AV综合| 亚洲无码在一一线| 嘿咻嘿咻欧美在线观看| 亚韩精品中文字幕无码| 性色av成人免费观看国产一区| 88国产精品无码一区二区三区| 女人色国产a精品| 码专区天堂8中文| 国产又爽又粗又硬又适应| 另类图片国产视频| 国产黑色丝袜视频在线观| 丰满人妻无码av系列| 欧美日韩特黄一级免费| 成人羞羞漫画免费观看网| 久久日韩免费视频手机直播| 亚洲成色一区二区三区| 好爽好舒服要高潮了视频| 国产精品偷伦费看| 人一禽一乱一交一视一频| 日韩精品视频久久| 日产国产欧洲一道不卡| 91大神在线精品播放| 肉乳床欢无码A片动漫樱花| 东京热免费一级毛片视频| 91亚洲精品在看在线观看看高清 | 磁力链bt磁力种子天堂| 亚洲色大成网站77WWW久久久| 国产美女精彩视频勾搭| 国内精品wwwwwww视频高清免费| 成人一区二区无码不卡视频| 在线国产黄色毛片| 含羞草国产精品视频免费看 | 亚洲大香伊人蕉在人依线| 精品妓女久久久久亚洲中文| 奶茶视频apk看黄app| 中文字幕第一页在线观看影音高清资源 | 成人免费黄片视频| 亚洲天堂制服诱惑| 久久亚洲欧洲日本韩国欧美| 亚洲无码久久性爱视频| 精品国产丝袜剧情在线拍| 男女免费下载观看黄色日逼| 最新日韩成人在线| 国产久热情品无码激情| 国产三级理论永久| 國產在視頻線在精品視頻2020| 777AⅤ无码乱码精品| 国产浪潮无码专区不卡| 日本欧美久一道一区二区不卡| 體驗區試看120秒啪啪免費| 為您国产日本精品久久久久| 国产特黄a级毛片无码视频| 天堂种子在线www网资源 | 国产精品无码a∨片在线观看播 | 蜜芽AⅤ色欲Aⅴ浪潮夜夜嗨| 人人爽人人爽人人片A∨| 精品99re66一区三区| 国产一国产二国产三国产 | 亚洲国产中文字幕在线观看| 中文字幕永久精品国产| 中日韩成人免费精品一二三区| 狠狠躁东京热无码专区| 一级婬片120分钟试看| 母亲韩国观看免费完整版| 潮喷失禁大喷水a无码| 女兵人3未删减版在线观看| 黄色免费av电影| 樱花AV在线无码| 香蕉欧美在线观看| 成年在线视频免费观看完整版| 国产精品欧美一区色二区三区 | 一区中文字幕在线欧美| 亞洲成色www久久網站夜月| 免费黄色国产网站| 久久综合精品国产| 国产熟女凹凸视频| 亚洲αvαv天堂αv在线网毛片 | 亚洲AV无码二区三区在线| 亚洲日韩欧美一区久久久我| 美女视频免费永久观看的| 国产在线不卡av最新| 欧美一级A片欧美精品野外| 精品国产高清毛片a| 88国产精品无码一区二区三区| 欧美日韩在线四区| 最新手机日韩av每天更新 | 国产精品一久久久久| 亚洲天堂在线观看不卡视频| 欧美超清视频在线观看| 久久久久无码精品l国产699 | 五月天久久久噜噜噜久久| 處女開苞大合集毛片视频| 宅男入口亚洲一区二区| 一区二区免费视 | 老牛视频国产一区在线观看| 久久久久成人亚洲成人| 欧美日韩在线另类| 亚洲麻豆精品一区二区综合Av| 亚洲日韩天堂AV在线网| 成人最新av网站在线观看| 精国产一级 片内射| 青草伊人久久综在合线亚洲观看 | 国产精品91激情| 草草浮力影视| 欧美日韩在线另类| 少妇人妻无码精品视频app| 久久亚洲AV无码精品狼群| 国产av一级美女毛片| Av在线天堂影院| 无码跟实体娃作爱视频在线| 视色4se影院在线观看| 极品人妻手机视频在线| 精品亚洲免费播放| 久草色在线AⅤ无遮挡性爱| 精品国产一区二区三区AV麻久久久久 | 90后极品粉嫩小泬20p| av精品久久天干久久久逑摩| 久久精品亚洲成在人线熟女| 青青青国产的视频在线播放| 国产黄在线视频免费观看和| 精品99re66一区三区| 少妇人妻无码高清精品| MD短视频传媒免费版怎么下载| 九九热在线免费观看视频 | 狠狠色综合久久| 国产精品福利一区二区亚瑟 | 乱码国产丰满人妻www69| 亚洲欧洲视频网址在线观看| 精品欧美大臿香蕉在线视频| 国内自拍理论片在线播放| 欧美一级免費网站| 988好吊妞的视频这里只有精| 亚洲国产成人av在线播放一本| 国产福利一区二区精品免费| 一级片欧美日韩| 国产一国产二国产三国产| 久久久久无码精品l国产699| 欧美精品口爆一区二区| 久久丝袜精品中文字幕| 十八禁精品福利视频| 首页国产亚洲动漫| 无码少妇综合免费| 青青草视频在线观看| 狠狠色综合久久| 无码中文字幕在线网视频在线| 人妻av乱片aV出轨中文字幕| 久久久久福利午夜视频电影| 性色av成人免费观看国产一区| 久久综合精品国产| 亚洲熟妇无码99精品| 国产三级交换夫妻电影| 国产色婷婷久久久| 日本婬片A片在线看视频| 91高清免费视频| chinavideos真实欧美福利在线观看| 久久久久无码精品l国产699| 久久国产亚洲欧美日韩| 国产精品成熟在线播放| 免费一级无码午夜精品福利| 无码性中文字幕| 亚洲无线码在线| 免费人成激情视频观看| 午夜在线播放网站| 国产一道本无码在线视频播放| 国产主播中文字幕种子链接| 777久久久国产精品| 為您国产日本精品久久久久| 欧美日韩国产丝袜综合首页一区| 东京热不卡免费A∨| 手机看片久久观看免费| 91视频高清完整版| 久久精品国产99国产精2020丨| 午夜福利短视频在线| 70岁熟女熟妇伦Av| 91午夜一区二区| 日本高清动作片www| 亚洲精品国产一区二区精华| 乱码1乱码2美美哒| 毛片国产一区二区三区| 亚洲综合 一区二区三区| 一本大道色卡1卡2卡3| 91香蕉视频ios污下载| 在线观看精品国产大片| 深夜在线电影| 亚州黄色一级电影| 天天看片天天a免费观看| 成人久久毛片免费| 男同gay自慰网站| 最新老熟女AV导航| 亚洲高清无码在线免费观看| AV丝袜脚天堂网无码| 深夜在线观看av| 国产亚洲一级精品电影| 风流老太婆大bbwbbwhd视频| 欧洲日韩免费视频| 东京热无码中文字幕AV专区| 久久狠狠人人综合网址| 综合婷婷久久亚洲| 亚洲日产韩国在线看片| 福利国产免费观看0855影视| 久久夜夜无片无码 | 99久久人妻精品免费一区色| 黄色视频在线观看网址| 在线伦理电影看免费观看网站| 曰本毛片va看到爽不卡| 探花视频国产在线观看免费高清网站| 国产午夜视频在线播放观看| 欧美专区国产专区| 一级a级毛片免费播放| 手机看片久久观看免费| 国偷自产91中文字幕婷婷在线不卡一区二区三区高清 | 潮喷失禁大喷水a无码| 丰满少妇一区二区| 青青河边草免费观看完整版高清 | 久久天天躁夜夜躁狠狠躁2015| h漫在线一区二区成人| 午夜剧场免费无码A片| 日本中文字幕?∨在线观看| 免费久久久久久精品成人欧美大片 | a在亚洲线播放| 91久久精品无码一区二区软件| 一级做a爰片久久毛片人呢| 精品人妻无码...| 亚洲欧美日韩精品变态另类重囗 | 了解最新久久一区二区精品| 在房间打扑克又疼又叫又开心| 国产人成中文字幕| 日韩欧美精品一区二区久久久久| 国产美女高潮抽搐喷出白浆| 国语高潮无遮挡免费看| 青青青青久在线视频免费观看| 亚洲国产精品看片在线观看电影 | 在线观看AV黄网站永久簧| 日产欧美一区二区三区不上| 永久无码免费色网站| 日产国产精品久久久久久| 亚洲簧片在线无码免费| 主人调教憋尿高潮锁| 十八禁精品福利视频| 日韩成人综合久久久| 免费无码刺激性a片完整版| 欧美午夜精品久久久| 熟女欧美日韩国产| 中国91视频日本不卡视频网站| 国产日韩av无码免费播放| 国产农村妇女特级毛片| 亚韩精品中文字幕无码| 久久久77777在人天堂网站| 日本三级字幕| 亚洲熟妇无码99精品| ass中国尤物肉体piCS| 性爱自拍偷拍日韩中文字幕| 日本黄色激情视频网站| 国产乱人在线视频| 色老头在线一区二区三区| 精品亚洲91在线无码播放| 亚洲欧美日韩国产另| 极品人妻手机视频在线| 少妇高潮喷水无码久久影院| 亚洲无码总合另类中文字幕| 日韩欧美精品有码在线播放免费| 激情国语在线一区二区图片| 欧美 日产 国产成人免费| 国产内射爽爽大kbkb日本成年网在线观看 | av中文字幕一区二区| 久久亚洲熟女一区二区| 人妻少妇av无码中文系列| 久久久77777在人天堂网站| 国产精品久久久蜜臀AV| 欧美日韩国产丝袜综合首页一区| 一夲道无码无卡免费视频| 亚洲无人区编码国产激情| 亚洲A∨无码精品色午夜果冻| 亚洲A∨无码精品色午夜果冻 | 天天摸人人澡人人超碰| 日本视频网站在线观看| 国产精品免费观看久久一区| 久久久久久国产综合精品| 人妻少妇nc18嫩草| (凹凸)中文人妻aⅤ高清一区二区 久久99热狠狠色精品一区二区三区 | 亚洲国产成人久久一区AAA| 4480中文字幕乱码私人影院| 日韩免费av一区| 西西4444www大胆无码| 成年人免费色网色网视频| 国产精品午夜啪啪啪| 精品中文乱伦国产| 久久久久久久久久免免费精品 | 国产综合成人亚洲区网站| 亚洲产在线精品亚洲第一站首页| 亚洲熟妇性视频| 一级毛片男女做受| 亚洲一区二区三区四区黄色| 高清无码在线不卡| 女人扒开腿让男人桶到爽免费视频| 白嫩极品女粉嫩喷水视频软件| 亚洲 欧美 日韩 三级| 动漫久久国产视频网站| 91大神在线精品播放| 在线黄色毛片观看| a毛片成人免费看视频| 国产亚洲欧美在线观看精品不卡| 直人实女处被破www免费| ts另类人妖视频一区二区| 日本高清有码一区二区三区 | 国产91高清三级久国产| 亚洲精品欧美精品午夜精品| 一级a级毛片免费播放| 国产专区欧美专区| 久久久午夜精品福利内容| 2022最新在线国产视频| 国产在线不卡视频| 亚洲日韩欧美美女综合热精品| 国产男人吃奶91视频| 成人a一级三级片免费看| 国产熟女精品视频大全| 亚洲精品国产专区91在 | 丰满人妻无码av系列| 青草亚洲国产欧美一区二区| 国产在线不卡爆乳视频| 成在人线?V无码免观看麻豆| 亚洲天堂中文网| 最近的中文字幕免费完整| 在线播放第一页无码| 狼友视频国产精品首页| 成h在线观看免费观看| 影音先锋无码AV片| 女教师波多野结衣高清在线 | 成人中文不卡黑人在线| 人妻少妇精品无码专区二区妖婧| 偷拍亚洲第一成年网站| 蜜桃尤物精品一区二区在线| 中文字幕久精品视频在线观看| 亚洲AV无码精品午夜福利久久| 日本在线一区二区三区直播| 亚洲第一区欧美国产综| 91亚洲精品漫画在线观看| 精品国产?Ⅴ一区二区三区4区| 日本免费久久高清| 八重神子被×哭还不断流东西网站游戏 | 日韩亚无码一区二区三区| 9191成人精品久久| 国产 国语对白 露脸正在播放| 看全色黄大色黄大片毛片| 母亲韩国观看免费完整版| 中文字幕乱码视频91| 99视频国产在线观看播放| 国产大片7777www免费| 色婷婷国产精品综合在线观看 | 免费高清在线视频色seyeye| 草莓视频app污色版| 国产片婬乱一毛片a最熱門最齊全電影! | 欧美精品欧美精品系列| 日本一区二区二区免费国产| 精品日韩欧美久久久久久| 国产成人亚洲综合91精品浪| 被公侵犯漂亮人妻中文字幕| 为你收集色天天天综合网色天天 | 亚洲欧美国产小姐a一级| 国产盗摄91精品一区二区| 97人妻夜夜人妻夜夜爽一区二区 | 国产精品综合香蕉视频| 中文无码 在线 亚洲| 亚洲综合国产在不卡在线首映| 亚洲 欧美 中文 日韩a v一区| 最新国产精品视频综合区| 一区二区无码操逼视频| 亞洲丁香五月天繳情綜合| 国产中文综合久久| 未满十八18禁止午夜免费网站 | 又大又粗又爽A级频片| 国产成人亚洲综合91精品浪| 亚洲伦理电影一区| 国产片婬乱一毛片a最熱門最齊全電影!| 一级a级毛片免费播放| 国产微拍在线观看无码| 污视频在线看| 国产乱码伦精品一区二区三区麻豆| 国产AV秘 无码一区区三区| 日韩主播在线视频一区二区| 国产大胆露出在线视频| 久久午夜福利视频| 污草莓视频免费下载| 精品一区二区三区在线网站| 天天躁日日躁狠狠躁欧美正在播放| 人与动人物a级毛片在线| 最新中文字幕无码视频在线| 国产一区二区在线观看影院| 欧美激情亚洲一区中文字幕| 亚洲av色男人的天堂| 国产伦子伦一级A片在线| 午夜在线播放网站| 97国产精品一区二区视频| a欧美特黄日韩大片免费观看| 国产黑色丝袜视频在线观| 综合高清日本中文| 国产网红视频种子链接| 日韩国产高清在线| 韩国资源国产精品| yy6080午夜国产高清理论| 国产成人三级视频在线播放播 | 在线亚洲精品露出国产区| 99久久国产综合精品国产| 白白高清日本黄色一区二区| 亚洲av美女夜夜| 99久久伊人精品综合| 国内久久婷婷五月综合欲色扒| 偷拍偷窥2019福利视频| 亚洲天堂在线观看不卡视频| 日韩av无码久久精品兔费| 久久久久亚洲av综合| 国产欧美午夜久久| 少妇爆乳无码免费专区| 日韩资源一区二区综合久久| 校园全肉高h湿一女多男| 夜夜躁狠狠躁日日躁孕妇| 性色国产精选在线观看| 亚洲波多野结衣一区二区中出| 國產精品國三級國產AV| 日本久久久久久久久| 国产在线一区不卡| 人阁色第四影院在线观看| 在线视频免费观看a毛片| 久久免费大片日本| 把老太弄高潮好几次| 最新亚洲日本中文字幕| 制服 亚洲 另类| 久久精品无码鲁网| 欧美色精品在线视频| 十八禁网站在线观看免费视频| 免费三级现频在线观看播放| 国产日韩欧美亚洲第一区| 精东传媒app免费地址在哪里| 免费久久久久久精品成人欧美大片| 蜜桃传媒果冻星空传媒视频| 亚洲欧美人高清精品α∨| 国产中文字幕第一页伊人网综合在线视频| 国产午夜精品无码免费不卡影院| 精品三级av无码一区色臀AV| 中文人妻精品一区二区| 中文字幕无码综合在线视频资源站| 久久久噜噜噜久久久白丝袜| 无码性中文字幕| 三级片久久久电影免费| 亚洲午夜大片网站| 久久99欧美激情| 99热精品日韩经典| 国产与丰满岳交尾乱免费视频| 胡桃吃旅行者的坤吧| 国产男女猛烈无遮掩免费观看呢 | 最近更新中文字幕4| 精品日韩欧美久久久久久| 国产欧美一区二区三区激情免费| 久久精品國產2020| 可疑的美容院中文字幕| 亚洲电影av一区二区三区四区| 日韩欧无码一二三区免费不卡| 日本免费人成视频播放120秒| 亚洲av无码近親相姦| 久久精品国产第一区二区三区| 日本一道本在线视频| 国产女人十八毛片水真多| 亚洲va久久久噜噜噜久久一| 国产大学生A片视频播放| 精品一区二区三区在线网站| 5566av资源网影音先锋| 久久久久久影院观看| 一级毛片国产的对白叫床| 久久人人97超碰精品国产| 中文自拍三级国产| 波多野结衣在线播放| 欧美一级特黄淫片在线观看| 一级在线观看黄色片| 中文字幕不卡一区2021| 狠狠躁东京热无码专区| 亚洲av成人福利在线观看| 天堂在线观看免费视频| 97久久久啊啊啊www| 国产愉拍91九色国产愉拍| 免费看美女抠逼软件| 中文字幕高清不卡免费| AV午夜久久蜜桃传媒软件 | 伊人久久大香线蕉免费视频| 五月天影院丰满熟妞区| 日本免费久久高清| 久久蜜桃精品无码一区二区| 久久国产一区二区不卡| 国内精品人妻无码短视频| 久久国产激情| 精品国产欧美精品v| 久久久久久影院观看| 亚洲欧洲中日韩在线观看| 白洁被五个人玩一夜| 欧美日韩特黄一级免费| 青青河边草免费观看完整版高清 | 亚洲亚洲人成网站网址| 在线国产黄色毛片| 老外一级片久久久久久}| 日韩一区二区免费看妖精视频| 澳洲美妇人妻真人无码永久| chinavideos真实欧美福利在线观看| 91熟女精品视频| 成人高清国产在线观看| 美丽姑娘视频在线观看免费高清版| 每日在线更新久草| 國產成人精品午夜視頻| 中文字幕第23頁| 新91精品中综合久久久久| 美女又大又粗又爽一级毛片| 高压监狱满天星美版免费观看 | 疯狂做受XXXX高潮不断| 最近的中文字幕免费完整| 久久久无码精品亚日韩精东传媒| 超国产人碰人摸人爰视频| 国产精品偷伦费看| 歐美精品人人做人人愛視頻| 少妇人妻无码高清精品| 97碰碰碰人妻无码免费看| 日本视频在线观看亚洲免费| 欧美专区亚洲专区日韩专区| 国产微拍精品一在线观看| 亚洲阿v天堂在线| 亚洲av日韩av欧v在线天堂| 操操操五月天婷婷丁香影院| 一级黄色欧美在线免费观看| 久久人人操人人看| 亚洲av天堂一区二区香蕉| 在线看黄网址| 日日摸日日碰夜夜爽无码AV| 亚洲AV无码一区二区三区天| (愛妃視頻)亚洲 欧美 综合 另类 中字| 成人涩涩涩视频在线观看| 磁力链bt磁力种子天堂| 国产精品成人午夜视频| 国产精品亚洲精品影院| 中文字幕高清不卡免费| 手机看片1024免费旧版国产精品久久久久无码av| 国产一国产二国产三国产| 致敬韩寒永久下载地址安卓版| 成人少妇综合视频在线观看| 国产国内三级在线视频| 肉乳床欢无码A片动漫樱花| 538porm国产在线观看| 欧美熟女视频一区| 未满十八18禁止午夜免费网站| 女s调教羞辱女m视频VK| 欧美精品手机在线观看视频| 香蕉欧美在线观看| 无码三级久久中文| 人妻精品视频一区二区三区| 亚洲一区二区国产观看| 中文字幕乱码视频91| 手机看片av永久免费不删除| 亚洲韩日av中文字幕| 免费a级日韩毛片| 国产高潮抽搐喷出白浆精品视频| 亚洲日本中文字幕视频| 少婦人妻互換不帶套| 最新国产·精品更多| 亚洲一区日韩中文字幕| 欧洲AV成人片无码精品| 无码少妇综合免费| 日韩无码免费网址| 无码专区亚洲精| 欧美一级特黄淫片在线观看| 色多多福利网站| 亚洲女同毛片一区二区三区| 草莓成视频人app污片| h漫在线一区二区成人| 欧美日韩在线播放成人| 直人实女处被破www免费| 被强奷很舒服好爽好爽爽| 人人干人人摸日日操| 欧美小视频在线观看| 亚州精品日韩在线视频|