精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Linux從頭學(xué):三級(jí)跳過程詳解-從 bootloader 到 操作系統(tǒng),再到應(yīng)用程序

系統(tǒng) Linux
不論是在 x86 平臺(tái)上,還是在嵌入式平臺(tái)上,系統(tǒng)的啟動(dòng)一般都經(jīng)歷了 bootloader 到 操作系統(tǒng),再到應(yīng)用程序,這樣的三級(jí)跳過程。

[[421378]]

目錄

  • bootloader 跳轉(zhuǎn)到操作系統(tǒng)
  • 操作系統(tǒng)跳轉(zhuǎn)到應(yīng)用程序
  • 應(yīng)用程序調(diào)用操作系統(tǒng)中的函數(shù)

不論是在 x86 平臺(tái)上,還是在嵌入式平臺(tái)上,系統(tǒng)的啟動(dòng)一般都經(jīng)歷了 bootloader 到 操作系統(tǒng),再到應(yīng)用程序,這樣的三級(jí)跳過程。

每一個(gè)相互交接的過程,都是我們學(xué)習(xí)的重點(diǎn)。

這篇文章,我們?nèi)匀灰?x86 平臺(tái)為例,一起來看一下:從上電之后,系統(tǒng)是如何一步一步的進(jìn)入應(yīng)用程序的入口地址。

bootloader 跳轉(zhuǎn)到操作系統(tǒng)

在上一篇文章中,討論了 bootloader 在進(jìn)入保護(hù)模式之后,在地址 0x0001_0000 處創(chuàng)建了全局描述符表(GDT),表中創(chuàng)建了 3 個(gè)段描述符:

圖片

只要在 GDT 中創(chuàng)建了這 3 個(gè)描述符,然后把 GDT 的地址(eg: 0x0001_0000)設(shè)置到 GDTR 寄存器中,此時(shí)就可以進(jìn)入保護(hù)模式工作了(設(shè)置 CR0 寄存器的 bit0 為 1)。

之前的第 6 篇文章中Linux從頭學(xué)06:16張結(jié)構(gòu)圖,徹底理解【代碼重定位】的底層原理,我們是假設(shè) bootloader 把操作系統(tǒng)程序讀取到內(nèi)存 0x0002_0000 的位置,這里繼續(xù)使用這個(gè)示例:

關(guān)于文件頭 header 的內(nèi)容,與實(shí)模式下是不同的。

在實(shí)模式下,header 的布局如下圖:

bootloader 在把操作系統(tǒng),從硬盤加載到內(nèi)存中之后,從 header 中取得 3 個(gè)段的匯編地址(即:段的開始地址相對(duì)于文件開始的偏移量),然后計(jì)算得到段的基地址,最后把段基地址寫回到 header 的這 3 個(gè)段地址空間中。

這樣的話,操作系統(tǒng)開始執(zhí)行時(shí),就可以從 header 中準(zhǔn)確的獲取到每一個(gè)段的基地址了,然后就可以設(shè)置相應(yīng)的段寄存器,進(jìn)入正確的執(zhí)行上下文了。

那么在保護(hù)模式下呢,操作系統(tǒng)需要的就不是段的基地址了,而是要獲取到每一個(gè)段的描述符才行。

很顯然,需要借助 bootloader 才可以完成這個(gè)目標(biāo),也就是:

  1. 在 GDT 中為操作系統(tǒng)程序中的三個(gè)段,建立相應(yīng)的描述符;
  2. 把每一個(gè)段的描述符索引號(hào),寫回到操作系統(tǒng)程序的 header 中;

注意:

這里描述的僅僅是一個(gè)可能的過程,主要用來理解原理。

有些系統(tǒng)可以用不同的實(shí)現(xiàn)方式,例如:在進(jìn)入操作系統(tǒng)之后,在另外一個(gè)位置存放 GDT,并重新創(chuàng)建其中的段描述符。

操作系統(tǒng)的 header 布局

既然 header 需要作為媒介,來接收 bootloader 往其中寫入段索引號(hào),所以 bootloader 與 OS 就要協(xié)商好,寫在什么位置?

可以按照之前的方式,直接覆寫在每個(gè)段的匯編地址位置,也可以寫在其他的位置,例如:

其中,最后的 3 個(gè)位置可以用來接收操作系統(tǒng)的三個(gè)段索引號(hào)。

建立操作系統(tǒng)的三個(gè)段描述符

bootloader 把 OS 加載到內(nèi)存中之后,會(huì)解析 OS 的 header 中數(shù)據(jù),得到每個(gè)段的基地址以及界限。

雖然 header 中沒有明確的記錄每個(gè)段的界限,可以根據(jù)下一個(gè)段的開始地址,來計(jì)算得到上一個(gè)段的長(zhǎng)度。

我們可以聯(lián)想一下:

現(xiàn)代 Linux 系統(tǒng)中 ELF 文件的格式,在文件頭部中記錄了每一個(gè)段的長(zhǎng)度,具體解析請(qǐng)參考這篇文章:Linux系統(tǒng)中編譯、鏈接的基石-ELF文件:扒開它的層層外衣,從字節(jié)碼的粒度來探索。

此時(shí),bootloader 就可以利用這幾個(gè)信息:段基地址、界限、類型以及其他屬性,來構(gòu)造出相應(yīng)的段描述符了(下圖橙色部分):

PS:這里的示例只為操作系統(tǒng)創(chuàng)建了 3 個(gè)段描述符,實(shí)際情況也許有更多的段。

OS 段描述符建立之后,bootloader 再把這 3 個(gè)段描述符在 GDT 中的索引號(hào),填寫到 OS 的 header 中相應(yīng)的位置:

上圖中,“入口地址”下面的那個(gè) 4,本質(zhì)上是不需要的,加上更有好處,好處如下:

當(dāng)從 bootloader 跳入到操作系統(tǒng)的入口地址時(shí),需要告訴處理器兩件事情:

  1. 代碼段的索引號(hào);
  2. 代碼的入口地址;

因此,把入口地址和索引號(hào)放在一起,有助于 bootloader 直接使用跳轉(zhuǎn)語句,進(jìn)入到 OS 的 start 標(biāo)記處開始執(zhí)行。

操作系統(tǒng)跳轉(zhuǎn)到應(yīng)用程序

從現(xiàn)代操作系統(tǒng)來看,這個(gè)標(biāo)題是有錯(cuò)誤的:

操作系統(tǒng)是應(yīng)用程序的下層支撐,相當(dāng)于是應(yīng)用程序的 runtime,怎么能叫做跳轉(zhuǎn)到應(yīng)用程序呢?

其實(shí)我想表達(dá)的意思是:操作系統(tǒng)是如何加載、執(zhí)行一個(gè)應(yīng)用程序的。

既然是保護(hù)模式,那么操作系統(tǒng)就承擔(dān)起重要的職責(zé):保護(hù)系統(tǒng)不會(huì)受到每一個(gè)應(yīng)用程序的惡意破壞!

因此,操作系統(tǒng):把應(yīng)用程序從硬盤上復(fù)制到內(nèi)存中之后,跳入應(yīng)用程序的第一條指令之前,需要為應(yīng)用程序分配好內(nèi)存資源:

  1. 代碼段的基地址、界限、類型和權(quán)限等信息;
  2. 數(shù)據(jù)段的基地址、界限、類型和權(quán)限等信息;
  3. 棧段的基地址、界限、類型和權(quán)限等信息;

以上這些信息,都以段描述符的形式,創(chuàng)建在 GDT 中。

PS: 在現(xiàn)代操作系統(tǒng)中,應(yīng)用程序都會(huì)有一個(gè)自己私有的局部描述符表 LDT,專門存儲(chǔ)應(yīng)用程序自己的段描述符。

還記得之前討論過的下面這張圖嗎?

段寄存器的 bit2 位 TI 標(biāo)志,就說明了需要到 GDT 中查找段描述符?還是到 LDT 中去查找?

為了方便起見,我們就把所有的段描述符都放在 GDT 中。

就猶如 bootloader 為 OS 創(chuàng)建段描述符一樣,OS 也以同樣的步驟為應(yīng)用程序來創(chuàng)建每一個(gè)段描述符。

此時(shí)的 GDT 就是下面這樣:

從這張圖中已經(jīng)可以看出一個(gè)問題了:

如果所有應(yīng)用程序的段描述符都放在全局的 GDT 中,當(dāng)應(yīng)用程序結(jié)束之后,還得去更新 GDT,勢(shì)必給操作系統(tǒng)的代碼帶來很多麻煩。

因此,更合理的方式應(yīng)該是放在應(yīng)用程序私有的 LDT 中,這個(gè)問題,以后還會(huì)進(jìn)一步討論到。

不管怎樣,OS 啟動(dòng)應(yīng)用程序的整體流程如下:

  1. 操作系統(tǒng)把應(yīng)用程序讀取到內(nèi)存中的某個(gè)空閑位置;
  2. 操作系統(tǒng)分析應(yīng)用程序 header 部分的信息;
  3. 操作系統(tǒng)為應(yīng)用程序創(chuàng)建每一個(gè)段描述符,并且把索引號(hào)寫回到 header 中;
  4. 跳轉(zhuǎn)到應(yīng)用程序的入口地址,應(yīng)用程序從 header 中獲取到每個(gè)段索引號(hào),設(shè)置好自己的執(zhí)行上下文(即:設(shè)置好各種寄存器);

應(yīng)用程序調(diào)用操作系統(tǒng)中的函數(shù)

這里的函數(shù)可以理解成系統(tǒng)調(diào)用,也就是操作系統(tǒng)為所有的應(yīng)用程序提供的公共函數(shù)。

在 Linux 系統(tǒng)中,系統(tǒng)調(diào)用是通過中斷來實(shí)現(xiàn)的,在中斷處理器程序中,再通過一個(gè)寄存器來標(biāo)識(shí):當(dāng)前應(yīng)用程序想調(diào)用哪一個(gè)系統(tǒng)函數(shù),也就是說:每一個(gè)系統(tǒng)函數(shù)都有一個(gè)固定的數(shù)字編號(hào)。

再回到我們當(dāng)前討論的 x86 處理器中,操作系統(tǒng)提供系統(tǒng)函數(shù)的最簡(jiǎn)單的方法就是:

把所有的系統(tǒng)函數(shù)都放在一個(gè)單獨(dú)的代碼段中,把這個(gè)段的索引號(hào)以及每一個(gè)系統(tǒng)函數(shù)的偏移地址告訴應(yīng)用程序。

這樣的話,應(yīng)用程序就可以通過這 2 個(gè)信息調(diào)用到系統(tǒng)函數(shù)了。

假如:有 2 個(gè)系統(tǒng)函數(shù) os_func1 和 os_func2,放在一個(gè)獨(dú)立的段中:

既然 OS 中多了一個(gè)代碼段,那么 bootloader 就需要幫助它在 GDT 中多創(chuàng)建一個(gè)段描述符:

在應(yīng)用程序的 header 中,預(yù)留一個(gè)足夠大的空間來存放每一個(gè)系統(tǒng)函數(shù)的跳轉(zhuǎn)信息(系統(tǒng)函數(shù)的段索引號(hào)和函數(shù)的偏移地址):

應(yīng)用程序有了這個(gè)信息之后,當(dāng)需要調(diào)用 os_func1 時(shí),就直接跳轉(zhuǎn)到相應(yīng)的 段索引號(hào):函數(shù)偏移地址,就可以調(diào)用到這個(gè)系統(tǒng)函數(shù)了。

這里同樣的會(huì)引出 2 個(gè)問題:

  1. 如果操作系統(tǒng)提供的系統(tǒng)函數(shù)很多,應(yīng)用程序也很多,那么操作系統(tǒng)在加載每一個(gè)應(yīng)用程序時(shí),豈不是要忙死了?而且應(yīng)用程序也不知道應(yīng)該保留多大的空間來存放這些系統(tǒng)函數(shù)的跳轉(zhuǎn)信息;
  2. 在執(zhí)行系統(tǒng)函數(shù)時(shí),此時(shí)代碼段、數(shù)據(jù)段都是屬于操作系統(tǒng)的勢(shì)力范圍,但是棧基址和棧頂指針使用的仍然是應(yīng)用程序擁有的棧,這樣合理嗎?

對(duì)于第一個(gè)問題,所以 Linux 中通過中斷,提供一個(gè)統(tǒng)一的調(diào)用入口地址,然后通過一個(gè)寄存器來區(qū)分是哪一個(gè)函數(shù)。

對(duì)于第二個(gè)問題,Linux 在加載每一個(gè)應(yīng)用程序時(shí),會(huì)在內(nèi)核中建立與該應(yīng)用程序相關(guān)的數(shù)據(jù)結(jié)構(gòu),并且在內(nèi)核中創(chuàng)建一塊內(nèi)存空間,專門用作:從這個(gè)應(yīng)用程序跳轉(zhuǎn)到內(nèi)核中執(zhí)行代碼時(shí),所使用的棧空間。

但是,還有一些問題依然存在,例如:

  1. 應(yīng)用程序雖然可以調(diào)用操作系統(tǒng)提供的函數(shù)了,但是操作系統(tǒng)如何對(duì)內(nèi)核代碼進(jìn)行保護(hù)?;
  2. Linux 為應(yīng)用程序建立內(nèi)部棧的底層支撐是什么?這就涉及到 x86 中復(fù)雜的特權(quán)級(jí)的相關(guān)內(nèi)容了,下一篇文章,我們就向這些細(xì)節(jié)問題繼續(xù)探索。

 End 

從 bootloader 到操作系統(tǒng),再到應(yīng)用程序,這個(gè)三級(jí)跳的最簡(jiǎn)流程就討論結(jié)束了。

希望對(duì)你有小小的幫助,謝謝!

本文轉(zhuǎn)載自微信公眾號(hào)「IOT物聯(lián)網(wǎng)小鎮(zhèn)」

 

責(zé)任編輯:姜華 來源: IOT物聯(lián)網(wǎng)小鎮(zhèn)
相關(guān)推薦

2020-02-23 15:45:02

大數(shù)據(jù)疫情運(yùn)營

2010-11-10 09:13:37

綜合布線綜合布線改造

2015-02-05 11:28:22

Docker應(yīng)用程序容器操作系統(tǒng)級(jí)虛擬化

2009-12-10 16:45:39

Linux操作系統(tǒng)

2021-09-13 07:56:12

Linux CPULinux 系統(tǒng)

2010-10-11 11:01:21

升職記

2011-07-28 15:47:20

IOS 程序 測(cè)試

2012-07-10 10:27:58

2012-06-29 15:01:46

2010-03-18 15:16:37

Linux操作系統(tǒng)

2010-04-15 12:58:15

Unix操作系統(tǒng)

2019-12-20 14:19:47

Linux操作系統(tǒng)引導(dǎo)

2009-12-10 17:27:19

Linux操作系統(tǒng)

2009-12-23 10:05:30

Linux操作系統(tǒng)

2022-09-05 16:21:28

開發(fā)Java操作系統(tǒng)

2009-12-17 14:10:37

Linux操作系統(tǒng)

2010-04-16 18:02:30

Unix操作系統(tǒng)

2023-11-07 11:55:20

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

中文字幕在线视频精品| 久久久婷婷一区二区三区不卡| 战狼4完整免费观看在线播放版| 久久亚洲人体| 亚洲免费三区一区二区| 国产日韩欧美一区二区| 国产一区免费看| 亚洲国产精品综合久久久| 精品国产污网站| 六月丁香婷婷在线| www在线视频| 丰满亚洲少妇av| 日韩女优人人人人射在线视频| 免费一级suv好看的国产网站| 日韩三级不卡| 色中色一区二区| 色哟哟免费网站| 精品久久av| 国产精品亚洲一区二区三区在线| 日韩av不卡电影| 国产亚洲精品久久777777| 欧美男gay| 精品福利在线导航| 欧美成人福利在线观看| 激情aⅴ欧美一区二区欲海潮| 国产精品大尺度| 欧美激情一区二区三区在线视频| 国产欧美久久久精品免费| 三级一区在线视频先锋| 国模私拍视频一区| 99精品久久久久| 精品一区二区三| 亚洲精品国产精品乱码不99按摩| 人人爽人人爽av| 日韩欧美2区| 日本久久电影网| 亚洲不卡中文字幕无码| 人人超在线公开视频| 国产精品黄色在线观看| 日韩国产在线一区| 黄色软件在线观看| 2014亚洲片线观看视频免费| 国产精品免费一区二区| 国产黄色片av| 国产精品亚洲а∨天堂免在线| 国产美女精品免费电影| 中文在线资源天堂| 日本在线不卡视频| 日韩暖暖在线视频| 日本一本在线观看| 日韩成人免费在线| 国产精品91久久| 看黄色一级大片| 日韩av不卡在线观看| 国产精品国产自产拍高清av水多 | 国产精品乱人伦中文| 欧美一区二区综合| 久草在现在线| 欧美经典一区二区| 日韩久久不卡| 18视频免费网址在线观看| 中文字幕第一区综合| 亚洲精品中文字幕乱码三区不卡| www黄在线观看| 国产精品免费观看视频| 樱花www成人免费视频| 免费不卡视频| 亚洲精品国产视频| 国产自产在线视频| 乱人伦视频在线| 欧美日韩一区二区在线播放| 黄色国产精品视频| 制服诱惑亚洲| 884aa四虎影成人精品一区| 在线a免费观看| 亚洲精品影片| 日韩高清有码在线| 亚洲女优在线观看| 午夜精品毛片| 欧美精品成人在线| 中文字幕精品三级久久久| 久久久亚洲一区| 国产欧美va欧美va香蕉在线| 国产偷拍一区二区| 99热精品一区二区| 污视频在线免费观看一区二区三区| 91porn在线观看| 一区二区成人在线视频| 久久这里只有精品23| 午夜精品成人av| 欧美精品第1页| 国产视频久久久久久| 九九精品在线| 欧美成人在线网站| 黄色片视频免费| 国产在线不卡一区| 久草热久草热线频97精品| 丁香婷婷在线观看| 亚洲愉拍自拍另类高清精品| 国产成人无码一二三区视频| 91成人app| 日韩极品精品视频免费观看| 少妇高潮惨叫久久久久| 国产精品一国产精品k频道56| 国产精品美女网站| 全部免费毛片在线播放一个| 国产日韩精品一区二区浪潮av| 国产 国语对白 露脸 | 午夜精品久久久久| 亚洲欧美日本一区二区三区| 国产suv精品一区二区四区视频| 国产午夜一区二区| 日韩少妇高潮抽搐| 久热成人在线视频| 麻豆av一区| 三级资源在线| 欧美日韩成人综合在线一区二区| 成人免费av片| 国内自拍一区| 成人做爽爽免费视频| 你懂的视频在线观看| 亚洲国产精品一区二区久久恐怖片| 爱爱爱爱免费视频| 国产成人黄色| 97在线看福利| 亚洲av色香蕉一区二区三区| 中文字幕日本乱码精品影院| 日韩中文字幕免费在线| 日本韩国欧美超级黄在线观看| 欧美美女18p| 国产女人18毛片水18精| 国产精品久久久久永久免费观看| 50路60路老熟妇啪啪| 农村少妇一区二区三区四区五区| 免费不卡欧美自拍视频| 中文字幕制服诱惑| 国产欧美一区二区精品仙草咪| 欧美日韩在线中文| 农村少妇一区二区三区四区五区| 欧美激情视频网站| 亚洲精品中文字幕成人片| 亚洲猫色日本管| 美女黄色片视频| 精品一区av| 国产精品久久久久久久久男| 久香视频在线观看| 91黄色免费看| www色com| 久久99久久精品| 正在播放一区二区三区| 日本电影久久久| 日韩中文字幕在线| 97成人免费视频| 亚洲日本va午夜在线影院| 国产精品嫩草影院8vv8| 天天做天天爱天天综合网2021 | 亚欧无线一线二线三线区别| 国内自拍欧美| 欧亚精品在线观看| 黄网在线免费| 欧美日韩国产经典色站一区二区三区| 日本成人免费在线观看 | 1024视频在线| 538在线一区二区精品国产| 卡通动漫亚洲综合| 国产成人午夜精品5599| 麻豆tv在线播放| 日韩精品亚洲aⅴ在线影院| 57pao成人国产永久免费| 激情视频在线观看免费| 欧美揉bbbbb揉bbbbb| 亚洲综合视频网站| 成人av在线影院| 欧美精品色婷婷五月综合| 日韩欧美高清| 91九色露脸| 周于希免费高清在线观看| 在线视频欧美性高潮| 99国产精品久久久久99打野战| 亚洲一线二线三线久久久| 中出视频在线观看| 免费成人你懂的| a天堂资源在线观看| 九九视频精品全部免费播放| 成人免费看片视频| 爱啪视频在线观看视频免费| 亚洲天天在线日亚洲洲精| 91 中文字幕| 天天av天天翘天天综合网色鬼国产| 日韩视频在线观看免费视频| 国产精品一区久久久久| 粗暴91大变态调教| 中文字幕一区二区三区欧美日韩| 精品一区二区三区日本| 青草综合视频| 欧美一级高清免费播放| 国产鲁鲁视频在线观看特色| 日韩国产中文字幕| 国产高潮流白浆喷水视频| 日韩欧美亚洲成人| 欧美爱爱小视频| 国产日韩欧美一区二区三区乱码| 国产伦理在线观看| 蜜臀av一区二区| 国产极品尤物在线| 91精品啪在线观看国产18| 玖玖玖精品中文字幕| av在线成人| 97不卡在线视频| 97caopron在线视频| 亚洲区中文字幕| 亚洲精品国产片| 欧美日韩一区高清| 亚洲天堂视频网站| 伊人婷婷欧美激情| 日韩一区二区三区四区视频| 99r国产精品| 天堂va欧美va亚洲va老司机| 久久精品99国产精品| 欧美日韩第二页| 亚洲精品男同| www.国产亚洲| 亚洲蜜桃视频| 在线观看国产一区| 欧美三级三级| 免费成人深夜夜行视频| 国产精品任我爽爆在线播放| 91人成网站www| 欧美日韩免费电影| 国产精品va在线| 亚洲性受xxx喷奶水| 韩国国内大量揄拍精品视频| 日韩伦理av| 九九视频直播综合网| 超碰免费在线播放| www.亚洲人.com| 欧美jizzhd欧美| 综合网日日天干夜夜久久| 黄色av网站在线| 亚洲日本aⅴ片在线观看香蕉| 三级视频网站在线| 日韩大片免费观看视频播放| 深爱激情五月婷婷| 亚洲国产精品热久久| 丰满肥臀噗嗤啊x99av| 亚洲成avwww人| 秋霞视频一区二区| 日韩精品在线私人| 日本免费不卡| 亚洲裸体xxxx| 国产玉足榨精视频在线观看| 亚洲天堂开心观看| 91在线看片| 久久夜精品香蕉| 丝袜在线视频| 午夜精品蜜臀一区二区三区免费| wwwww亚洲| 7777kkkk成人观看| 中文字幕在线官网| 国产精品高潮粉嫩av| 成人在线免费电影网站| 成人黄色在线观看| 亚洲一区二区三区四区电影| 国产精品裸体一区二区三区| 日韩在线你懂的| 污视频在线免费观看一区二区三区| 91综合在线| 国产a级黄色大片| 99这里有精品| 国产又粗又长又大的视频| 麻豆精品视频在线观看免费| 亚洲自拍第三页| 99久久综合国产精品| 国产手机在线观看| 亚洲欧洲日韩一区二区三区| 激情综合五月网| 欧美性xxxx极品hd欧美风情| 中文字幕无线码一区| 日韩免费福利电影在线观看| 天堂在线视频免费观看| 一区二区亚洲精品国产| 成人日日夜夜| 91sao在线观看国产| 精品久久99| 国产在线精品一区| 日韩免费特黄一二三区| bt天堂新版中文在线地址| 视频在线观看91| 欧美性猛交xx| 久久精品亚洲精品国产欧美| 日本中文在线视频| 欧美色视频日本高清在线观看| 一级特黄色大片| 日韩电影大全免费观看2023年上| 91亚洲欧美| 欧美一级片一区| 国产精品久久免费视频| 欧美日韩精品免费观看 | 成人免费观看视频在线观看| 日韩手机在线观看| 亚洲成av人片观看| 中文字幕乱码视频| 亚洲成av人片在线观看香蕉| 最近高清中文在线字幕在线观看| 久久久久久久成人| 欧美黄页在线免费观看| 久久久福利视频| 综合av在线| 色啦啦av综合| 久久综合狠狠综合| 国产一级视频在线观看| 欧美日韩一二区| 久草在线网址| 97视频网站入口| 亚洲啊v在线免费视频| 一区二区三区四区国产| 日韩中文字幕区一区有砖一区| 日本精品一二三| 亚洲激情av在线| 国产精品人人爽| 最好看的2019年中文视频| 国产精品专区免费| 激情五月综合色婷婷一区二区 | 亚洲精品一区二区三区中文字幕 | 99热免费精品| 在线xxxxx| 一区二区久久久久久| 97在线视频人妻无码| 亚洲老头老太hd| 日韩影院在线| 久久99精品久久久久久青青日本| 午夜精品久久久久99热蜜桃导演| 四季av一区二区三区| 国产精品欧美一区喷水| 黄色av网站免费| 亚洲天堂一区二区三区| 亚洲成人人体| 欧美色欧美亚洲另类七区| 久久久噜噜噜久久狠狠50岁| 好吊一区二区三区视频| 激情av一区二区| 搡老岳熟女国产熟妇| 国内外成人免费激情在线视频| 91综合久久爱com| 日本人体一区二区| 99热精品国产| av片免费观看| 国产亚洲欧美另类中文| 最新日韩一区| 婷婷视频在线播放| 国产乱人伦偷精品视频不卡| 国产美女久久久久久| 日韩亚洲欧美在线| 麻豆av在线播放| 精品无码久久久久久久动漫| 亚洲伊人观看| 中文字幕被公侵犯的漂亮人妻| 日本韩国欧美一区二区三区| 国产黄色片在线观看| 国产人妖伪娘一区91| 天堂网在线观看国产精品| 国产伦精品一区二区三区妓女下载 | 精品国产一区二区三区久久久久久 | 美女国产精品久久久| 波多野结衣 作品| 成人av午夜电影| 丁香社区五月天| 久久精品国产一区二区电影| 日韩精品一区二区三区免费视频| 一本久道高清无码视频| 久久人人超碰精品| 亚洲字幕av一区二区三区四区| 久久亚洲国产精品| 久久久久久毛片免费看 | 国产超碰精品| 亚洲图片都市激情| 国产ts人妖一区二区| 天天干天天干天天操| 在线视频欧美日韩| 大桥未久女教师av一区二区| 国产麻花豆剧传媒精品mv在线| 中文字幕在线观看不卡| 亚洲AV无码国产精品午夜字幕| 91地址最新发布| 天天操综合网| 国产在线观看无码免费视频| 欧美日韩国产综合一区二区三区| 色呦呦网站在线观看| 欧美精品一区在线发布| 国内成人免费视频| 成人免费看片98欧美| 波霸ol色综合久久| 午夜先锋成人动漫在线| 亚洲最大天堂网| 一本大道av伊人久久综合| 97超碰在线公开在线看免费| 日韩精品久久一区| gogo大胆日本视频一区| 91久久精品国产91性色69| 555www成人网|