《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 嵌入式實時操作系統μC/OS-II在S12單片機上的移植
嵌入式實時操作系統μC/OS-II在S12單片機上的移植
摘要: 本文介紹嵌入式實時操作系μC/OS-II在飛思卡爾16位單片機MC9S12DG128上的移植過程。首先對MC9S12DG128的體系結構和存儲器組織進行了分析,然后詳細論述了μC/OS-II移植過程中的難點和關鍵問題,最終實現了移植過程。對移植結果進行了測試實驗,并驗證了移植代碼的正確性。
Abstract:
Key words :

1 引言

    在采用前后臺系統軟件設計模式的嵌入式系統中,主程序是一個無限循環,單任務順序執行,通過設置一個或多個中斷來處理異步事件。這種系統對于簡單的應用是可以的,但對于實時性要求比較高的、處理任務較多的應用,就會暴露出實時性差、系統可靠性低、穩定性差等缺點。μC/OS-II 是一個源代碼公開、可移植、可裁剪的實時多任務操作系統,具有低成本、穩定可靠、實時性好等優點,是專門針對微處理器和微控制器設計的實時內核,它的內核可以做到很小,很適合在單片機系統上移植。移植了μC/OS-II 的嵌入式系統可以使各個任務獨立工作,互不干涉,很容易實現準時而且無誤執行,使實時應用程序的設計和擴展變得容易,使應用程序的設計過程大為減化。

     本文選用飛思卡爾(Freescale)公司的16 位單片機S12DG128" title="MC9S12DG128" target="_blank">MC9S12DG128 作為硬件平臺,針對MC9S12DG128 的存儲器組織和體系結構,對μC/OS-II 源代碼作了相應的改寫,最終實現了μC/OS-II 操作系統在MC9S12DG128 上的移植。通過μC/OS-II 在MC9S12DG128 上的移植,可以掌握移植和測試μC/OS-II 的實質內容,同時也很容易將其移植到其它的CPU 平臺上。

2 MC9S12DG128 的體系結構(存儲器的組織)

    作者認為深刻理解MC9S12DG128 微控制器的體系結構和存儲器組織是移植成功的一個關鍵步驟。MC9S12DG128 是16 位的高性能單片機,它具有極低的電源功耗和可高達25MHz 的內部總線頻率,片內資源包括1KB 的內部寄存器、8KB RAM、128KB FLASH、2KBEEPROM。MC9S12DG128 采用普林斯頓總線結構,程序存儲器、數據存儲器和I/O 端口為統一編址方式,總的尋址空間為64 KB,但DG128 內部有128KB Flash,顯然存儲空間超過了S12MCU 可尋址的64KB 空間,因此引入了頁面訪問機制,S12CPU 在內存的$8000~$BFFF 這一段開了一個窗口,這里有8 個16KB 的頁面(其中$3E 和$3F 有固定地址),可以通過頁面寄存器(PPAGE)選擇其中的一頁。對于64KB 以外的存儲區,應用專用指令CALL 調用子程序,然后通過RTC 指令返回。

    微控制器內部不同的存儲器占用不同的存儲空間,也就是說,不同的地址范圍,它們均占據特定的地址空間,這些存儲器和內部集成模塊的地址分配并不是固定不變的,用戶自己可以重新分配,但建不要輕易改動默認的映射空間,應直接采用默認地址映射空間。圖1 是MC9S12DGl28 復位后的內存空間分配情況。其中,地址$0000~$03FF 為1KB 寄存器空間; $0000~$1FFF 為8KB RAM(可見7KB);$0000~$07FF 為2KBEEPROM(不可見)。

 

 

圖1 MC9S12DGl28 復位后的內存空間分布情況

可以通過設置INITRG,INITRM,INIteE 寄存器來重新分配各存儲器的位置。這些寄存器只能寫一次,建議在初始化時分配存儲器的位置。如果映射出現地址重疊時,S12CPU 內部的優先級控制邏輯會自動屏蔽級別較低的資源,保留級別最高的資源。寄存器具有最高優先級,與其重疊的RAM 和EEPROM 此時無效。存儲器的優先級如下表所列。

3 μC/OS-II 在MC9S12DG128 上的移植

μC/OS-II 運行時要占用一部分ROM 和RAM 空間,但μC/OS-II 操作系統內核目標代碼最小可以裁剪到小于2KB,MC9S12DG128 有8KB 的RAM 存儲器和128KB 的Flash 存儲器,所以μC/OS-II 操作系統完全可以移植并運行在MC9S12DG128 上。

μC/OS-II 的95%代碼是由ANSI C 寫成的,具有很好的移植性。要實現μC/OS-II向S12 的移植,主要是做兩方面的工作,一是重新定義內核的大小和功能;二是為內核編寫與硬件相關的代碼。μC/OS-II 的文件結構如圖2 所示。

 

 

圖2 μC/OS-II 的文件結構

可以看到,μC/OS-II 與CPU 類型無關的C 代碼文件包括很多文件,它們是μC/OS-II的內核和很多功能函數,其中OS_CORE.C、OS_TIME.C 和OS_TASK.C 這三個文件是一定要用的,其他幾個文件用于任務間通信,應用程序中可能只用到其中的幾個,不用的可以不包含進去,以避免編譯時生成沒有代碼。這部分代碼與CPU 類型無關,在移植時,這些文件一個也不要動。

與CPU 類型有關的代碼文件主要有:OS_CFG.H、OS_CPU.H、OS_CPU_A.ASM 和OS_CPUC.C。OS_CFG.H 是配置文件,需要根據應用配置,主要作用是確定用戶應用程序使用μC/OS-II 提供的哪些系統功能函數,這個文件移植時要修改。OS_CPU.H 文件定義用于特定CPU 的數據類型、定義相關的宏。OS_CPU_A.ASM 是用匯編語言寫的硬件有關的代碼,OS_CPUC.C 文件是用C 語言寫的與硬件有關的代碼。如果移植使用的C 交叉編譯工具在C 代碼中可以插入匯編語句,那么在移植中,可以將OS_CPU_A.ASM 合到S_CPUC.C文件中。

3.1 重新定義內核的大小和功能

公共頭文件INCLUDES.H,這個文件會被所有的C 源程序引用。在本例中此文件的代碼如下。

#include

#include

#include

#include

#include

#include

#include

前四個頭文件是C 函數庫、預定義的類型等,和移植沒有關系,是否一定要加取決于所用的編譯器。后三個頭文件必須被引用,用戶可以添加自己的頭文件,但一定要放

在最后面。

需要根據應用修改的文件是OS_CFG.H,這個文件用于配置內核的屬性。用于設置與微控制器CPU 核心相關的屬性,包括各種數據類型對應的存儲長度等等。OS_CPU.H 包括了用#define 語句定義的、與處理器相關的常數、宏及類型等。因為不同的處理器有不同的字長,所以μC/OS-II 的移植包括的一系列數據類型定義,以確保其可移植性。μC/OS-II 代碼不使用語言中的short,int,及long 等數據類型,因為它們是與編譯器相關的,是不可移植的。采用定義的整形數據結構等既是可移植的,又很直觀。

typedef unsigned char BOOLEAN; /* 布爾變量*/

typedef unsigned char INT8U; /* 無符號8 位整型變量*/

typedef signed char INT8S; /* 有符號8 位整型變量 */

typedef unsigned int INT16U; /* 無符號16 位整型變量*/

typedef signed int INT16S; /* 有符號16 位整型變量*/

……

用戶還必須將任務堆棧的數據類型告訴給μC/OS-II。S12CPU 的是堆棧是16 位的,所以定義OS_STK 為INT16U。所有的任務堆棧都必須用OS_STK 來聲明數據類型。

#define OS_STK INT16U /* 堆棧是16 位寬度*/

對于不同的處理器而言,數據入堆棧時堆棧指針的增長方向也是不一樣的,MC9S12DG128 單片機的堆棧指針是由高地址向低地址增長的,所以,要預先設定堆棧的

增長方向:

#define OS_STK_GROWTH 1 /*堆棧指針由高地址向低地址增長*/

μC/OS-II 需要先禁止中斷再訪問代碼的臨界段,并且在訪問完畢后重新允許中斷。這就使得μC/OS-II 能夠保護臨界段代碼免受多任務或中斷服務例程的破壞。禁止和允

許中斷的宏是OS_ENTER_CRITICAL()和OS_EXIT_CRITICAL(),定義這兩個宏的有三種方法,移植時采用的是方法1,進入臨界代碼前關中斷,脫離臨界代碼后開中斷[2]。方法1在OS_CPU.H 中是這樣定義的:

#if OS_CRITICAL_METHOD == 1 //方法一

#define OS_ENTER_CRITICAL( ) asm SEI

#defien OS_EXIT_CRITICAL () asm CLI

#endif

3.2 編寫與硬件相關的代碼

接下來需要編寫與硬件相關的代碼。這部分代碼可以用C 語言,也可以用匯編語言。移植中與硬件相關的文件中最主要的是OS_CPU_C.C 和匯編文件OS_CPU_A.ASM。由于移植使用的是Metrowerks 公司提供的CodeWarrior CW12 V4.6 版本的C 交叉編譯工具,而CW12 V4.6 允許在C 代碼中插入匯編語句,所以可以把OS_CPU_A.ASM 這個文件合并到OS_CPU_C.C 文件中去。以下是具體的移植過程。

3.2.1 中斷服務子程序OSTickISR()

中斷服務子程序所使用的中斷可以用實時時鐘產生,也可以用單片機片內的定時器模塊來產生。本次移植采用的是用模數計數器產生精確時鐘節拍中斷,用S12 的模數計數器可以實現任意時間的精確中斷,這里的中斷為每秒30 次。

時鐘節拍中斷發生時,CPU12 會自動CPU 把CPU 寄存器推入堆棧,然后是清中斷標志。但是頁面寄存器PPAGE 并沒有被推入堆棧,如果CPU12 的尋址范圍超過了64KB,則要把PPAGE 也推入堆棧,本文中沒有用到PPAGE 寄存器。

時鐘節拍中斷服務子程序可能激活一個優先級高于當前被中斷任務的優先級的任務。時鐘節拍中斷服務子程序要連續調用:OSIntEnter()、OSTimerTick()和OSIntExit()這三個函數。OSIntEnter()通知μC/OS-II 進入中斷服務子程序了。OSTimerTick()給要求延遲若干時鐘節拍的任務延遲計數器減1,減1 后為0 則該任務進入就緒態。

OSIntExit()函數告訴μC/OS-II 時鐘節拍中斷服務子程序結束了,如果這時有更高優先級的任務進入了就緒態,OSIntExit()就會調用中斷級的任務切換函數OSIntCtxSw()做任務切換,以便讓更高的優先級的任務運行。以下是函數代碼:

void OSTickISR(void)

{

/*根據需要決定是否保存PPAGE 寄存器,此處沒有保存*/

OSIntEnter();

MCFLG_MCZF=1; //清除模計數器中斷標志位

OSTimeTick();

OSIntExit(); //退出中斷并進行任務切換

}

3.2.2 任務堆棧初始化函數OSTaskStkInit()

這個C語言寫的函數是與CPU硬件相關的。這個函數初始化任務的堆棧,由建立任務的函數OSTaskCreate()或擴展的建立任務函數OSTaskCreatExit()調用。建立任務的函數帶有4個形式參數,擴展的建立任務的函數有8個參數。其中pdata用于向任務傳遞參數。利用了這個參數將頁面寄存器PPAGE 參數傳給建立的任務。在改寫該函數的時候一定要深刻了解S12CPU在中斷發生時各個CPU寄存器的入棧的順序,否則,μC/OS-II是運行不起來的。中斷發生時S12CPU各個寄存器入棧的順序如圖3所示。由于該函數是被建立任務的函數所調用的,所以各個CPU寄存器的初始值并不重要。但要CCR寄存器的內容需要注意:如果選擇任務啟動后允許中斷發生,則所有的任務運行期間中斷都允許;同樣,如果選擇任務啟動后禁止中斷,則所有的任務都禁止中斷發生,而不能有所選擇。本文選擇在任務啟動時開啟中斷。以下是函數代碼:

void *OSTaskStkInit (void (*task)(void *pd), void *pdata, void *ptos, INT16U opt)

{

INT16U *stk;

pt = opt; // 'opt'未使用,此處可防止編譯器的警告

stk = (INT16U *)ptos; //載入堆棧指針

*--stk = (INT16U)(pdata); //放置向函數傳遞的參數pdata

*--stk = (INT16U)(task); //函數返回地址PC

*--stk = (INT16U)(0x1122); //寄存器 Y

*--stk = (INT16U)(0x3344); //寄存器 X

((INT8U *)stk)--; // 寄存器A 僅需要1 個字節

*(INT8U *)stk = (INT8U)(0x55); //寄存器 A

((INT8U *)stk)--; // 寄存器B 僅需要1 個字節

*(INT8U *)stk = (INT8U)(0x66); //寄存器 B

((INT8U *)stk)--; // 寄存器CCR 僅需要1 個字節

*(INT8U *)stk = (INT8U)(0x00); //寄存器 CCR,開中斷

return ((void *)stk);

}

3.2.3 讓優先級最高的就緒態任務開始運行OSStartHightRdy()

OSStartHighRdy()是在多任務啟動時被OSStart()調用的,μC/OS-II 做完所有的初始化工作之后,OSStart()就啟動運行多任務,而OSStart()調用OSStartHighRdy()函數運行多個就緒任務中優先級最高的任務。注意,堆棧指針總是儲存在任務控制塊的開頭。

 

 

圖3 中斷發生時S12CPU寄存器入棧的順序

OSStartHighRdy()將CPU 的堆棧指針SP 的值,改成優先級最高的就緒態任務的堆棧指針的值,然后將該任務的狀態字由非運行態“FALSE”,改為運行態“TRUE”,然后執行中斷返回指令RTI 以開始運行這個任務。以下是詳細代碼:

void OSStartHighRdy(void)

{

OSTaskSwHook(); //調用鉤子函數

asm{

ldx OSTCBCur // 加載OSTCBCur 的地址到 x

lds 0,x //把OSTCBStrPtr 載入堆棧指針 sp

ldaa OSRunning

inca // SRunning = TRUE

staa OSRunning

rti

}

}

3.2.4 任務級任務切換函數OSCtxSw()和中斷級任務切換函數OSIntCtxSw()

任務級的切換是通過執行軟中斷指令來實現的。OSCtxSw()實際上就是軟中斷服務子程序,軟中斷服務子程序的向量地址指向OSCtxSw()。如果當前任務調用μC/OS-II提供的功能函數,并使更高優先級任務進入了就緒狀態,則μC/OS-II 就會借助上面提到的向量地址找到OSCtxSw()。在系統服務調用的最后,μC/OS-II 會調用任務調度函數OSSched(),并由此推斷出當前任務不再是需要運行的最重要的任務。

OSIntCtxSw()函數中的絕大多數代碼同OS_TASK_SW()函數是一樣的。而中斷退出函數則是通過函數OSIntCtxSw()來從ISR 中執行切換功能,區別只是因為ISR 已經保存了CPU 的寄存器,而不再需要在OSIntCtxSw()函數中保存CPU 的寄存器。以下只給出任務級任務切換函數OSCtxSw()的代碼:

void OSCtxSw(void)

{

asm{

ldx OSTCBCur // 加載當前任務的堆棧指針

sts 0,x // 保存到當前任務的TCB 中

}

OSTaskSwHook(); //調用鉤子函數

STCBCur = OSTCBHighRdy; // 改變任務的 OSTCBCur 和OSPrioCur

SPrioCur = OSPrioHighRdy;

asm{

ldx OSTCBCur // 得到新任務的堆棧指針

lds 0,x // 加載新任務的堆棧指針到 sp

rti

}

}

4 移植代碼的測試

為了驗證移植結果是否正確,對移植后μC/OS-II 代碼進行了測試,這是移植中很重要的一個環節。首先對內核自身的運行情況進行了測試,待內核自身的運行正常工作后,又創建三個任務:任務1 通過PORTA 口點亮LED 燈,該任務每秒運行一次;任務2和任務3 都通過串輸出字符串,這兩個任務都是每2 秒運行一次,并通過信號量來實現互斥,以使得每個任務每次運行時均可完成所有字符的輸出。實驗測試證明在μC/OS-II管理與調度下,使得這三個任務都能正確、可靠地相繼運行。

5 小結

通過μC/OS-II在MC9S12DG128上的移植,加深了對μC/OS-II內核工作原理和任務調度實現方法的理解,掌握了μC/OS-II移植的一般方法,測試結果表明移植代碼可以穩定可靠的運行,實現了多任務的管理和調度。μC/OS-II實時操作系統的引入,不但可以提高系統的實時性、可靠性和穩定性,還提高了應用軟件的可移植性,降低了開發人員的工作量。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          亚洲风情在线资源站| 国产精品www.| 黄色成人免费观看| 国产综合视频在线观看| 亚洲综合另类| 国产精品久久久久久亚洲毛片| 国产精品亚洲一区二区三区在线| 久久精品91久久久久久再现| 一区二区三区自拍| 黄色亚洲大片免费在线观看| 一区二区三区在线视频免费观看| 欧美午夜一区二区三区免费大片| 国产在线高清精品| 国产专区欧美精品| 欧美激情国产精品| 国外精品视频| 欧美成人精品激情在线观看| 欧美精品不卡| 国产日韩在线亚洲字幕中文| 亚洲激情视频在线| 亚洲九九精品| 国模精品一区二区三区色天香| 亚洲国产天堂久久综合网| 亚洲国产日韩一级| 国产中文一区二区三区| 欧美午夜www高清视频| 久久午夜av| 亚洲国产美女| 国产精品久久久久影院色老大| 久久免费视频网站| 欧美色精品天天在线观看视频| 99www免费人成精品| 亚洲嫩草精品久久| 亚洲自啪免费| 欧美午夜精品电影| 亚洲精选中文字幕| aa国产精品| 久久久久久久久伊人| 欧美午夜精品理论片a级按摩| 国产一区二区欧美日韩| 在线观看福利一区| 欧美巨乳在线| 国产精品欧美精品| 欧美另类极品videosbest最新版本| 亚洲人成网站色ww在线| 午夜在线视频一区二区区别| **网站欧美大片在线观看| 久久综合久久综合久久综合| 亚洲一区二区三区四区视频| 亚洲一区在线观看免费观看电影高清| 香蕉免费一区二区三区在线观看| 亚洲伦理在线| 国产精品视频九色porn| 欧美日韩精品一区二区| 欧美视频在线不卡| 欧美麻豆久久久久久中文| 久久aⅴ国产欧美74aaa| 亚洲欧美在线免费| 久久久久久久网站| 亚洲在线免费观看| 久久久综合免费视频| 欧美日韩精品一区视频| 亚洲激情女人| 久久久久久色| 欧美日韩在线不卡一区| 欧美激情视频一区二区三区在线播放| 欧美午夜精品伦理| 亚洲欧洲一级| 在线观看一区二区精品视频| 国模叶桐国产精品一区| 欧美精品一区二区三| 欧美韩国日本一区| 99国产精品私拍| 亚洲欧美日本视频在线观看| 免费视频最近日韩| 久久综合伊人77777| 国产毛片一区| 国产日韩欧美在线一区| 国产精品欧美一区二区三区奶水| 99热精品在线观看| 午夜精品婷婷| 国产一区二区剧情av在线| 欧美.日韩.国产.一区.二区| 国产欧美精品在线播放| 国产精品你懂的在线| 国产精品久久久久久模特| 欧美一区二粉嫩精品国产一线天| 久久久久国内| 国产资源精品在线观看| av不卡在线| 国产精品久久久一区二区三区| 日韩一二三在线视频播| 欧美午夜视频在线| 国产一区二区在线观看免费| 欧美日韩午夜剧场| 亚洲影院色无极综合| 国产亚洲亚洲| 久久国产66| 午夜精品一区二区三区电影天堂| 久久婷婷国产麻豆91天堂| 欧美色视频在线| 一区二区三区视频观看| 久久美女艺术照精彩视频福利播放| 午夜视频在线观看一区二区三区| 一区二区三区欧美在线观看| 亚洲人成毛片在线播放女女| 欧美激情二区三区| 亚洲欧美日韩精品久久亚洲区| 欧美日韩综合在线| 亚洲精品视频啊美女在线直播| 国产精品免费aⅴ片在线观看| 午夜精品剧场| 中日韩在线视频| 狠狠色综合日日| 欧美日本在线| 亚洲美女免费精品视频在线观看| 国产精品久久99| 久久久人成影片一区二区三区观看| 亚洲男人天堂2024| 国产精品永久免费观看| 国产美女精品视频| 久久精品国产第一区二区三区| 欧美精品粉嫩高潮一区二区| 欧美三级视频在线观看| 亚洲最新合集| 欧美日本精品| 欧美大片免费观看在线观看网站推荐| 在线日韩中文| 欧美成人福利视频| 国产乱肥老妇国产一区二| 亚洲夜间福利| 久久狠狠久久综合桃花| 激情六月婷婷久久| 欧美在线|欧美| 宅男噜噜噜66国产日韩在线观看| 激情成人综合网| 亚洲精品综合精品自拍| 亚洲一区在线观看视频| 欧美午夜精品一区二区三区| 久久精品一区二区三区四区| 亚洲第一色中文字幕| 国产精品久久久久久久第一福利| 欧美在线观看天堂一区二区三区| 99国内精品久久| 麻豆国产精品va在线观看不卡| 亚洲综合社区| 午夜久久黄色| 99这里只有久久精品视频| 国产精品人成在线观看免费| 日韩视频永久免费| 欧美日韩精品中文字幕| 亚洲欧美精品在线| 99pao成人国产永久免费视频| 国产精品ⅴa在线观看h| 国产在线视频欧美| 韩国三级电影一区二区| 欧美日产一区二区三区在线观看| 久久免费视频一区| 欧美黄色大片网站| 亚洲日本成人| 欧美日本不卡高清| 欧美在线日韩在线| 在线欧美一区| 欧美亚洲成人免费| 国产伦精品一区二区三区高清| 久久精品国产99| 在线观看一区二区视频| 欧美丰满少妇xxxbbb| 久久三级福利| 国产亚洲欧美日韩一区二区| 亚洲制服丝袜在线| 国产精品久久久久免费a∨大胸| 久热这里只精品99re8久| 久久久精品免费视频| 另类图片综合电影| 美女尤物久久精品| 国产午夜一区二区三区| 亚洲人妖在线| 国产欧美一区二区视频| 国产精品一国产精品k频道56| 国产精品卡一卡二| 欧美在线综合视频| 亚洲影视在线| 欧美电影在线播放| 欧美成人情趣视频| 国产日韩欧美中文在线播放| 国产精品久久波多野结衣| 亚洲欧美日韩综合| 激情久久久久久久| 欧美日韩福利在线观看| 国产综合在线看| 欧美一区二区私人影院日本| 西瓜成人精品人成网站| 中文亚洲字幕| 国产精品大片wwwwww| 亚洲午夜在线观看| 怡红院精品视频在线观看极品| 亚洲国产天堂久久综合网| 欧美日韩免费观看中文| 亚洲美女中文字幕| 国产精品久久久久久久久久尿| 亚洲精品网址在线观看| 一区二区日韩免费看| 亚洲美女中文字幕| 亚洲影视中文字幕| 夜夜嗨av色一区二区不卡| 欧美日韩成人在线播放| 在线观看成人小视频| 亚洲黄色成人网| 欧美一乱一性一交一视频| 午夜精品www| 久久手机免费观看| 久久久久久自在自线| 国产精品日韩专区| 国产精品区一区二区三区| 欧美日在线观看| 亚洲精品中文在线| 欧美激情中文字幕在线| 国产一区二区日韩| 亚洲免费不卡| 国产精品麻豆va在线播放| 国产精品日本| 黄色一区二区三区四区| 99re在线精品| 国产日韩精品视频一区二区三区| 欧美性一二三区| 亚洲每日更新| 在线观看视频一区| 免费一区二区三区| 国内精品**久久毛片app| 欧美日韩第一区| 国产精品高潮呻吟久久av无限| 国产婷婷色一区二区三区四区| 国产精品久久久久aaaa樱花| 久久综合网hezyo| 欧美涩涩视频| 亚洲精品乱码久久久久| 欧美日韩999| 亚洲一区在线播放| 欧美中文字幕| 在线一区免费观看| 亚洲欧洲视频| 久久精品国产99国产精品澳门| 国产日韩欧美不卡在线| 亚洲激情中文1区| 国产精品普通话对白| 久久国产日韩欧美| 另类尿喷潮videofree| 久久国产乱子精品免费女| 国产日韩精品一区二区三区| 国产亚洲精品综合一区91| 久久综合给合| 欧美另类专区| 亚洲欧美乱综合| 亚洲日本一区二区| 欧美大片免费观看| 午夜国产精品影院在线观看| 伊人影院久久| 免费国产自线拍一欧美视频| 日韩午夜激情av| 一区二区三区日韩欧美精品| 开元免费观看欧美电视剧网站| 中文无字幕一区二区三区| 99精品热视频只有精品10| 美女在线一区二区| 国产视频精品va久久久久久| 伊甸园精品99久久久久久| 亚洲高清视频在线| 99亚洲伊人久久精品影院红桃| 欧美在现视频| 欧美在线观看一二区| 国产日韩精品视频一区| 国内伊人久久久久久网站视频| 午夜日韩福利| 先锋影音国产一区| 久久精品免费电影| 亚洲性视频网站| 极品日韩久久| 亚洲人成毛片在线播放| 国产亚洲成精品久久| 激情婷婷欧美| 欧美一区二区三区在线观看| 午夜视频在线观看一区| 欧美一区二区三区在线观看| 国产精品欧美一区二区三区奶水| 国产视频精品xxxx| 国产日韩视频| 欧美日本免费一区二区三区| 国产精品男女猛烈高潮激情| 国产精品久久久久9999| 欧美一区二区三区精品| 在线成人h网| 亚洲国产欧美国产综合一区| 久久成人这里只有精品| 一区二区三区免费在线观看| 欧美国产日韩精品免费观看| 国产一区二区三区四区hd| 国产精品嫩草影院av蜜臀| 国产精品一区二区三区成人| 国产日韩在线亚洲字幕中文| 欧美日韩精品二区第二页| 欧美日韩极品在线观看一区| 欧美色123| 在线播放国产一区中文字幕剧情欧美| 欧美亚洲视频在线看网址| 欧美一级大片在线免费观看| 欧美国产激情| 激情成人中文字幕| 亚洲无玛一区| 久久久久久成人| 欧美日韩精品三区| 亚洲电影免费| 久久亚洲私人国产精品va媚药| 国产性色一区二区| 欧美在线你懂的| 久久久久久久综合狠狠综合| 亚洲欧美一区二区视频| 欧美在线免费播放| 国产在线乱码一区二区三区| 91久久夜色精品国产九色| 久久婷婷麻豆| 羞羞答答国产精品www一本| 欧美电影在线免费观看网站| 国产精品狠色婷| aa国产精品| 亚洲欧美网站| 欧美日韩在线精品一区二区三区| 亚洲国产天堂久久综合网|