《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > μC/OS-II在ARM平臺上移植的深入探討
μC/OS-II在ARM平臺上移植的深入探討
來源:微型機與應用2010年第12期
王琨強, 趙志珩
(汽車管理學院 基礎部, 蚌埠 233011)
摘要: 在以S3C2410處理器的嵌入式平臺上,把經典的vivi啟動代碼與μC/OS-II操作系統結合在一起,探討了μC/OS-II的移植實現,尤其詳述了在ARM處理器ISR中斷模式下如何實現斷點數據保護的方法。利用該方法,可以將一般ARM系統的啟動代碼同μC/OS-II操作系統融合起來,對于μC/OS-II操作系統在ARM平臺的推廣和μC/OS-II操作系統的研究都很有意義。
Abstract:
Key words :

摘   要: 在以S3C2410處理器的嵌入式平臺上,把經典的vivi啟動代碼與μC/OS-II操作系統結合在一起,探討了μC/OS-II的移植實現,尤其詳述了在ARM處理器ISR中斷模式下如何實現斷點數據保護的方法。利用該方法,可以將一般ARM系統的啟動代碼同μC/OS-II操作系統融合起來,對于μC/OS-II操作系統在ARM平臺的推廣和μC/OS-II操作系統的研究都很有意義。
關鍵詞: 嵌入式操作系統; μC/OS-II; ARM; S3C2410

    μC/OS-II在ARM平臺的移植是一個重要的學習過程,有助于提高對RTOS的認識與理解,從而提高嵌入式工作者的理論與技術水平。μC/OS-II是一個小的實時內核,源代碼公開,有詳盡的解釋。正是因為其內核小,才便于研究、理解和掌握。另外,參照TCP/IP協議、標準和一些公開的圖書,在μC/OS-II上增加TCP/IP協議棧,藍牙通信軟件、紅外通信協議也十分方便,商業價值得到了認可。
    隨著科技的發展,嵌入式應用的復雜性越來越高,同時ARM體系處理器的價格越來越低,ARM平臺 + 實時操作系統的架構體系的使用會越來越廣泛。有鑒于此,本文對μC/OS-II在ARM平臺下的移植進行了深入探討。
1 操作系統μC/OS-II及S3C2410開發平臺簡介
1.1 μC/OS-II簡介

    μC/OS最早出自于1992年美國嵌入式系統專家Jean J.Labrosse在《嵌入式系統編程》雜志5月和6月上刊登的文章連載,并把μC/OS的源代碼發表在該雜志的BBS上。μC/OS-II是目前最新的版本。
 μC/OS-II是專門為計算機的嵌入式應用而設計的,絕大部分代碼用C語言編寫。CPU的相關部分采用匯編語言編寫,總量在200行左右的匯編語言被壓縮到最低限度,目的是便于移植到任何一種其他的CPU上去。μC/OS-II具有執行效率高、占用空間小、實時性優良、可擴展等特點,最小內核可編譯至2 KB。μC/OS-II可移植到幾乎所有知名的CPU上。
1.2 μC/OS-II的組成
    嚴格地說μC/OS-II只是一個實時操作系統內核,它僅僅包含了任務調度、任務管理、時間管理、內存管理和任務間的通信和同步等基本功能。沒有提出輸入輸出管理、文件系統、網絡通信等額外的服務。但由于μC/OS-II良好的可擴展性和源代碼開放,這些非必須的功能完全可以由用戶根據自己的需要分別實現。
    μC/OS-II可以大致分成核心、任務處理、時間處理、任務同步與通信、CPU的移植等5個部分[1]。
    (1)核心部分(OSCore.c):操作系統的處理核心,包括操作系統的初始化、操作系統運行、中斷進出的前導、時鐘節拍、任務調度、事件處理等多部分。
    (2)任務處理部分(OSTask.c):與任務操作密切相關的部分。包括任務的建立、刪除、掛起、恢復等等。
    (3)時鐘部分(OSTime.c):μC/OS-II中最小的時鐘單位是timetick(時鐘節拍)。任務延時等操作在此完成。
    (4)任務同步和通信部分:為事件處理部分,包括信號量、郵箱、郵箱隊列、事件標志等部分,主要用于任務間的相互聯系和對臨界資源的訪問。
    (5)與CPU的接口部分:這里是指μC/OS-II針對所使用的CPU需要改寫的部分。由于μC/OS-II是一個通用性的操作系統,其開放的源代碼是以X86內核為例而編寫的,在應用到其他處理器平臺上時,這部分代碼必須做相應的改變。
1.3 ARM硬件開發平臺簡介
    調試時所用的硬件開發平臺是一款基于三星S3C2410A芯片的開發平臺。S3C2410開發板是一款通用的ARM9開發板,其基本配置采用三星公司的S3C2410 ARM920T芯片,主頻203 MHz。集成有SDRAM控制器、NAND Flash控制器、SD讀卡器、USB Host和USB Device控制器、LCD控制器、I2C總線控制器、SPI總線接口等。開發板上Flash空間為32 MB,SDRAM容量為128 MB。
2 S3C2410引導程序
    開發板原有引導程序由VIVI公司提供,其運行過程分成兩個階段。第一階段的代碼用匯編語言編程,主要完成以下任務: (1)初始化CPU速度、存儲器、存儲器配置寄存器,以及串口等硬件資源的配置;(2)建立內存空間的映射圖,將系統的軟硬件環境帶到合適的狀態,為最終調用操作系統內核做準備; (3)裝載操作系統映像到內存中;(4)設置相關寄存器和資源,跳轉到main()函數,進入第二階段。
    第二階段的代碼用C語言編寫,從main()函數開始,主要工作有:開發板外部接口初始化(I/O接口、UART接口、LCD接口等)、內存映射和內存管理單元初始化等,最后啟動linux內核。有大量文章對此開發板引導程序作了詳細的分析[3],本文在這里不做重復,本文的重點是將引導程序與μC/OS-II操作系統二者融合,既利用了開發板源代碼提供的關于UART口、LCD和觸摸屏接口程序;時鐘、內存管理等豐富的驅動程序和接口程序,又成功地完成了對μC/OS-II實時操作系統的移植和整合。
3 移植要點
  μC/OS-II的內核分成2個部分,與處理器無關的代碼和與處理器有關的代碼。移植過程中需要根據S3C2410處理器和ADSV1.2開發平臺(這里特地強調編譯平臺的因素,主要考慮到各個編譯平臺對數據格式的理解略有差別)的特點來重新編寫3個文件,用C語言編寫的OS_CPU.H、OS_CPU_C.C和用匯編語言編寫的OS_CPU_A.ASM,此外,要將S3C2410開發板引導程序和μC/OS-II內核程序融合在一起,還必須將各自main()函數融為一體。
3.1 OS_CPU.H的移植
    μC/OS-II內核中OS_CPU.H代碼是根據X86內核而寫的,其中的數據格式定義與ARM9內核以及ADSv1.2開發平臺不完全相符。OS_CPU.H的移植分為以下4個部分:
    (1)數據類型定義:在調試時發現,雖然定義8 bit或16 bit數據類型時,在編譯過程中不會報錯,但這些變量并不會按要求被正確初始化或賦值,運行過程常常出錯。所以,在改寫OS_CPU.H代碼時,將所有變量都定義成32 bit或64 bit;
    (2)堆棧生長方向定義:ARM的堆棧是從上往下生長的,OS_STK_GROWTH定義為1;
    (3)開關中斷的宏定義:用開關中斷的匯編函數實現,放在OS_CPU_A.ASM文件中。
    (4)宏定義OS_TASK_SW():這個宏定義是在ARM中斷處理之外時,μC/OS-II從低優先級切換到高優先級任務時所調用的代碼,它總是在任務級代碼中被調用。在有些資料中[1],將OS_TASK_SW()和OSIntCtxSw()等同起來,這在ARM內核中是不行的,因為后者是ARM內核在中斷模式下的任務切換函數,而不同模式下處理器的寄存器組是不同的,所要保護的寄存器內容也不相同,經過調試,發現以下代碼可達到目的。
OS_TASK_SW    
    stmfd    sp!, {lr}                         ; PC入棧,lr其實是任務的返回地址,
    stmfd    sp!, {r0-r12, lr}
    mrs        r4,  cpsr
    stmfd    sp!, {r4}                     ;最后保存CPSR        ldr        r4, =OSTCBCur
    ldr        r5, [r4]
    str        sp, [r5]                      ;將SP保存在當前任務的控制塊中        ldr    r5, =OSTCBHighRdy
    ldr        r5, [r5]
    str        r5, [r4]                       ;OSTCBCur = OSTCBHighRdy        ldr    r6, =OSPrioHighRdy
    ldr        r6, [r6]
    ldr        r4, =OSPrioCur
    str        r6, [r4]                       ;OSPrioCur = OSPrioHighRdy
    ldr        sp, [r5]                    ;得到新任務的堆棧指針
    ldr        r4, [sp], #4        
    msr        cpsr_cxsf, r4                            ;先恢復CPSR
    ldmfd    sp!, {r0-r12, lr, pc}
3.2  OS_CPU_C.C.H的移植
    在OS_CPU_C.C中,最主要的函數是OSTaskStkInit(),它在任務建立時,用來初始化任務堆棧結構,其余鉤子函數可以不用動,這個函數的代碼比較簡單[2]。需要說明的是,由于本文所述系統,用戶任務運行在SVC模式下,沒有保存SPSR寄存器。
3.3 OS_CPU_A.ASM的移植
    OS_CPU_A.ASM文件的匯編程序是μC/OS-II移植工程的重點和難點。它通常包括OSStartHighRdy()、OSIntCtxSw()、OSTickISR()和開關中斷代碼等。其中,OSStartHighRdy()的主要工作是將優先級最高任務對應的所有寄存器按順序從任務堆棧中恢復出來,其代碼簡單[2]。對于開關中斷函數,在調試時所用代碼如下:
EnterCritical   
    mrs    r1, cpsr
    str    r1, [r0]
    orr    r1, r1, #NOINT
    msr    cpsr_cxsf, r1        
    mov pc, lr    
ExitCritical
    ldr    r1, [r0]
    msr    cpsr_cxsf, r1    
    mov pc, lr    
    需要指出的是,在每次成對調用這兩個函數時,需要提前聲明變量r,代碼如下所示:
    INT32U          r;
    EnterCritical(&r);
    ExitCritical(&r);
    需要慎重對待的是OSIntCtxSw()、OSTickISR()函數。在調試時發現,用一般參考資料所介紹的代碼都無法實現多任務的正常運行,其主要原因是,對ARM9內核而言,其每種特定的中斷返回,都有特定的返回指令,在中斷處理過程中,強制使用模式切換指令,使處理器的中斷處理機制發生混亂,程序無法正常執行。例如在ISR模式中使用指令:
 MSR CPSR_c, #(NO_INT | SVC32_MODE)
其目的是返回ISR發生之前的模式,然后保存一些寄存器。但調試時發現,在上述指令執行之后,處理器重新響應ISR中斷,并沒有順序執行,而是立即回到ISR模式下。
 還有,對于S3C2410的ARM920T內核而言,其ISR模式的返回指令是:
    ldmfd    sp!, {r0-r12, lr}
    subs        pc, lr, #04
其他任何形式的指令都無法使處理器正確返回。有些資料用下述指令:
    Ldmfd  sp!, {r0-r12, lr,pc}; 執行之前堆棧中相應存儲單元的內容為(lr-4)。
 看起來與前面的兩行代碼意義相同,但后面的代碼僅僅讓處理器實現PC指針的跳轉,而無法實現處理器的模式轉換,即從ISR模式回到中斷發生之前的模式。
 但在中斷發生時,無法在中斷處理過程中保存所有的處理器寄存器。例如,在ISR模式下,無法保存SVC模式的LR寄存器等。為了解決這個問題,本文采取了如圖1所示的框圖結構來編寫中斷處理代碼和OSIntCtxSw()函數。


 因為S3C2410在進入ISR模式后,自動屏蔽ISR中斷,所以粗存在中斷嵌套,可以表明2個全部變量ISR_LR和ISR_SPSR用于保存ISR中斷發生之時處理器的lr和spsr寄存器。其代碼的特別之處在于,在ISR中斷處理過程中通過修改lr寄存器,而使處理器在退出ISR模式時能根據任務的需要返回至ISR中斷發生之處或者代碼指定地點。在代碼指定地點,可以保存上次中斷發生時被中斷任務的處理器的所有寄存器數據。這里需要注意一點,當處理器退出ISR模式時跳轉到Saveregister處開始執行命令,需要提前將Saveregister處的地址加上4,然后賦值給lr寄存器。因為在ISR退出時,需要將lr減去4再賦值給程序計數器pc。
4 S3C2410啟動代碼和μC/OS-II的融合
 本文1.1節已經介紹過,S3C2410的啟動代碼開始部分是匯編語言的初始化過程,然后跳轉到main()函數。融合的工作就從改造S3C2410的main()函數和μC/OS-II的main()函數(在test.c中)開始。在S3C2410的main()函數中,保留原啟動代碼中關于端口、內存、外部設備初始化代碼,刪去跳轉到Linux操作系統的代碼;在μC/OS-II的test.c文件的main()函數中,刪去一切與X86內核有關的初始化代碼和輸入輸出函數代碼(因為這部分代碼在S3C2410的啟動代碼中已經實現),并將與 μC/OS-II內核有關的3個函數OSInit()、OSTaskCreate(…)、OSStart()復制到S3C2410的main()函數中,同時刪去μC/OS-II的test.c文件。融合后的main()函數主要代碼如下:
 ChangeClockDivider(1, 1);                           //1:2:4
      ChangeMPllValue(161,3,1);             //FCLK=203.0 MHz
      SetClockDivider(1, 1);
      SetSysFclk(FCLK_203M);
      Port_Init();
      Isr_Init();
      Uart_Init(0, 115200);
      Uart_Select(0);    
      MMU_Init();                                         //MMU 初始化
     EnableModuleClock(CLOCK_ALL);    
      rMISCCR &= ~(0x3007);
    OSInit(); 
    OSTaskCreate(TaskStart,……, 0); 
      OSStart();               
    至此,處理器已執行完S3C2410的啟動代碼,并開始執行μC/OS-II內核代碼。當然,要實現多任務,處理器的中斷必須是打開的。這個工作在OSStart ()函數中完成,在執行OSStartHighRdy之前,要按照系統的需求完成處理器的中斷初始化工作,同時打開中斷。至此,融合工作基本完成,剩下的工作就是按照系統的需求在μC/OS-II的TaskStart(…)函數中自由添加實際工作所需的任務了。
    在本文所述系統中,在μC/OS-II所帶3個系統任務的基礎上添加了3個任務Task1、Task2和Task3,方法是在OSStatInit( )之前添加OSTaskCreate(Task1,…)等代碼,然后按下述格式和自己的需求編寫Task1、Task2和Task3函數。代碼為:
    void    Task1(void *data)
  {
          while(1)    { ;任務代碼    }
  }
    因篇幅所限,無法詳述在融合過程中遇到的所有問題,尤其是在ADSv1.2環境下編譯、調試過程出現的語法問題和各種細節問題。
    隨著科技的發展和實際任務復雜性的逐步增加,傳統的單片機前后臺編程模式漸漸不能滿足實際應用的要求。在嵌入式應用開發中使用嵌入式操作系統已經成為一種趨勢,本文在S3C2410開發板上將原有的引導程序和μC/OS-II操作系統結合在一起,開發出能自引導的μC/OS-II操作系統,該系統除了3個系統任務外,還自帶3個實際任務,在ADSV1.2環境下編譯、調試,并在板卡上成功運行,對μC/OS-II在ARM平臺上的移植有一定借鑒意義。
參考文獻
[1]     任哲,潘樹林,房紅征,編著.嵌入式操作系統基礎 μC/OS-II和Linux[M].北京:北京航空航天大學出版社,
2007.
[2]     韓山,郭云,付海艷,編著.ARM微處理器應用開發技術詳解與實例分析[M].北京:清華大學出版社,2007:284-286.
[3]     蔣維. 基于ARM S3C2410嵌入式系統的Bootloader分析與設計[J].電子工程師,2008(10).

此內容為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>
          久久狠狠亚洲综合| 欧美二区视频| 亚洲黄色成人久久久| 99精品热6080yy久久| 99在线精品观看| 亚洲女同在线| 欧美国产欧美亚洲国产日韩mv天天看完整| 久久久91精品国产一区二区精品| 欧美暴力喷水在线| 日韩午夜免费视频| 日韩视频在线一区| 国产亚洲精品一区二555| 欧美专区在线播放| 亚洲乱码视频| 久久精品人人做人人爽| 欧美一区二区三区免费观看| 国产一区av在线| 国产精品magnet| 99精品欧美一区二区蜜桃免费| 狂野欧美激情性xxxx| 亚洲精品一区二区网址| 国产精品美女一区二区| 一区在线免费观看| 国产区精品视频| 免费精品视频| 国内精品美女av在线播放| 亚洲无线一线二线三线区别av| 亚洲视频精品在线| 久久精品水蜜桃av综合天堂| 日韩视频欧美视频| 欧美一区永久视频免费观看| 午夜在线观看欧美| 一区二区三区三区在线| 亚洲黑丝在线| 亚洲欧美日韩综合aⅴ视频| 黑人巨大精品欧美一区二区小视频| 午夜在线播放视频欧美| 欧美激情精品久久久久久黑人| 蜜桃av一区| 亚洲在线第一页| 蜜桃伊人久久| 国产毛片精品视频| 亚洲午夜精品久久久久久app| 欧美精品观看| 欧美午夜精品久久久久久人妖| 欧美巨乳在线观看| 亚洲一二三区在线| 国产精品chinese| 亚洲破处大片| 久久精品国产一区二区三| 亚洲国产一成人久久精品| 亚洲理论在线观看| 亚洲欧洲99久久| aa成人免费视频| 久久伊人亚洲| 欧美经典一区二区| 国产精品xxxav免费视频| 久久国产福利国产秒拍| 亚洲在线观看免费| 欧美激情亚洲视频| 久久阴道视频| 在线亚洲一区观看| 亚洲国产网站| 亚洲少妇一区| 欧美区二区三区| 久久av免费一区| 欧美日韩免费一区二区三区| 欧美另类变人与禽xxxxx| 激情久久影院| 国产一区二区精品久久91| 欧美一区二视频| 欧美屁股在线| 久久国产加勒比精品无码| 蜜桃久久精品乱码一区二区| 欧美激情日韩| 欧美日韩国产不卡| 老司机67194精品线观看| 亚洲男人av电影| 欧美亚洲综合网| 国产日韩精品综合网站| 亚洲大胆视频| 蜜臀av性久久久久蜜臀aⅴ| 欧美精品九九99久久| 韩日午夜在线资源一区二区| 久久久在线视频| 亚洲第一福利在线观看| 欧美视频在线观看免费网址| 欧美第十八页| 国产精品三级久久久久久电影| 国产欧美一区二区精品仙草咪| 激情文学一区| 欧美理论在线| 亚洲日韩视频| 国产在线精品一区二区夜色| 国产精品永久免费观看| 亚洲精一区二区三区| 亚洲国产一成人久久精品| 国产精品扒开腿做爽爽爽软件| 久久久久国产精品午夜一区| 亚洲人成网在线播放| 亚洲视频一区在线| 一区二区三区日韩欧美| 国产一区二区三区精品久久久| 黄网站免费久久| 欧美日韩成人在线| 亚洲电影中文字幕| 国产日韩综合一区二区性色av| 亚洲国产成人高清精品| 国产综合欧美在线看| 一区二区不卡在线视频 午夜欧美不卡在| 久久婷婷成人综合色| 麻豆亚洲精品| 国产日韩欧美视频| 亚洲伊人伊色伊影伊综合网| 国产人久久人人人人爽| 久久国产精品网站| 久久全国免费视频| 国产精品一区二区三区久久久| 欧美jizzhd精品欧美巨大免费| 欧美涩涩网站| 国产日韩亚洲欧美精品| 美国成人毛片| 亚洲综合色丁香婷婷六月图片| 欧美精品一区二区视频| 欧美性猛交xxxx乱大交蜜桃| 欧美日韩中文字幕日韩欧美| 日韩天堂在线观看| 亚洲伦理在线| 亚洲欧美另类中文字幕| 欧美a级一区| 美女国内精品自产拍在线播放| 欧美福利网址| 欧美日韩国产91| 亚洲激情成人| 久久精品国产v日韩v亚洲| 国产精品伦理| 欧美精品九九99久久| 国产精品毛片a∨一区二区三区|国| 亚洲美女在线视频| 欧美日韩在线观看一区二区| 亚洲精选视频免费看| 麻豆精品一区二区av白丝在线| 亚洲老司机av| 亚洲午夜小视频| 99成人精品| 国产亚洲观看| 欧美一区二区三区免费在线看| 欧美成人精品在线观看| 欧美视频在线观看免费网址| 国产日韩欧美一二三区| 亚洲少妇自拍| 欧美v亚洲v综合ⅴ国产v| 久久青草福利网站| 欧美三级日本三级少妇99| 老牛嫩草一区二区三区日本| 欧美一区三区三区高中清蜜桃| 久久高清福利视频| 日韩午夜中文字幕| 欧美风情在线| 国产欧美日韩另类一区| 在线观看成人网| 久久久久久久综合日本| 亚洲一级二级在线| 亚洲精品久久久久| 国产精品v日韩精品v欧美精品网站| 亚洲一区二区免费| 久久综合999| 欧美aⅴ99久久黑人专区| aa成人免费视频| 欧美一级视频免费在线观看| 欧美成人有码| 尤物精品在线| 国产精品日韩欧美大师| 国产字幕视频一区二区| 亚洲高清一区二区三区| 久久国产精品72免费观看| 亚洲高清色综合| 欧美一区二区黄| 久久女同精品一区二区| 欧美精品一区二区高清在线观看| 午夜欧美大片免费观看| 香蕉av777xxx色综合一区| 欧美日韩在线不卡一区| 欧美性做爰毛片| 亚洲电影自拍| 久久婷婷国产麻豆91天堂| 国产精品午夜在线观看| 欧美日韩国产综合网| 亚洲精品小视频| 亚洲一区二区三区精品动漫| 欧美看片网站| 亚洲最新合集| 国产精品免费看片| 久久精品99| 中国成人亚色综合网站| 一区二区三区精品| 在线亚洲精品福利网址导航| 久久综合五月| 欧美美女bbbb| 国产精品入口麻豆原神| 国产一区二区三区四区五区美女| 欧美日韩一级片在线观看| 国产精品久久久久久久久搜平片| 亚洲精品乱码久久久久| 亚洲国产精品久久久久| 国产精品乱码妇女bbbb| 欧美亚州韩日在线看免费版国语版| 在线观看91精品国产入口| av成人手机在线| 久久爱91午夜羞羞| 欧美色网一区二区| 伊人久久综合| 亚洲国产va精品久久久不卡综合| 亚洲在线视频免费观看| 一本色道久久综合狠狠躁篇的优点| 亚洲高清一区二| 久久精品欧美日韩| 亚洲综合视频在线| 激情成人综合网| 欧美综合第一页| 国产精品久久久久久久浪潮网站| 欧美电影免费观看网站| 国产欧美日韩视频一区二区| 欧美视频在线观看 亚洲欧| 欧美freesex8一10精品| 国产精品一区二区久久久| 亚洲高清视频在线观看| 9色porny自拍视频一区二区| 欧美日韩日本网| 欧美成人综合一区| 亚洲欧洲精品一区二区三区| 国内精品久久久久久久影视蜜臀| 亚洲国产精品悠悠久久琪琪| 美脚丝袜一区二区三区在线观看| 好吊视频一区二区三区四区| 亚洲一区二区三区成人在线视频精品| 久久综合五月| 亚洲欧美卡通另类91av| 国产精品多人| 欧美xart系列在线观看| 亚洲麻豆国产自偷在线| 性欧美18~19sex高清播放| 久久亚洲视频| 国产精品视频xxxx| 国产精品无码永久免费888| 久久精品国产亚洲aⅴ| 午夜精品久久久久久99热| 毛片一区二区三区| 国产日产欧产精品推荐色| 一区一区视频| 国产精品影音先锋| 亚洲高清不卡一区| 99精品久久久| 欧美刺激性大交免费视频| 日韩视频一区二区三区在线播放| 久久久国产精品一区二区三区| 午夜精品美女久久久久av福利| 亚洲国产一区二区三区在线播| 国产日韩亚洲欧美综合| 洋洋av久久久久久久一区| 国产欧美日韩专区发布| 免费观看成人www动漫视频| 亚洲国产综合在线| 久热精品视频在线免费观看| 亚洲欧美国产精品桃花| 在线视频日韩| 99在线视频精品| 伊人久久噜噜噜躁狠狠躁| 99视频一区| 久久精品免费观看| 伊人成人开心激情综合网| 久久国产毛片| 老司机久久99久久精品播放免费| 国产精品高清免费在线观看| 国产精品美女久久久久aⅴ国产馆| 亚洲免费精品| 农村妇女精品| 欧美一区亚洲| 国产综合色精品一区二区三区| 狂野欧美一区| 欧美激情一区二区三区蜜桃视频| 91久久在线视频| 久久夜色精品国产欧美乱| 香蕉精品999视频一区二区| 一区二区三区久久久| 欧美成人精品一区| 国产精品你懂得| 国产伦精品一区二区三区视频黑人| 亚洲欧美在线一区| 亚洲日韩欧美视频| 久久久久国产精品厨房| 亚洲一区二区免费视频| 亚洲一区综合| 久久精品一区二区三区不卡牛牛| 香蕉av福利精品导航| 牛牛精品成人免费视频| 国内精品久久久久影院薰衣草| 国产欧美一区二区三区另类精品| 国产一区二区三区视频在线观看| 国产欧美91| 欧美日韩视频第一区| 国产精品二区二区三区| 国产精品人人做人人爽| 久久久999精品视频| 国产精品成人国产乱一区| 国内精品久久久久久久影视麻豆| 国产精品第一区| 国产精品99久久久久久久女警| 欧美另类高清视频在线| 韩国一区电影| 久久精品国产一区二区三区| 国产啪精品视频| 欧美日韩第一区| 久久久久国产精品午夜一区| 欧美一区成人| 国产精品久久国产精麻豆99网站| 老**午夜毛片一区二区三区| 亚洲女同在线| 一区二区国产精品| 国产日韩欧美不卡| 欧美一区二区视频在线观看| 国产日韩欧美不卡在线| 欧美亚洲成人精品| 在线综合亚洲欧美在线视频| 毛片基地黄久久久久久天堂| 欧美日韩在线播放三区| 久久久久久久久久久久久久一区| 久久久久国产精品一区三寸|