《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > ’C5402 DSP自舉引導方法的分析與研究

’C5402 DSP自舉引導方法的分析與研究

2009-02-23
作者:陳麗安

  摘?要: 介紹’C5402 DSP芯片幾種自舉引導方法的特點,對最常用的并行自舉引導方式進行了深入的分析及研究,并通過實例說明建立自舉表的步驟及應注意的問題。?

  關鍵詞: 數字信號處理器(DSP)? 自舉引導? 并行引導?

?

  在DSP領域,TI公司(德州儀器公司)一直處于世界霸主地位,它生產的TMS320系列DSP芯片以其獨特的哈佛結構、硬件密集型方案和靈活的指令系統成為數字信號處理器產業中的領先者[1]。其C5000系列DSP芯片具有功耗小、高度并行等優點,可以滿足眾多領域的實時處理要求。尤其是新近推出的TMS320VC5402及 TMS320UC5402(簡稱’C5402)以其獨有的高性能、低功耗及低價位等優勢,在推出之初便受到業界人士的普遍歡迎。?

  為充分利用DSP快速運行的優點,通常希望用戶程序能在DSP中高速運行,這就需要運用DSP自舉引導功能。本文以’C5402為例,說明自舉引導的特點及自舉表建立的步驟。?

1 幾種自舉引導方式?

1.1 自舉引導方式簡介?

  眾所周知,欲獲得全速的DSP運行速度,方法之一是在DSP芯片出廠前將用戶程序掩膜在其片內的ROM上。這種方法對大部分應用場合并不適用,且成本很高。對大多數用戶而言,可行的方法是利用DSP自舉引導功能。?

  Bootlooader(自舉引導程序,也稱引導裝載程序)是在出廠前固化在DSP芯片內ROM中的一段程序代碼,其主要功能是在上電或復位時將用戶程序從外部加載至程序存儲器(片內RAM或擴展的RAM)中,以便實現高速運行。因此,用這種方法可以以較低的成本實現高速運行。不同型號的DSP,其Bootlooader也不同。如TMS320C54X系列的DSP提供了四種自舉引導方法[2]:并行EPROM、并行I/O口、串行口及主機接口HPI自舉引導方式,它們適用于不同的應用場合。?

1.2? ’C5402 DSP自舉引導方式?

  新近推出的’C5402 DSP片內ROM掩膜的Bootlooader程序與TMS320C54X系列的其它DSP有較大的不同,它包括以下五種自舉引導方式:主機接口HPI、并行口、標準串行口、8位串行EEPROM及I/O口自舉引導方式。?

  DSP上電復位后,首先檢查其MP/引腳,如果該引腳為高電平,說明DSP被設置為微處理器工作方式,即從外部程序存儲器0FF80h地址開始執行用戶程序;若該引腳為低電平,說明DSP被設置為微計算機工作方式,即從片內ROM的0FF80h起執行程序?!疌5402 DSP片內4K ROM掩膜了TI設計的幾段程序,其中包括自舉引導程序,具體內容如表1所示[3]。因此,為利用自舉引導功能,必須將DSP設置為微計算機工作方式,即MP/=0。?

  由表1可見,從片內ROM的0FF80h地址開始存放的是中斷向量表,它實為一條分支轉移指令(BD 0F800h)。該指令使程序跳轉至0F800h,并從此開始執行自舉引導程序。?

  在執行自舉引導搬移程序之前,首先進行初始化,其程序片段如下:?

0000:F800 ?

  SSBX??? INTM???????; INTM=1,使中斷失效?

  STM #0FFFFh,IFR?? ; 清除IFR標志 ?

  LD? #0h,DP????????; DP=0,數據存儲器頁指針為0?

  ORM #02B00h,ST1?? ; XF=INTM=OVM=SXM=1?

  ORM #020h,PMST????; OVLY=1?

  STM #07FFFh,SWWSR ; SWWSR=07FFFh?

  STM #07Dh,SP????? ; SP=07Dh?

  從以上程序可看出,初始化的內容主要包括:?

 ?、訇P閉所有可屏蔽中斷(INTM=1);?

  ②將片內DARAM映射至程序/數據存儲空間(OVLY=1);?

 ?、蹖⒊绦颉祿癐/O存儲空間均設置為7個等待狀態(SWWSR=07FFFh)。?

  初始化完成后,根據外部設定的條件,選擇不同的自舉引導方式,判斷條件是有先后順序的,其流程如圖1所示。

?

?

  圖1中各種自舉引導方式各有特點[3]:?

 ?、僦鳈C接口HPI自舉引導方式?

  欲執行的程序代碼通過HPI(主機接口總線)由外部主處理器加載至片內存儲器中。一旦主處理器改變了被加載代碼的起始地址(存放于內存007Fh處),便開始執行程序。?

 ?、?位串行EEPROM自舉引導方式?

  自舉引導程序通過一串聯的EEPROM讀取自舉表,并按照自舉表中指定的方式加載代碼。該EEPROM與設置為clockstop模式的多通道緩沖串口McBSP1相連接。?

  ③并行自舉引導方式?

  自舉引導程序通過外部并行接口總線讀取存放于數據存儲空間中的自舉表。自舉表的內容包括:欲加載的各段代碼、各代碼段長度、各代碼段存放的目標地址、程序入口地址及其它配置信息。?

 ?、軜藴蚀锌谧耘e引導方式?

  自舉引導程序通過被設置為標準模式的多通道緩沖串口McBSP0讀取自舉表,并按照自舉表中指定的方式加載代碼。McBSP0及McBSP1分別支持16位及8位串行接收方式。?

 ?、軮/O自舉引導方式?

  自舉引導程序通過外部并行接口總線從地址為0h的I/O口讀取自舉表。該外部并行接口總線使用了異步握手協議(利用XF及BIO引腳),使數據傳輸速度可按外部設備的要求設置。?

2 并行自舉引導方式?

  在’C5402的五種自舉引導方式中,并行自舉引導方式是最常用的一種。欲加載的各代碼段存放在字寬為8位或16位的外部存儲器中,在自舉引導時,通過外部并行接口總線將這些代碼從數據存儲空間傳送到程序存儲空間。?

  在并行引導方式中,由于可重新設置SWWSR及BSCR寄存器的內容,所以當從快速的外部存儲器EEPROM引導用戶程序時,可采用較少的軟件等待狀態(默認為7個等待狀態)。?

  并行自舉引導方式流程圖如圖2所示。從圖2可知,自舉表首地址既可從地址為0FFFFh的I/O口讀取,也可從地址為0FFFFh的數據存儲器獲得。兩種方式中,后者更為方便,因為在單片的外部存儲器EPROM或FLASH中可同時包含自舉表內容及自舉表存放的首地址。對’C5402而言,有效的外部數據存儲器的地址范圍為04000h~0FFFFh。?

?

?

  并行自舉引導程序片段如下:?

  ...?

  xentry? .set??? 61H???? ;61h存放程序入口地址的XPC值?

??? entry???.set??? 62H???? ;62h存放程序入口地址?

  src???? .set??? 65H???? ;65h存放自舉表首地址?

  ...?

0000:F831 ?

  STM #0h, @xentry?????? ;初始化程序入口地址?

  STM #boot, @entry????? ;?

  PORTR #0FFFFh,@src???? ;從I/O口讀取自舉表的首地址 ?

??? MVDK @src,AR1????????? ;將自舉表的首地址送至AR1中?

??? LD? *AR1+,A??????????? ;(AR1)→A, AR1=AR1+1?

  SUB #010AAh,A,B?????? ;B=A-10AAh?

  BC? par16,BEQ????????? ;若B=0,執行16位并行自舉程序?

??? AND #0FFh,A??????????? ;屏蔽A高16位?

  SUB #08h,A,B????????? ;B=A-08h?

  BC? chk_data,BNEQ????? ;若B≠0, 程序跳轉至chk_data?

  LD? *AR1+,A??????????? ; (AR1)→A, AR1=AR1+1?

  AND #0FFh,A??????????? ;屏蔽A高16位?

  SUB #0AAh,A??????????? ;A=A-0AAh?

  BC? par08,AEQ???????? ?;若A=0, 執行8位并行自舉程序chk_data STM #0FFFFh,AR1 ;從數據存儲器讀取自舉表首地址?

  NOP???????? ??????????? ;避免流水線沖突?

  NOP???????????? ??????? ;避免流水線沖突?

  LD? *AR1+,A??????????? ;(AR1)→A, AR1=AR1+1?

  STLM A,AR1???????? ??? ;將A低16位內容存入AR1中?

  NOP?????????????????? ? ;避免流水線沖突?

  NOP???????????????????? ;避免流水線沖突?

  LD *AR1+,A???????????? ;(AR1)→A, AR1=AR1+1?

  SUB #010AAh,A,B?????? ;B=A-10AAh?

  BC? par16,BEQ????????? ;若B=0,執行16位并行自舉程序?

 ? STM #0FFFFh,AR1??????? ;(0FFFFh)→AR1?

  NOP??????????????????? ?;避免流水線沖突?

  NOP??????????????????? ?;避免流水線沖突?

  LDU *AR1-,A??????????? ;(AR1)→A,AR1=AR1-1,符號位置0?

  AND #0FFh,A??????????? ;屏蔽A高16位?

  SUB #08h,A,B?????? ?? ;B=A-08h?

  BC? ser_ini,BNEQ?????? ;若B≠0, 程序跳轉至ser_ini?

  LD *AR1+,A?????????? ? ;(AR1)→A, AR1=AR1+1?

  AND #0FFh,A??????????? ;屏蔽A高16位?

  SUB #0AAh,A??????????? ;A=A-0AAh?

  BC? par08,AEQ????????? ;若A=0,執行8位并行自舉程序?

  ser_ini?

  ...??????????????????? ?;標準串行口自舉引導程序?

  par08?

  ...??????????????????? ?;8位并行自舉搬移程序?

  par16?

  ...???????????????????? ;16位并行自舉搬移程序?

3 自舉表的建立?

  自舉表的內容不僅包括了欲加載的各段代碼,而且包括各段代碼長度、各代碼段存放的目標地址、程序入口地址等信息。因此若想利用自舉引導功能,首先必須正確建立自舉表。自舉表可由hex500格式轉換器自動生成。hex500實際為一通用程序,它將公共目標文件格式——COFF文件轉換成各種EPROM或FLASH的編程格式。因此,在使用hex500工具之前,首先必須對DSP的匯編語言、C語言或兩者的混合編程語言進行匯編、編譯、鏈接,生成COFF格式的.out文件,然后再通過設置適當的選項生成用戶所要求的自舉表。?

  為了書寫及修改方便,可將hex500的所有選項及輸入輸出文件名以.cmd 批處理命令文件的形式保存。下面以一個DSP匯編語言程序example.asm為例,說明建立’C5402自舉表的具體步驟。?

  第一步:對example.asm進行編譯,生成example.obj文件。不論是用Windows 環境下的CCS(Code Composer Studio),還是用DOS環境下的asm500命令文件,編譯時必須加選項—v548,且DOS的asm500版本必須在1.2以上,否則無法生成正確的’C5402自舉表。?

  第二步:鏈接,生成example.out文件。?

  第三步:使用hex500格式轉換工具,將example.out文件轉換成example.hex文件,命令格式如下:?

  C:tic5400cgtoolsbin>hex500 example.cmd?

  注:在上面的命令行中,example的擴展名cmd一定要加上。?

  以下是命令文件example.cmd的內容:?

  example.out???? /*被轉換的COFF文件名?

  -e 200h???????? /*程序入口地址被定義為200h?

  -a????????????? /*轉換為ASCII-hex格式文件?

  -o example.hex? /*轉換后文件名為example.hex?

  -memwidth 16??? /*外部數據存儲器字寬為16位?

  -romwidth 16??? /*ROM字寬為16位?

  -boot?????????? /*將COFF文件中各段均轉換至自舉表?

  -bootorg 8000h? /*存放自舉表的首地址為8000h?

  如果example.asm是一個簡單的求乘法累加運算,程序內容如下[2]:?

  *****************************************?

  * example.asm y=a1*x1+a2*x2+a3*x3+a4*x4?? *?

  *****************************************?

  .title? ″example.asm″???????? ;源程序取名為example.asm?

STACK .usect ″STACK″,10h? ?? ;為名為STACK的堆棧預留16個單元?

??? .bss? x, 4?????????????? ? ;在數據存儲器中為未初始?

??? .bss??? a, 4???????????? ?? 化變量(續) x, a, y分別?

??? .bss??? y, 1??????????? ??? 預留4,4,1個單元?

??? .def ?? ?start????????????? ;?

??? .data?????????????????????? ;以下為數據段?

table:.word? 1, 2, 3, 4???? ;在以標號table開始的8個?

??? .word? 8, 6, 4, 2??????? 程序存儲單元中存放8個已初始化數據?

??? .text?????????????????????? ;以下為程序段?

start: STM? # STACK+10,SP? ;設置堆棧指針?

??? STM? # table, AR1????? ;AR1指向table的首地址?

??? STM? # x, AR2????????? ;AR2指向存放變量x的首地址?

??? STM? # 7, AR0????????? ;AR0=7?

??? LD? # 0, A???????????? ;A=0?

loop:?? LD? *AR1+, A?????? ;(AR1)→A, AR1=AR1+1?

??? STL ? A, *AR2+???????? ;A→(AR2) , AR2=AR2+1?

??? BANZ? loop,*AR0-?????? ;若AR0≠0,循環,AR0=AR0-1?

??? CALL? sum?????????????? ;若AR0=0,調用sum子程序?

end:??? B ? ?end??????????????????? ;?

sum:??? LD? ? #0, A??????? ;A=0?

??? STM? #a, AR3?????????? ;AR3指向存放變量a的首地址?

??? STM? #x, AR4?????????? ;AR4指向存放變量x的首地址?

??? RPT ? #3??????????????? ;?

??? MAC *AR3+,*AR4+,A???? ;完成三次乘法累加運算?

??? STL A,@y???????????? ? ;將結果存入預留的數據存儲器中?

??? RET???????????????????? ;返回主程序?

??? .end??????????????????? ;結束匯編命令?

  則生成的example.hex文件的內容如表2所示。?

?

?

??? 如果將example.hex的內容燒寫至16位EPROM中,則其數據存儲器內部組織結構如表3所示。?

?

?

  由表3 的EPROM數據組織結構可看出,在0FFFFh地址處存放的是自舉表首地址8000h。從8000h處開始是16位自舉表的內容。自舉表的第一個字是16位自舉標記10AA,第二、三個字分別為寄存器SWWSR及BSCR的內容。從第四個字開始分別是程序入口地址、各代碼段長度、存放各代碼段的目標地址及各段代碼(本例含有程序段及數據段),最后為塊結束標志0000h。這樣, 一個正確的自舉表就建立起來了。?

  ’C5402 DSP芯片為用戶提供了豐富靈活的自舉引導方式,用戶可根據各自的需求選擇不同的引導方式,其中并行自舉是最常用的引導方式之一。正確建立自舉表是充分利用自舉引導功能的前提及關鍵。?

參考文獻?

1 張雄偉,曹鐵勇.DSP芯片的原理與開發應用.北京:電子工業出版社,2000.9?

2 戴明楨.TMS320C54X數字信號處理器結構、原理及應用. TI DSPS UNIVERSITY,1999.7?

3 Ruben D.Perez. TMS320VC5402 and TMS320UC5402 Bootloader,C5000 Applications. Texas Instruments Application Report, SPRA618-February 2000
本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热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>
          久久日韩精品| 欧美日韩精品综合在线| 国产毛片精品国产一区二区三区| 在线看不卡av| 国产精品嫩草99av在线| 国产精品v欧美精品v日本精品动漫| 亚洲午夜免费福利视频| 伊人精品视频| 久久人人超碰| 欧美国产丝袜视频| 国产一区二区三区最好精华液| 免播放器亚洲| 久久精品99无色码中文字幕| 欧美激情视频在线免费观看 欧美视频免费一| 欧美女同视频| 欧美精品18videos性欧美| 国产欧美日韩精品专区| 欧美精品尤物在线| 国产一区二区三区黄| 国产色综合网| 在线观看成人av| 久久久免费观看视频| 久久久.com| 亚洲欧洲一级| 99精品国产在热久久婷婷| 亚洲国产成人午夜在线一区| 欧美不卡激情三级在线观看| 欧美黄色网络| 欧美插天视频在线播放| 国产曰批免费观看久久久| 国产精品美女诱惑| 亚洲三级性片| 国产精品久久国产愉拍| 欧美不卡视频一区发布| 国产亚洲欧美中文| 亚洲视频大全| 午夜国产精品视频免费体验区| 亚洲免费网址| 国产日产高清欧美一区二区三区| 亚洲欧美久久久久一区二区三区| 亚洲中午字幕| 欧美特黄视频| 麻豆91精品91久久久的内涵| **性色生活片久久毛片| 欧美色大人视频| 亚洲一区二区3| 亚洲午夜伦理| 激情小说另类小说亚洲欧美| 性欧美1819sex性高清| 亚洲黄色免费| 日韩一级大片在线| 国产精品日日摸夜夜摸av| 欧美三级日本三级少妇99| 亚洲国产一区二区三区青草影视| 欧美日韩精品欧美日韩精品一| 欧美日韩免费一区| 亚洲第一毛片| 激情久久久久久久久久久久久久久久| 一区二区三区四区五区精品| 欧美亚一区二区| 99视频精品全部免费在线| 国产乱人伦精品一区二区| 久久国产欧美| 亚洲日本中文字幕免费在线不卡| 亚洲欧美成人网| ●精品国产综合乱码久久久久| 欧美精品一区二区三区久久久竹菊| 永久91嫩草亚洲精品人人| 欧美日韩免费高清一区色橹橹| 夜夜嗨av一区二区三区网站四季av| 先锋影音国产精品| 在线观看久久av| 蜜桃精品久久久久久久免费影院| 国产精品五月天| 久久精品91久久久久久再现| 亚洲裸体俱乐部裸体舞表演av| 欧美日韩dvd在线观看| 欧美激情一区二区久久久| 一区二区三区日韩精品视频| 欧美久久久久久久| 在线天堂一区av电影| 欧美人与性禽动交情品| 国产精品久久久久久户外露出| 樱桃视频在线观看一区| 亚洲国产成人porn| 欧美顶级艳妇交换群宴| 一区二区三区导航| 欧美日韩精品一区二区三区| 亚洲欧美日韩电影| 亚洲国产精品t66y| 欧美二区视频| 夜夜精品视频一区二区| 男女av一区三区二区色多| 亚洲婷婷国产精品电影人久久| 久久se精品一区精品二区| 欧美国产成人在线| 国产精品亚洲一区二区三区在线| 亚洲午夜精品一区二区三区他趣| 日韩视频在线一区二区| 精品69视频一区二区三区| 国产精品久久久久aaaa樱花| 亚洲精品乱码久久久久| 国产精品久久精品日日| 亚洲天堂免费观看| 亚洲一区日韩在线| 亚洲电影免费观看高清完整版在线观看| 亚洲综合激情| 欧美另类99xxxxx| 免费观看久久久4p| 99热免费精品在线观看| 亚洲欧美日韩国产综合| 久久久蜜桃一区二区人| 亚洲综合丁香| 久久av免费一区| 国产日韩精品一区二区三区在线| 国产精品久久午夜夜伦鲁鲁| 在线精品国产成人综合| 午夜精品国产| 国产欧美一区二区三区久久人妖| 欧美在线黄色| 欧美国产亚洲精品久久久8v| 欧美日韩亚洲视频一区| 亚洲一区区二区| 国产在线精品一区二区夜色| 久久综合国产精品| 亚洲影视中文字幕| 久久精品国产v日韩v亚洲| 久久看片网站| 久久这里只精品最新地址| 99国产精品视频免费观看| 欧美福利精品| 亚洲第一福利在线观看| 欧美日韩免费视频| 欧美国产一区二区三区激情无套| 久久九九久久九九| 亚洲视频在线观看网站| 国产精品日本一区二区| 欧美区二区三区| 亚洲日本无吗高清不卡| 一区二区亚洲欧洲国产日韩| 国产视频一区二区三区在线观看| 国产精品一区二区男女羞羞无遮挡| 亚洲精品中文字| 亚洲激情六月丁香| 亚洲免费成人av电影| 麻豆久久久9性大片| 麻豆精品视频在线观看视频| 亚洲国产精品一区二区尤物区| 韩国视频理论视频久久| 麻豆免费精品视频| 午夜精品视频网站| 亚洲欧美日韩国产| 国产精品九九久久久久久久| 国产日韩1区| 亚洲精品免费一区二区三区| 久久久久久一区二区三区| 99re视频这里只有精品| 亚洲二区在线观看| 国产日韩欧美一区二区三区在线观看| 国内精品伊人久久久久av一坑| 欧美性猛交99久久久久99按摩| 欧美专区一区二区三区| 欧美日韩喷水| 羞羞漫画18久久大片| 亚洲视屏在线播放| 在线观看视频亚洲| 亚洲高清资源综合久久精品| 亚洲乱码国产乱码精品精| 亚洲免费av片| 久久久久久久网站| 国产亚洲人成a一在线v站| 国产精品―色哟哟| 国产精品亚洲а∨天堂免在线| 欧美视频精品在线观看| 国产精品专区第二| 日韩小视频在线观看专区| 欧美激情第1页| 99亚洲伊人久久精品影院红桃| 久热综合在线亚洲精品| 久久国产欧美日韩精品| 亚洲欧洲av一区二区三区久久| 欧美大片在线观看一区二区| 欧美日一区二区在线观看| 亚洲第一福利在线观看| 男女精品网站| 免费永久网站黄欧美| 国产女主播一区| 136国产福利精品导航网址应用| 亚洲欧美日韩精品一区二区| 欧美日韩国产一区精品一区| 尤物视频一区二区| 在线亚洲+欧美+日本专区| av成人福利| 1024欧美极品| 亚洲丰满在线| 国产欧美一区二区三区沐欲| 久久久久国产精品厨房| 久久香蕉国产线看观看av| 国产一区二区三区黄| 在线免费观看成人网| 欧美日韩免费在线视频| 欧美精品一卡二卡| 激情综合中文娱乐网| 国产原创一区二区| 欧美电影免费观看| 91久久综合亚洲鲁鲁五月天| 欧美日本国产| 欧美一区在线视频| 国产欧美日韩伦理| 欧美日韩一区二区在线播放| 久久久久久9| 久久精品久久综合| 伊伊综合在线| 亚洲美女视频| 欧美日韩精品免费观看视频| 免费高清在线一区| 欧美国产日本高清在线| 91久久久精品| 亚洲视频在线一区| 亚洲激情一区| 牛牛国产精品| 亚洲无线一线二线三线区别av| 亚洲精品日韩综合观看成人91| 欧美激情视频免费观看| 国内精品视频久久| 亚洲二区在线观看| 牛人盗摄一区二区三区视频| 亚洲成色www久久网站| 亚洲免费成人av电影| 亚洲国产专区| 狠久久av成人天堂| 欧美日韩国产高清| 国产偷久久久精品专区| 国产亚洲欧美中文| 久久精品国产亚洲5555| 欧美激情免费在线| 国产欧美日韩在线| 欧美激情综合五月色丁香| 国产精品久久久久久久久久尿| 亚洲一区一卡| 久久精品视频免费观看| 亚洲一级在线| 国产一区亚洲一区| 亚洲一区二区成人| 在线一区日本视频| 夜色激情一区二区| 欧美亚男人的天堂| 在线观看欧美成人| 亚洲欧美成人综合| 久久精品水蜜桃av综合天堂| 国产精品美女在线| 亚洲精品日韩激情在线电影| 国产精品伊人日日| 99视频在线观看一区三区| 国产午夜精品全部视频在线播放| 欧美色一级片| 欧美女激情福利| 看片网站欧美日韩| 在线综合视频| 欧美成人精品三级在线观看| 国产又爽又黄的激情精品视频| 一区二区三区精品视频在线观看| 国产精品你懂得| 久久精品人人做人人爽| 欧美一级午夜免费电影| 99在线观看免费视频精品观看| 国产亚洲免费的视频看| 亚洲电影免费在线| 国产精品高潮呻吟视频| 久久久激情视频| 国产亚洲成av人在线观看导航| 久久九九有精品国产23| 欧美国产日韩精品免费观看| 欧美日韩视频第一区| 亚洲国产日韩欧美综合久久| 亚洲精品一区二区三区福利| 久久大逼视频| 国产一区二区三区在线观看网站| 亚洲美女视频在线免费观看| 欧美国产日产韩国视频| 久久综合99re88久久爱| 久久久免费精品| 欧美高清在线播放| 欧美精品在线免费| 国外成人在线视频| 国产午夜一区二区三区| 国产精品九九久久久久久久| 亚洲成色www久久网站| 亚洲一区二区三区涩| 国产精品一区二区三区乱码| 国产亚洲精品一区二区| 伊人久久成人| 一区在线视频观看| 亚洲第一网站免费视频| 欧美福利精品| 国产精品区二区三区日本| 欧美日韩三级视频| 亚洲一区二区成人| 国产日韩在线一区二区三区| 国产精品自拍在线| 久久久精品午夜少妇| 亚洲在线视频一区| 欧美视频精品在线观看| 嫩模写真一区二区三区三州| 久久精品论坛| 精品不卡在线| 在线不卡a资源高清| 亚洲精品久久久久久一区二区| 久久久久国色av免费看影院| 亚洲宅男天堂在线观看无病毒| 久久免费高清视频| 免费亚洲视频| 亚洲国产精品成人va在线观看| 黑人一区二区| 亚洲人体1000| 开元免费观看欧美电视剧网站| 国产精品视区| 欧美日韩亚洲综合在线| 欧美视频专区一二在线观看| 亚洲欧洲日韩女同| 欧美激情麻豆| 久久成人人人人精品欧| 国产免费成人av| 欧美日韩精品免费观看| 久久亚洲影院| 欧美午夜视频在线| 亚洲一区二区不卡免费| 国产精品青草综合久久久久99|