在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何解決zigbee&BLE 模塊最大的不足

AGk5_ZLG_zhiyua ? 來源:未知 ? 作者:劉勇 ? 2017-12-06 06:30 ? 次閱讀

第九章為BLE&zigbee 無線模塊,本文內(nèi)容為9.1 BLE 核心板。

本章導(dǎo)讀

市面上現(xiàn)有zigbee&BLE 模塊最大的不足就是不能很好地支持用戶進(jìn)行二次開發(fā),即便某些模塊能夠?qū)崿F(xiàn)二次開發(fā),卻因?yàn)椴痪邆渫暾能浻布鷳B(tài)鏈和穩(wěn)定可靠的組網(wǎng)協(xié)議軟件。因此用戶還需要花很多時(shí)間學(xué)習(xí)與zigbee&BLE 相關(guān)的知識,非得將自己培養(yǎng)成通曉zigbee&BLE 技術(shù)的專家,才有可能開發(fā)出穩(wěn)定且具有競爭力的產(chǎn)品

其實(shí),人與人之間的差別不在于知識和經(jīng)驗(yàn),而是思維方面的差異決定了每個(gè)人的未來。雖然大多數(shù)開發(fā)者都很勤奮,但其奮斗目標(biāo)不是企業(yè)和個(gè)人收益最大化,而是以學(xué)習(xí)與MCU和zigbee&BLE 相關(guān)的非核心域技術(shù)為樂趣。不愿意與市場人員和用戶交流,不注重提升個(gè)人挖掘用戶需求的創(chuàng)造力,還為自己的錯(cuò)誤行為貼上高大上的標(biāo)簽——一切都在掌握之中。

事實(shí)上,每個(gè)人不可能做到面面俱全,你只是自己所在領(lǐng)域的專家,所以不要將精力用錯(cuò)了地方。以至于很多人在辛辛苦苦奮斗十多年之后,還是找不到失敗的原因時(shí),只是表面地嘆息自己懷才不遇,甚至將失敗的責(zé)任推給他人。這種落后的開發(fā)思維,導(dǎo)致很多企業(yè)無法開發(fā)出具有行業(yè)領(lǐng)先地位產(chǎn)品。

基于此,ZLG 推出了各種功能的MCU+zigbee或BLE 模塊,MCU 包括M0+、M4、ARM9、A7 和A8 內(nèi)核,支持AMetal 和AWorks 平臺。

9.1 BLE 核心板

>>> 9.1.1 產(chǎn)品簡介

AW824BPTBLE 核心板是廣州致遠(yuǎn)電子有限公司基于NXP藍(lán)牙4.0 BLE 芯片和MCU芯片LPC824 開發(fā)的,一款低功耗、高性能,支持二次開發(fā)的藍(lán)牙4.0 BLE 模塊。其中的LPC824 是基于ARM? Cortex?-M0+內(nèi)核設(shè)計(jì)的32 位處理器,30MHz 主頻,32KB 片內(nèi)Flash 和8KB 片內(nèi)SRAM,支持4 種低功耗模式。

如圖9.1 所示的AW824PBT 核心板采用外置天線的封裝、通過半孔工藝將I/O 引出,幫助客戶繞過繁瑣的射頻硬件設(shè)計(jì)、開發(fā)與生產(chǎn),加快產(chǎn)品上市。

圖9.1 AW824BPT 實(shí)物圖

完善的軟件開發(fā)平臺可滿足快速開發(fā)需求,減少軟件投入,縮短研發(fā)周期。該模塊方便迅速橋接電子產(chǎn)品智能移動(dòng)設(shè)備,可廣泛應(yīng)用于有此需求的各種電子設(shè)備,如儀器儀表、健康醫(yī)療、智能家居、運(yùn)動(dòng)計(jì)量、汽車電子和休閑玩具等。

1. 產(chǎn)品特征

  • 32 位ARM? Cortex?-M0+內(nèi)核處理LPC824,32KB 片內(nèi)Flash,8KB 片內(nèi)SRAM;

  • 3 路USART(可分配給任意I/O 管腳),4 路I2C,2 路SPI,12 路ADC,6 路PWM;

  • 支持主從模式,主機(jī)最多連接8 個(gè)從機(jī);

  • 高達(dá)50kbps 數(shù)據(jù)傳輸速率,支持藍(lán)牙4.0;

  • 寬工作電壓2.4~3.6V;

  • 接收靈敏度:-93dBm;

  • 發(fā)射功率:-20dbm~4dbm,通過AT 指令可調(diào);

  • 天線類型:外置天線。

AW824BPT 模塊相關(guān)參數(shù)詳見表9.1。

表9.1 選型表

2. 硬件描述

AW824BPT 無線核心模塊默認(rèn)運(yùn)行在橋接模式(透傳模式)下,模塊啟動(dòng)后會自動(dòng)進(jìn)行廣播,已打開特定 APP 的手機(jī)會對其進(jìn)行掃描和對接,連接成功之后就可以通過 BLE 在模塊和手機(jī)之間進(jìn)行數(shù)據(jù)傳輸。

在橋接模式下,用戶MCU 可以通過模塊的通用串口和移動(dòng)設(shè)備進(jìn)行雙向通訊;用戶也可以通過特定的串口AT 指令,對某些通訊參數(shù)進(jìn)行修改,比如,串口波特率、廣播周期等。AW824BPT 的引腳分布詳見圖9.2,引腳說明詳見表9.2。

表9.2 AW824BPT 引腳說明

圖9.2 AW824BPT 引腳分布

為了便于快速開發(fā),在AW824BPT 內(nèi)部,已經(jīng)固定的將LPC824 的一些引腳(PIO0_16、PIO0_24 ~ PIO0_28)與AW824BPT 中的藍(lán)牙模塊相連接,示意圖詳見圖9.3。

圖9.3 LPC824 與藍(lán)牙模塊連接示意圖

藍(lán)牙模塊相關(guān)的引腳有7 個(gè),但其中5 個(gè)引腳已經(jīng)在AW824BPT 內(nèi)部與LPC824 連接,另外兩個(gè)引腳BLE_LKSLP 和BLE_LKCON 作為藍(lán)牙模塊的輸出信號,直接通過AW824BPT 的1、2 腳引出。藍(lán)牙模塊的相關(guān)引腳簡介詳見表9.3。

表9.3 藍(lán)牙模塊引腳功能描述

特別注意,LPC824 的PIO0_26 和PIO0_27 與藍(lán)牙模塊的串口相連,當(dāng)使用AW824BPT進(jìn)行二次開發(fā)時(shí),需要將LPC824 的PIO0_26 配置為串口TX 功能,PIO0_27 配置為串口的RX 功能。

>>> 9.1.2 協(xié)議說明

AW824BPT 中包含藍(lán)牙模塊,AW824BPT 可以快捷的與其它BLE 設(shè)備(如手機(jī))之間進(jìn)行雙向數(shù)據(jù)通訊。在BLE 的連接過程中,AW824BPT 是從機(jī)設(shè)備,與之連接的其它BLE設(shè)備(如手機(jī))是主機(jī)設(shè)備。

為敘述方便,后文描述時(shí),均假定與AW824BPT 連接的主機(jī)設(shè)備為手機(jī)端。由于BLE屬于藍(lán)牙4.0 的范疇,因此要求手機(jī)的藍(lán)牙模塊是4.0 以上的版本。iPhone4S 及后續(xù)版本的蘋果手機(jī)都支持;Android 手機(jī)則需要4.3.1 以上的版本才能夠支持。

AW824BPT 中藍(lán)牙模塊發(fā)送數(shù)據(jù)的速率理論可達(dá)5.5K byte/s,速率主要與BLE 的連接間隔相關(guān),若 BLE 連接間隔較短,則速率較高,平均功耗也較高;反之,若BLE 連接間隔較長,則數(shù)據(jù)傳輸?shù)乃俾蕰档停瑯悠骄囊矔档汀K{(lán)牙模塊的BLE 連接間隔默認(rèn)值為20ms(最小值),可以使用接口函數(shù)對其進(jìn)行修改,最大支持2000ms。

每個(gè)連接間隔最多傳輸110 個(gè)字節(jié)的數(shù)據(jù),若連接間隔為T(單位:ms),那么每秒最高傳輸速率 V(單位:byte/s)為:V =110*1000 /T (byte s),式中乘以 1000 是由于 T 的單位為ms。顯然,T 值越小,數(shù)據(jù)傳輸速率越高,當(dāng)T 為最小值20ms 時(shí),可得到最高傳輸速率為:

當(dāng)然,這只是理論值,實(shí)際測試表明,轉(zhuǎn)發(fā)速率在4K 以下,丟包率很低,高于4K 時(shí),丟包率將有所提高。但是為了安全起見,無論是低速或者高速轉(zhuǎn)發(fā)大數(shù)據(jù)量應(yīng)用時(shí),都建議在上層做校驗(yàn)重傳處理。

使用藍(lán)牙進(jìn)行數(shù)據(jù)傳輸是雙向的。對于AW824BPT 發(fā)送數(shù)據(jù)至手機(jī)端,其流程是首先通過LPC824 的串口發(fā)送數(shù)據(jù)至藍(lán)牙模塊,然后藍(lán)牙模塊通過BLE 將數(shù)據(jù)轉(zhuǎn)發(fā)至手機(jī)端。這就存在一個(gè)速率匹配的問題。若串口傳輸速率高于BLE 傳輸速率。則數(shù)據(jù)通過串口發(fā)送至藍(lán)牙模塊的速率高,而通過BLE 轉(zhuǎn)發(fā)數(shù)據(jù)的速率低,若數(shù)據(jù)不間斷傳輸,則會導(dǎo)致藍(lán)牙模塊內(nèi)部200 字節(jié)的緩沖區(qū)很快被填滿,使得后續(xù)數(shù)據(jù)不得不丟棄,這種情況下,LPC824通過串口每發(fā)送200 字節(jié)數(shù)據(jù)至藍(lán)牙模塊后,均需要延時(shí)一段時(shí)間,以確保下次發(fā)送數(shù)據(jù)前,藍(lán)牙模塊已經(jīng)通過BLE 完成對數(shù)據(jù)的轉(zhuǎn)發(fā),內(nèi)部有可用空間用于裝載新的數(shù)據(jù)。

同理,對于手機(jī)端發(fā)送數(shù)據(jù)至主控AW824BPT,其流程是首先手機(jī)端通過BLE 發(fā)送數(shù)據(jù)至藍(lán)牙模塊,然后藍(lán)牙模塊通過串口將數(shù)據(jù)發(fā)送至LPC824。若串口傳輸速率低于BLE 傳輸速率。則數(shù)據(jù)通過BLE 發(fā)送至ZLG9021 的速率高,而通過串口轉(zhuǎn)發(fā)數(shù)據(jù)的速率低,也將導(dǎo)致傳輸速率的不匹配。

最理想的情況就是,串口波特率與BLE 數(shù)據(jù)傳輸速率剛好匹配,發(fā)送至藍(lán)牙模塊一個(gè)數(shù)據(jù)的時(shí)間與BLE 轉(zhuǎn)發(fā)一個(gè)數(shù)據(jù)的時(shí)間恰好相等,這樣的話,就不存在速率不匹配的問題了。若BLE 的傳輸速率為5.5K,則平均傳輸一個(gè)數(shù)據(jù)的時(shí)間為:

若串口波特率為baudrate,由于串口使用格式為1 位起始位、8 位數(shù)據(jù)位、無校驗(yàn)位、1位停止位。因此發(fā)送一個(gè)字節(jié)數(shù)據(jù)大約需要傳輸10 位的時(shí)間。即:

UART 傳輸速率與BLE 傳輸速率恰好相等,可以得出:

由此可見,當(dāng)BLE 傳輸速率為5.5K 時(shí),串口波特率為55556 時(shí),可以達(dá)到速率匹配。若波特率高于此值,則UART 傳輸速率高于BLE 傳輸速率。若波特率低于此值,則UART傳輸速率低于BLE 傳輸速率。

實(shí)際上,藍(lán)牙模塊的UART 只支持常見的波特率:4800、9600、19200、38400、57600、115200。因此,若使用AW824BPT 主要是用于發(fā)送大數(shù)據(jù)至手機(jī)端,則UART 傳輸速率應(yīng)該低于BLE 傳輸速率,此時(shí),波特率設(shè)置為38400 較為合適。若使用AW824BPT 主要用于接收來自手機(jī)端的大數(shù)據(jù),則UART 傳輸速率應(yīng)該高于BLE 傳輸速率,此時(shí),波特率設(shè)置為57600 較為合適。一般地,若雙方都有大數(shù)據(jù)傳輸,則確保每發(fā)送200 字節(jié)數(shù)據(jù)之間存在一定的時(shí)間間隔(30 ~ 60ms)即可。

>>> 9.1.3 藍(lán)牙模塊初始化

AMetal 已經(jīng)支持AW824BPT 中的藍(lán)牙模塊,提供了相應(yīng)的驅(qū)動(dòng),可以直接使用相應(yīng)的API 完成藍(lán)牙模塊的配置及數(shù)據(jù)的收發(fā),用戶無需關(guān)心底層的通信協(xié)議,即可快速使用AW824BPT 進(jìn)行BLE 數(shù)據(jù)通信。使用其它各功能函數(shù)前必須先完成初始化,初始化函數(shù)的原型(am_zlg9021.h)為:

其中,p_dev 為指向am_zlg9021_dev_t 類型實(shí)例的指針,p_devinfo 為指向am_zlg9021_devinfo_t 類型實(shí)例信息的指針。

注,AW824BPT 中的藍(lán)牙模塊為ZLG9021,因此,接口使用zlg9021 作為藍(lán)牙模塊驅(qū)動(dòng)的命名空間。對于用戶來講,只需要使用接口進(jìn)行藍(lán)牙相關(guān)的操作即可,無需關(guān)心具體使用的何種藍(lán)牙模塊。

  • 實(shí)例

定義am_zlg9021_dev_t 類型(am_zlg9021.h)實(shí)例如下:

其中,g_zlg9021_dev 為用戶自定義的實(shí)例,其地址作為p_dev 的實(shí)參傳遞。

  • 實(shí)例信息

實(shí)例信息主要描述了與ZLG9021 通信時(shí),與引腳、UART 波特率、緩沖區(qū)等相關(guān)的信息。其類型am_zlg9021_devinfo_t 的定義(am_zlg9021.h)如下:

其中,pin_en、pin_brts、pin_rst、pin_restore 分別表示LPC824 與藍(lán)牙模塊對應(yīng)功能引腳相連接的引腳號,通過圖9.3 可知,pin_en 與PIO0_16 連接,pin_brts 與PIO0_25 連接,pin_rst 與PIO0_28 連接。RESTORE 引腳用于恢復(fù)出廠設(shè)置,AW824BPT 未使用該引腳,pin_restore 的值設(shè)置為-1 即可。

baudrate 表示UART 使用的波特率,ZLG9021 出廠默認(rèn)波特率為9600,對于出廠設(shè)置的模塊,該值必須設(shè)置為9600。初始化完成后,后續(xù)可以使用ZLG9021 控制函數(shù)修改波特率(支持的波特率有:4800、9600、19200、38400、57600、115200)。若修改了波特率,則必須確保下次調(diào)用初始化函數(shù)時(shí),實(shí)例信息中baudrate 的值為修改后的波特率值。

為了提高數(shù)據(jù)處理的效率和確保接收數(shù)據(jù)不會因?yàn)檎谔幚硎聞?wù)而丟失。UART 發(fā)送和接收都需要一個(gè)緩沖區(qū),用于緩存數(shù)據(jù),緩沖區(qū)的實(shí)際大小由用戶根據(jù)實(shí)際情況確定,建議在64 字節(jié)以上,一般設(shè)置為128 字節(jié)。p_uart_rxbuf 和rxbuf_size 描述了接收緩沖區(qū)的首地址和大小,p_uart_txbuf 和txbuf_size 描述了發(fā)送緩沖區(qū)的首地址和大小。如分別定義大小為128 字節(jié)的緩沖區(qū)供發(fā)送和接收使用,定義如下:

其中,g_zlg9021_uart_txbuf[128]為用戶自定義的數(shù)組空間,供發(fā)送使用,充當(dāng)發(fā)送緩沖區(qū),其地址(數(shù)組名g_zlg9021_uart_txbuf 或首元素地址&g_zlg9021_uart_txbuf[0])作為實(shí)例信息中p_uart_txbuf 成員的值,數(shù)組大小(這里為128)作為實(shí)例信息中txbuf_size 成員的值。同理,g_zlg9021_uart_rxbuf[128]充當(dāng)接收緩沖區(qū),其地址作為實(shí)例信息中p_uart_rxbuf成員的值,數(shù)組大小作為實(shí)例信息中rxbuf_size 成員的值。

基于以上信息,實(shí)例信息可以定義如下:

其中,g_zlg9021_devinfo 為用戶自定義的實(shí)例信息,其地址作為p_devinfo 的實(shí)參傳遞。

  • UART 句柄uart_handle

若使用LPC824 的USART2 與ZLG9021 通信,則UART 句柄可以通過LPC82x 的USART1 實(shí)例初始化函數(shù)am_lpc82x_usart2_inst_init()獲得。即:

獲得的UART 句柄即可直接作為uart_handle 的實(shí)參傳遞。

  • 實(shí)例句柄

ZLG9021 初始化函數(shù)am_zlg9021_init()的返回值即為ZLG9021 實(shí)例的句柄。該句柄將作為其它功能接口函數(shù)的handle 參數(shù)的實(shí)參。

其類型am_zlg9021_handle_t(am_zlg9021.h)定義如下:

若返回值為NULL,說明初始化失敗;若返回值不為NULL,說明返回了一個(gè)有效的handle。基于模塊化編程思想,將初始化相關(guān)的實(shí)例、實(shí)例信息等的定義存放到ZLG9021的配置文件(am_hwconf_zlg9021.c)中,通過頭文件(am_hwconf_zlg9021.h)引出實(shí)例初始化函數(shù)接口,源文件和頭文件的程序范例分別詳見程序清單9.1 和程序清單9.2。

程序清單9.1 ZLG9021 實(shí)例初始化函數(shù)實(shí)現(xiàn)(am_hwconf_zlg9021.c)

程序清單9.2 ZLG9021 實(shí)例初始化函數(shù)聲明(am_hwconf_zlg9021.h)

后續(xù)只需要使用無參數(shù)的實(shí)例初始化函數(shù)即可獲取到ZLG9021 的實(shí)例句柄。即:

>>> 9.1.4 藍(lán)牙模塊控制接口

ZLG9021 控制接口用于控制ZLG9021,完成所有與ZLG9021 相關(guān)的控制,如參數(shù)設(shè)置、參數(shù)獲取、軟件復(fù)位等。其函數(shù)原型(am_zlg9021.h)為:

其中,cmd 用于指定控制命令,不同的命令對應(yīng)不同的操作。p_arg 為與命令對應(yīng)的參數(shù)。當(dāng)命令不同時(shí),對應(yīng)p_arg 的類型可能不同,因此,這里p_arg 使用的類型為 void *,其實(shí)際類型應(yīng)該與命令指定的類型一致。常見命令(am_zlg9021.h)及命令對應(yīng)的p_arg 類型詳見表9.4。

表9.4 支持的命令及命令對應(yīng)的p_arg 類型

有些命令無需參數(shù)(表中p_arg 類型標(biāo)識為“—”),如復(fù)位模塊命令。此時(shí),調(diào)用am_zlg9021_ioctl ()函數(shù)時(shí),只需將p_arg 的值設(shè)置為NULL 即可。帶“*”的類型表示指針類型。若函數(shù)返回值為AM_OK,表示操作成功,否則表示操作失敗。

雖然控制命令較多,看似使用起來較為復(fù)雜,但由于在絕大部分應(yīng)用場合下,默認(rèn)值即可正常工作,因此,若無特殊需求,可以直接使用讀寫數(shù)據(jù)接口完成“透傳數(shù)據(jù)”的發(fā)送和接收。一般地,也僅可能使用少量命令完成一些特殊應(yīng)用需求。下面詳細(xì)介紹各個(gè)命令的使用方法。

1. 設(shè)置/獲取BLE 連接間隔

模塊與手機(jī)相連時(shí),會定時(shí)進(jìn)行同步,保證手機(jī)與模塊一直處于連接狀態(tài),且數(shù)據(jù)交互操作也是在同步的時(shí)候進(jìn)行的。若 BLE 連接間隔較短,則速率較高,平均功耗也教高;反之,若BLE 連接間隔較長,則數(shù)據(jù)傳輸?shù)乃俾蕰档停瑯悠骄囊矔档汀?/p>

連接間隔的單位為ms,有效值有:20、50、100、200、300、400、500、1000、1500、2000,出廠默認(rèn)值為20,即最小時(shí)間間隔。

如設(shè)置連接間隔為50ms,范例程序詳見程序清單9.3。注意,設(shè)置連接間隔后掉電會丟失,并且連接間隔的修改只有在重新連接后才生效。

程序清單9.3 設(shè)置BLE 連接間隔范例程序

連接間隔設(shè)置成功與否主要取決于手機(jī)端對連接間隔的限制。不同手機(jī)的實(shí)際連接間隔也可能不同,如魅族手機(jī)的實(shí)際連接間隔會比設(shè)定值少25%左右;iPhone 手機(jī)在連接時(shí)均是先以30ms 間隔運(yùn)行1 分鐘,然后切換成設(shè)定值。

可以通過命令獲取當(dāng)前的連接間隔,范例程序詳見程序清單9.4。

程序清單9.4 獲取BLE 連接間隔范例程序

程序執(zhí)行結(jié)束后,interval_ms 的值即為當(dāng)前使用的連接間隔。若使用程序清單9.3 所示的代碼修改了時(shí)間間隔,則此處獲取的值應(yīng)該為50。

2. 模塊重命名/獲取模塊名

模塊名即手機(jī)端發(fā)現(xiàn)ZLG9021 時(shí),顯示的ZLG9021 模塊的名字。模塊名限定在15 字節(jié)以內(nèi)。如修改模塊名為“ZLGBLE”,范例程序詳見程序清單9.5。注意,修改模塊名后,掉電不會丟失。

程序清單9.5 模塊重命名范例程序

修改模塊名為“ZLGBLE”后,手機(jī)端發(fā)現(xiàn)ZLG9021 時(shí),將顯示其名字為“ZLGBLE”。顯然,當(dāng)使用ZLG9021 開發(fā)實(shí)際產(chǎn)品時(shí),在同一應(yīng)用場合,可能存在多個(gè)ZLG9021 模塊,若全部命名為“ZLGBLE”,將不容易區(qū)分具體的ZLG9021 模塊。此時(shí),可以使用自動(dòng)添加MAC 后綴的模塊重命名命令,使用方法與AM_ZLG9021_RENAME 相同,范例程序詳見程序清單9.6。

程序清單9.6 模塊重命名(自動(dòng)添加MAC 后綴)范例程序

使用該命令修改模塊名后,會自動(dòng)添加6 個(gè)字符(MAC 地址后3 個(gè)字節(jié)的Hex 碼),若ZLG9021 模塊的MAC 地址為:08:7C:BE:CA:A5:5E,則重命名后,ZLG9021 的模塊名被設(shè)置為“ZLGBLECAA55E”。可以通過命令獲取當(dāng)前的模塊名,范例程序詳見程序清單9.7。

程序清單9.7 獲取ZLG9021 模塊名范例程序

程序中,由于模塊名的最大長度為15 字符,為了存放'

主站蜘蛛池模板: 精品国产高清在线看国产| 欧美破处视频在线| 五月亭亭六月丁香| 88av视频在线| 国产三片高清在线观看| 久久国产乱子伦精品免费一| 又粗又硬又爽又黄毛片| 日韩毛片高清在线看| 三级特黄视频| 五月情婷婷| 三级网址在线播放| 免费看成年视频网页| 激情五月婷婷基地| 毛片网在线| 国产亚洲视频在线| 两性午夜欧美高清做性| 四虎影库网址| 国产精品自线在线播放| 中文字幕色婷婷在线精品中| 亚洲a视频| 一级特黄aa大片免费播放视频 | 五月婷婷婷| 日韩精品免费一区二区三区| 免费国产黄网站在线观看视频| 黄色精品| 我色综合| 4虎影院在线观看| 天天综合网站| 97se亚洲综合| 黄网站在线观看| 色窝视频| 色婷婷激婷婷深爱五月小说| 天天鲁天天爽天天视频| 午夜在线视频国产| 欧美色视频网站| 国产偷窥女洗浴在线观看亚洲| 夜夜精品视频| 亚洲第一视频网| 干天天| 久艹精品| 亚洲免费网站在线观看|