青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

luqingfei@C++

為中華之崛起而崛起!
兼聽則明,偏聽則暗。

匯編語言--內中斷

 

內中斷

任何一個通用的CPU,比如8086,都具備一種能力,可以在執行完當前正在執行的指令之后,檢測到從CPU外部發送過來的或內部產生的一種特殊信息,并且可以立即對所接收到信息進行處理。這種特殊的信息,我們可以稱其為:中斷信息。

中斷的意思是指,CPU不再接著(剛執行完的指令)向下執行,而是轉去處理這個特殊信息。

 

注意,這里所說的中斷信息,是為了便于理解而采用的一種邏輯上的說法。它是對幾個具有先后順序的硬件操作所產生的事件的統一描述。

“中斷信息”是要求CPU馬上進行某種處理,并向所要進行的該種處理提供了必備的參數的通知信息。

 

中斷信息可以來自CPU的內部和外部。

 

 

 

內中斷的產生

對于8086CPU,當CPU內部有下面的情況發生的時候,將產生相應的中斷信息:

1) 除法錯誤,比如:執行div指令產生的除法溢出;

2) 單步執行;

3) 執行int0指令;

4) 執行int指令。

 

8086CPU用稱為中斷類型碼的數據來標識中斷信息的來源。中斷類型碼為一個字節數據,可以表示256種中斷信息的來源。以后,我們將產生中斷信息的事件,即中斷信息的來源,簡稱為中斷源,上述的4種中斷源,在8086CPU中的中斷類型碼如下:

1) 除法錯誤:0

2) 單步執行:1

3) 執行int0指令:4

4) 執行int指令,該指令的格式為int n,指令中的n為字節型立即數,是提供給CPU的中斷類型碼。

 

 

 

中斷處理程序

CPU收到中斷信息后,需要對中斷信息進行處理。

而如何對中斷信息進行處理,可以由我們編程決定。

我們編寫的,用來處理中斷信息的程序被稱為中斷處理程序。

一般來說,需要對不同的中斷信息編寫不同的處理程序。

 

CPU在收到中斷信息后,應該轉去執行該中斷信息的處理程序。

 

若要8086CPU執行某處的程序,就要將CS:IP指向它的入口(即程序第一條指令的地址)。

 

可見首要的問題是,CPU在收到中斷信息后,如何根據中斷信息確定其處理程序的入口。

 

CPU的設計者必須在中斷信息和其處理程序的入口地址之間建立某種聯系,使得CPU根據中斷信息可以找到要執行的處理程序。

 

中斷信息中包含有標識中斷源的類型碼。根據CPU的設計,中斷類型碼的作用就是用來定位中斷處理程序。

若要定位中斷處理程序,需要知道它的段地址和偏移地址,而如何根據8位的中斷類型碼得到中斷處理程序的段地址和偏移地址呢?

 

 

 

中斷向量表

CPU8位的中斷類型碼通過中斷向量表找到相應的中斷處理程序的入口地址。

中斷向量表就是中斷向量的列表,中斷向量,就是中斷處理程序的入口地址。

中斷向量表,就是中斷處理程序入口地址的列表。

 

中斷向量表在內存中保存,其中存放著256個中斷源所對應的中斷處理程序的入口。

 

CPU只要知道了中斷類型碼,就可以將中斷類型碼作為中斷向量表的表項號,定位相應的表項,從而得到中斷處理程序的入口地址。

 

中斷向量表在內存中存放,對于8086PC機,中斷向量表指定放在內存地址0處。從內存0000:00000000:03e81000個單元中存放著中斷向量表。這是規定。

 

一個表項存放一個中斷向量,也就是一個中斷處理程序的入口地址,對于8086CPU,這個入口地址包括段地址和偏移地址,所以一個表項占兩個字,四個字節,高地址字存放段地址,低地址字存放偏移地址。

 

 

存儲N號中斷源對應的中斷處理程序入口的偏移地址的內存單元的地址為:N*4

存儲N號中斷源對應的中斷處理程序入口的段地址的內存單元的地址為:N*4+2

N0開始。)

 

 

 

中斷過程

可以用中斷類型碼,在中斷向量表中找到中斷處理程序的入口。

找到這個入口地址的最終目的是用它設置CSIP,使CPU執行中斷處理程序。

 

用中斷類型碼找到中斷向量,并用它設置CSIP,這個工作是由CPU的硬件自動完成的。

CPU硬件完成這個工作的過得被稱為中斷過程。

 

CPU收到中斷信息后,要對中斷信息進行處理,首先將引發中斷過程。硬件在完成中斷過程后,CS:IP將指向中斷處理程序的入口,CPU開始執行中斷處理程序。

 

8086CPU在收到中斷信息后,所引發的中斷過程:

1)(從中斷信息中)取得中斷類型碼;

2)標志寄存器的值入棧;(因為在中斷過程中要改變標志寄存器的值,所以先將其保存在棧中。)

3)設置標志寄存器的第8TF和第9IF的值為0

4CS的內容入棧;

5IP的內容入棧;

6)從內存地址為中斷類型碼*4和中斷類型碼*4+2的兩個字單元中讀取中斷處理程序的入口地址設置IPCS

 

CPU在收到中斷信息之后,到處理該中斷信息,就完成一個由硬件自動執行的中斷過程(程序員無法改變這個過程中所要做的工作)。

 

中斷過程的主要任務就是用中斷類型碼在中斷向量表中找到中斷處理程序的入口地址,設置CSIP

 

因為中斷處理程序執行完成后,CPU還要回過頭來繼續執行被中斷的程序,所以要在設置CSIP之前,先將它們的值保存起來。

 

因為在執行中斷處理程序后,需要恢復在進入中斷處理程序之前的CPU現場(某一時刻,CPU中各個寄存器的值)。所以應該在修改標記寄存器之前,將它的值入棧保存。

 

 

我們更簡潔地描述中斷過程,如下:

1) 取得中斷類型碼N

2) pushf

3) TF=0IF=0

4) push CS

5) push IP

6) (IP)=(N*4), (CS)=(N*4+2)

在最后一步完成后,CPU開始執行由程序員編寫的中斷處理程序。

 

 

 

 

中斷處理程序

由于CPU隨時隨地可能檢測到中斷信息,也就是說,CPU隨時隨地可能執行中斷處理程序,所以中斷處理程序必須一直存儲在內存某段究竟之中。而中斷處理程序的入口地址,即中斷向量,處理存儲在對應的中斷向量表表項中。

 

 

中斷處理程序的編寫方法和子程序的比較相似,常規步驟如下:

1) 保存用到的寄存器。

2) 處理中斷。

3) 恢復用到的寄存器。

4) iret指令返回。

 

iret指令的功能用匯編語法描述為:

pop IP

pop CS

popf

iret通常和硬件自動完成的中斷過程配合使用。

iret指令執行后,CPU回到執行中斷處理程序前的執行點繼續執行程序。

 

 

除法錯誤中斷的處理

CPU執行div等除法指令的時候,如果發生了除法溢出錯誤,將產生中斷類型碼為0的中斷信息,CPU將檢測到這個信息,然后引發中斷過程,轉去執行0號中斷所對應的中斷處理程序。

mov ax,1000h

mov bh,1

div bh

 

 

編程處理0號中斷

編程:當發生除法溢出時,在屏幕中間顯示“overflow!”,返回DOS

分析:

1)當發生除法溢出的時候,產生0號中斷信息,從而引發中斷過程。

       此時,CPU將進行以下工作:

       1)取得中斷類型碼0

       2)標志寄存器入棧,TFIF設置為0

       3CSIP入棧;

       4(IP)=(0*4), (CS)=(0*4+2)

 

2)可見,當中斷0發生時,CPU將轉去執行中斷處理程序。

       只要按如下步驟編寫中斷處理程序,當中斷0發生時,即可顯示“overflow!”。

       1)相關處理。

       2)向顯示緩沖區送字符串“overflow!”。

       3)返回DOS

       我們將這段程序稱為:do0

3)現在的問題是:do0應存放在內存中。因為除法溢出隨時可能發生,CPU隨時都可能將CS:IP指向do0的入口,執行程序。

       那么do0應該放在哪里呢?

       由于我們是在操作系統之上使用計算機,所有的硬件資源都在操作系統的管理之下,所以我們要想得到一塊內存區存放do0,應該向操作系統申請。

n         但在這里出于兩個原因我們不想這樣做:

n         過多地討論申請內存將偏離問題的主線;

       我們學習匯編的一個重要目的就是要獲得對計算機底層的編程體驗。所以,在可能的情況下,我們不去理會操作系統,而直接面向硬件資源。

       問題變得簡單而直接,我們只需找到一塊別的程序不會用到的內存區,將do0傳送到其中即可。

 

       內存0000:0000~0000:03E8,大小約1KB的空間是系統存放中斷處理程序入口地址的中斷向量表。8086支持256個中斷,但是,實際上,系統中要處理的中斷事件遠沒有達到256個。所以在中斷向量表中,有許多單元是空的。

 

       中斷向量表是PC系統中最重要的內存區,只用來存放中斷處理程序的入口地址,DOS系統和其他應用程序都不會隨便使用這段空間。我們可以利用中斷向量表中的空閑單元來存放我們的程序。一般情況下,從0000:02000000:0300256個字節。

       結論:我們可以將do0傳送到內存0000:0200處。

 

4)我們將中斷處理程序do0放到0000:0200后,若要使得除法溢出發生的時候,CPU轉去執行do0,則必須將do0的入口地址,即0000:0200登記在中斷向量表的對慶表項中。因為除法溢出對應的中斷類型碼為0,它的中斷處理程序的入口地址應該從0×4字單元開始存放,段地址存放在0×4+2字單元中,偏移地址存放在0×4字單元中。也就是說要將do0的段地址0存放在0000:0002字單元中,將偏移地址200H存放在0000:0000字單元中。

 

       總結上面的分析,我們要做以下幾件事情:

       1)編寫可以顯示“overflow!”的中斷處理程序:do0

       2)將do0送入內存0000:0200處;

       3)將do0的入口地址0000:0200存儲在中斷向量表0號表項中。

 

 

程序的框架如下:

assume cs:code

code segment

start: do0安裝程序

        設置中斷向量表

        mov ax,4c00h

        int 21h

 

do0: 顯示字符串“overflow!

        mov ax,4c00h

        int 21h

code ends

end start

 

上面的程序分為兩部分:

1)安裝do0,設置中斷向量的程序;

2do0

 

do0的代碼是不執行的,它只是作為do0安裝程序所要傳送的數據。

首先執行do0安裝程序,將do0的代碼拷貝到內存0:200處,然后設置中斷向量表,將do0的入口地址,即偏移地址200H和段地址0,保存在0號項中。這兩部分工作完成后,程序就返回了。

程序的目的就是在內存0:200處安裝do0的代碼,將0號中斷處理程序的入口地址設置為0:200do0的代碼雖然在程序中,卻不在程序執行的時候執行。它是在除法溢出發生的時候才得以執行的中斷處理程序。

 

do0部分代碼的最后兩條指令是依照我們的編程要求,用來返回DOS的。

 

 

       現在,我們再反過來從CPU的角度看一下,什么是中斷處理程序?我們來看一下do0是如何變成0號中斷的中斷處理程序的:

1)主程序在執行時,被加載到內存中,此時do0的代碼在程序所在的內存空間中,它只是存放在主程序代碼段中的一段要被傳送到其他單元中的數據,我們不能說它是0號中斷的中斷處理程序;

2)主程序中安裝do0的代碼執行完后,do0的代碼被從主程序的代碼段中拷貝到0:200處。此時,我們也不能說它是0號中斷的中斷處理程序,它只不過是存放在0:200處的一些數據;

3)主程序中設置中斷向量表的代碼執行完后,在0號表項中填入了do0的入口地址0:200,此時0:200處的信息,即do0的代碼,就變成了0號中斷的中斷處理程序。因為當除法溢出(即0號中斷)發生時,CPU將執行0:200處的代碼。

 

回憶以下:

如何讓一個內存單元成為棧頂?將它的地址放入SSSP中;

如何讓一個內存單元中的信息被CPU當作指令來執行?將它的地址放入CSIP中;

如何讓一段程序成為N號中斷的中斷處理程序?將它的入口地址放入中斷向量表的N號表項中。

 

 

 

安裝

使用movsb指令,將do0的代碼送入0:200處。程序如下:

assume cs:code

code segment

 start:    設置es:di指向目的地址

              設置ds:si指向源地址

              設置cx為傳輸長度

              設置傳輸方向為正

              rep movsb

              設置中斷向量表

              mov ax,4c00h

              int 21h

 

       do0: 顯示字符串“overflow!

              mov ax,4c00h

              int 21h

code ends

end start

 

rep movsb指令的時候要確定的信息如下:

1)傳送的原始位置,段地址:code,偏移地址:offset do0

2)傳送的目的位置:0:200

3)傳送的長度:do0部分代碼的長度;

4)傳送的方向:正向。

 

更明確的程序如下:

assume cs:code

code segment

 start:    mov ax,cs

              mov ds,ax

              mov si,offset do0          ;設置ds:si指向源地址

 

              mov ax,0

              mov es,ax

              mov di,200h                 ;設置es:di指向目的地址

 

              mov cx do0部分代碼的長度              ;設置cx為傳輸長度

              cld                                             ;設置傳輸方向為正

              rep movsb

 

              設置中斷向量表

              mov ax,4c00h

              int 21h

 

do0:     顯示字符串“overflow!

           mov ax,4c00h

           int 21h

code ends

end start

 

如何知道do0代碼的長度?

可以利用編譯器來計算do0的長度,如下所示:

assume cs:code

code segment

 start:    mov ax,cs

              mov ds,ax

              mov si,offset do0          ;設置ds:si指向源地址

 

              mov ax,0

              mov es,ax

              mov di,200h                 ;設置es:di指向目的地址

 

              mov cx,offset do0end-offset do0         ;設置cx為傳輸長度

              cld                                             ;設置傳輸方向為正

              rep movsb

 

              設置中斷向量表

              mov ax,4c00h

              int 21h

 

do0:     顯示字符串“overflow!

           mov ax,4c00h

           int 21h

do0end: nop

do0end:

code ends

end start

             

-”是編譯器識別的運算符號,編譯器可以用它來進行了兩個常數的減法。比如:

指令:mov ax,8-4,被編譯器處理為指令:mov ax,4

 

匯編編譯器可以處理表達式,比如:

指令:mov ax,(5+3)*5/10,被編譯器處理為指令:mov ax,4

 

 

 

do0

do0程序的主要任務是顯示字符串,程序如下:

do0: 設置ds:si指向字符串

       mov ax,0b800h

       mov es,ax

       mov di,12*150+36*2            ;設置es:di指向顯存空間的中間位置

       mov cx,9                             ;設置cx為字符串長度

 s:   mov al,[si]

       mov es:[di],al

       inc si

       add di,2

       loop s

do0end:nop

 

       mov ax,4c00h

       int 21h

 

程序寫好了,可要顯示的字符串放在哪里呢?

assume cs:code

data:segment

       db “overflow!”

data ends

 

code segment

 start:    mov ax,cs

              mov ds,ax

              mov si,offset do0          ;設置ds:si指向源地址

 

              mov ax,0

              mov es,ax

              mov di,200h                 ;設置es:di指向目的地址

      

              mov cx, offset do0end-offset do0 ;設置cx為傳輸長度

              cld                               ;設置傳輸方向為正

 

              rep movsb

              設置中斷向量表

              mov 4c00h

              int 21h

do0:     mov ax,data

           mov ds,ax

 

           mov si,0                ;設置ds:si指向字符串

           mov ax,0b800h

           mov es,ax

           mov di,12*160+36*2     ;設置es:di指向顯存空間中的中間位置

 

           mov cx,9                      設置cx為字符串長度

 s:     mov al,[si]

           move s:[di],al

           inc   si

           add di,2

           loop s

 

           mov ax,4c00h

           int 21h

 do0end:nop

code ends

end start

 

上述程序有一處大錯,注意字符串“overflow!”,是在data段中。程序執行完成后返回,它所占用的內存空間被系統釋放,而在其中存放的“overflow!”也將很可能被別的信息覆蓋。

do0程序被放到了0:200處,隨時都會因發生了除法溢出而被CPU執行,很難保證do0程序從原來程序所處的空間中取得的是要顯示的字符串“overflow”。

 

       因為do0程序隨時可能被執行,而它要用到字符串“overflow”,所以該字符串也應該放在一段不會被覆蓋的空間中。正確的程序如下:

assume cs:code

code segment

 start:    mov ax,cs

              mov ds,ax

              mov si,offset do0          ;設置ds:si指向源地址

 

              mov ax,0

              move s,ax

              mov di,200h                 ;設置es:di指向目的地址

 

              mov cx,offset do0end-offset do0         ;設置cx為傳輸長度

              cld                               ;設置傳輸方向為正

 

              rep movsb

              設置中斷向量表

 

              mov 4c00h

              int 21h

 do0:    jmp short do0start

              db “overflow!”

 do0start:     mov ax,cs

                     mov ds,ax

                     mov si,202h           ;設置ds:si指向字符串

 

                     mov ax,0b800h

                     mov es,ax

                     mov di,12*160+36*2     ;設置es:di指向顯存空間的中間位置

 

                     mov cx,9                      ;設置cx為字符串長度

       s:     mov al,[si]

              mov es:[di],al

 

              inc si

              add di,2

              loop s

 

              mov ax,4c00h

              int 21h

 do0end:nop

code ends

end start

 

上面的程序,將字符串“overflow!”放到了do0程序中,在程序執行時,將標號do0到標號do0end之間的內容送到0000:0200處。

 

注意,因為在do0程序開始處的“overflow!”不是可以執行的代碼,所以在“overflow!”之前加上一條jmp指令,轉移到正式的do0程序,當除法溢出發生時,CPU執行0:200處的jmp指令,路過后面的字符串,轉到正式的do0程序執行。

 

       do0程序執行過程中必須要找到“overflow!”,那么它在哪里呢?首先來看段地址,”overflow!”do0的代碼處于同一個段中,而除法溢出發生時,CS中必須存放do0的段地址,也就是“overflow!”的段地址;再來偏移地址,0:200處的指令為jmp short do0start,這條指令占兩個字節,所以“overflow!”的偏移地址為202h

 

 

設置中斷向量

do0的入口地址0:200,寫入中斷向量表的0號表項中,使do0成為0號中斷的中斷處理程序。

0號表項的地址為0:0,其中0:0字單元存放偏移地址,0:2字單元存放段地址。程序如下:

mov ax,0

mov es,ax

mov word ptr es:[0*4],200h

mov word ptr es:[0*4+2],0

 

 

 

單步中斷

CPU在執行完一條指令之后,如果檢測到標志寄存器的TF位為1,則產生單步中斷,引發中斷過程。單步中斷的中斷類型碼為1,則它所引發的中斷過程如下:

1)取得中斷類型碼1

2)標志寄存器入棧,TFIF設置為0

3CSIP入棧;

4)(IP=1*4),(CS=1*4+2)。

 

如果TF=1,則執行一條指令后,CPU就要轉去執行1號中斷處理程序。

 

在進入單步中斷處理程序之前,設置TF=0,從而避免CPU在執行中斷處理程序的時候發生單步中斷。這就是為什么在中斷過程中有TF=0這個步驟,再來看一下中斷過程:

 

CPU為什么要提供這樣的功能呢?

CPU提供單步中斷功能的原因就是,為單步跟蹤程序的執行過程,提供了實現機制。

 

 

 

響應中斷的特殊情況

一般情況下,CPU在執行完當前指令后,如果檢測到中斷信息,就響應中斷,引發中斷過程。

但是,在有些情況下,CPU在執行完當前執行后,即便是發生中斷,也不會響應。比如:

在執行完向ss寄存器傳送數據的指令后,即便是發生中斷,CPU也不會響應。這樣做的主要原因是,ss:sp聯合指向棧頂,而對它們的設置應該連續完成

 

 

 

 

 

 

 

 

 

posted on 2010-08-04 10:35 luqingfei 閱讀(1671) 評論(0)  編輯 收藏 引用 所屬分類: 匯編語言基礎學習

導航

<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

統計

留言簿(6)

隨筆分類(109)

隨筆檔案(105)

Blogers

Game

Life

NodeJs

Python

Useful Webs

大牛

搜索

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲在线免费| 国产精品久久久久免费a∨| 久久综合狠狠综合久久激情| 亚洲一区二区在线免费观看视频| 在线欧美小视频| 亚洲激情视频在线播放| 在线欧美电影| 亚洲欧洲一区二区三区久久| 99精品欧美一区二区三区综合在线| 最新国产乱人伦偷精品免费网站| 亚洲黄色免费电影| 日韩视频在线观看一区二区| 亚洲一区精彩视频| 久久久久久一区二区| 久久综合99re88久久爱| 欧美国产乱视频| 一本一道久久综合狠狠老精东影业 | 亚洲欧洲日产国码二区| 亚洲精选一区| 午夜精品视频网站| 久久综合九色综合欧美狠狠| 欧美激情综合亚洲一二区| 欧美三级午夜理伦三级中视频| 欧美午夜免费电影| 亚洲国产精品成人精品| 亚洲一区二区在线免费观看视频| 久久精品三级| 亚洲乱码久久| 久久综合九色欧美综合狠狠| 国产精品免费一区豆花| 亚洲国产婷婷综合在线精品| 欧美一二三视频| 欧美xx69| 亚洲欧美影音先锋| 亚洲午夜精品一区二区三区他趣| 欧美亚州在线观看| 亚洲成在人线av| 午夜在线视频观看日韩17c| 麻豆精品在线观看| 亚洲图片欧美午夜| 农夫在线精品视频免费观看| 国产伦精品一区| 日韩一区二区免费看| 久久精品亚洲一区二区| 日韩视频二区| 欧美高清你懂得| 国产视频久久久久| 亚洲资源av| 亚洲精选视频免费看| 久久精品中文| 国产精品亚洲综合天堂夜夜| 99国产一区| 欧美不卡视频| 久久精品国产精品亚洲| 国产精品一区二区女厕厕| 中国女人久久久| 亚洲日本中文字幕免费在线不卡| 欧美中文在线免费| 国产区二精品视| 亚洲男女毛片无遮挡| 日韩亚洲欧美高清| 欧美精品一区二区蜜臀亚洲| 亚洲欧洲一区二区天堂久久| 久久久99免费视频| 香蕉精品999视频一区二区| 欧美日韩在线播放三区| 亚洲人成在线观看网站高清| 久久免费视频一区| 欧美一区二区大片| 国产精品推荐精品| 午夜在线精品| 西西裸体人体做爰大胆久久久| 国产精品久久久久久久一区探花| 一本综合精品| 一区二区久久久久| 国产精品久久久一区二区三区| 亚洲一区二区综合| 亚洲一区图片| 国内外成人免费激情在线视频网站 | 欧美日韩在线大尺度| 亚洲免费高清视频| 一本久道综合久久精品| 欧美日韩在线播| 欧美在线啊v一区| 欧美中文字幕在线播放| 亚洲第一网站| 日韩视频在线免费观看| 久久夜色精品国产欧美乱| 亚洲天堂成人在线观看| 欧美日韩免费观看中文| 性久久久久久久久| 欧美在线视频免费| 在线成人国产| 亚洲精品一区在线观看| 亚洲一区在线播放| 亚洲电影毛片| 亚洲精选视频在线| 国产精品推荐精品| 麻豆视频一区二区| 欧美日韩国产首页在线观看| 午夜精品久久久久久99热| 久久激情视频| 亚洲影视中文字幕| 久久蜜桃av一区精品变态类天堂| 日韩视频永久免费| 中文精品一区二区三区| 国产一区二区三区精品欧美日韩一区二区三区 | 免费在线欧美黄色| 欧美日韩一卡| 老司机精品导航| 欧美日韩一区二区在线观看| 久久亚洲精品中文字幕冲田杏梨| 欧美精品一区视频| 久久久久久**毛片大全| 欧美三日本三级三级在线播放| 久久久精品性| 欧美午夜精品久久久久久孕妇| 久久久久久久久久久久久9999| 欧美人成网站| 欧美成人免费小视频| 国产精品一区二区a| 亚洲欧洲综合| 在线精品亚洲一区二区| 亚洲欧美一区二区原创| 亚洲线精品一区二区三区八戒| 免费成人av| 免费在线视频一区| 娇妻被交换粗又大又硬视频欧美| 亚洲线精品一区二区三区八戒| 亚洲欧洲中文日韩久久av乱码| 欧美一级专区| 亚洲欧美在线播放| 欧美日韩一区二区三区视频| 亚洲国产精品成人精品| 国产专区欧美专区| 欧美亚洲综合在线| 欧美一区二区在线免费播放| 欧美日韩综合在线| 亚洲精品自在在线观看| 亚洲精品一区中文| 欧美韩国日本综合| 亚洲国产成人精品女人久久久 | 久久影院亚洲| 老司机一区二区| 国产日韩综合| 欧美亚洲在线播放| 久久人人97超碰人人澡爱香蕉| 国产精品香蕉在线观看| 一区二区av在线| 亚洲女女做受ⅹxx高潮| 欧美午夜寂寞影院| 亚洲欧美国产日韩天堂区| 香蕉国产精品偷在线观看不卡 | 国产精品都在这里| 一区二区三区四区五区在线| 亚洲男人影院| 久久都是精品| 欧美成人激情在线| 国产精品裸体一区二区三区| 午夜免费久久久久| 久久免费视频观看| 亚洲国产日韩一区二区| 欧美激情黄色片| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲性xxxx| 欧美一区二区三区免费观看视频| 国产精品一区二区三区乱码| 欧美中文字幕久久| 欧美刺激午夜性久久久久久久| 亚洲精品国产品国语在线app| 亚洲天堂av电影| 久久躁日日躁aaaaxxxx| 99精品国产高清一区二区| 国产精品久久久久国产a级| 欧美一区二区三区在| 亚洲福利免费| 欧美一区1区三区3区公司| 狠狠久久综合婷婷不卡| 欧美刺激性大交免费视频| 一区二区三区不卡视频在线观看| 久久久久久久波多野高潮日日| 亚洲美女av电影| 国产亚洲精品aa| 蘑菇福利视频一区播放| 一本色道久久88亚洲综合88| 美女视频黄 久久| 亚洲一区二区三区视频| 在线观看日韩av| 国产精品日韩在线观看| 美女任你摸久久| 欧美一区在线视频| 亚洲乱码精品一二三四区日韩在线 | 午夜日韩视频| 亚洲三级性片| 国产综合婷婷| 国产精品卡一卡二卡三| 午夜精品福利在线| 9色porny自拍视频一区二区| 美女视频黄a大片欧美| 欧美一区激情视频在线观看|