九九99在线视频-九九99香蕉在线视频美国毛片-九九99热久久精品在线9-九九99热-九九99久久精品在免费线bt-九九99久久

Rss & SiteMap

曙海教育集團(tuán)論壇 http://www.bjzhda.cn

曙海教育集團(tuán)論壇
共1 條記錄, 每頁(yè)顯示 10 條, 頁(yè)簽: [1]
[瀏覽完整版]

標(biāo)題:嵌入式設(shè)備上的 Linux 系統(tǒng)開(kāi)發(fā)

1樓
wangxinxin 發(fā)表于:2010-11-25 9:55:31
嵌入式設(shè)備上的 Linux 系統(tǒng)開(kāi)發(fā)
出於好玩和獲利目的修補(bǔ) PDA
Anand K Santhanam(asanthan@in.ibm.com),軟體工程師,IBM Global Services
Vishal Kulkarni(kvishal@in.ibm.com),軟體工程師,IBM Global Services

2002 年 3 月
如果您剛接觸嵌入式開(kāi)發(fā),那?l大量可用的引導(dǎo)裝載程式(bootloader)、規(guī)?s小的分發(fā)版(distribution)、文件系統(tǒng)和 GUI 看起來(lái)可能太多了。但是這些豐富的選項(xiàng)實(shí)際上是一種恩賜,允許您調(diào)整開(kāi)發(fā)或用戶(hù)環(huán)境以完全符合您的需要。對(duì) Linux 嵌入式開(kāi)發(fā)的概述將幫助您理解所有這些選項(xiàng)。
Linux 正在嵌入式開(kāi)發(fā)領(lǐng)域穩(wěn)步發(fā)展。因?d Linux 使用 GPL(請(qǐng)參閱本文後面的參考資料),所以任何對(duì)將 Linux 定制於 PDA、掌上機(jī)或者可佩帶設(shè)備感興趣的人都可以從因特網(wǎng)免費(fèi)下載其內(nèi)核和應(yīng)用程式,並開(kāi)始移植或開(kāi)發(fā)。許多 Linux 改良品種迎合了嵌入式/即時(shí)市場(chǎng)。它們包括 RTLinux(即時(shí) Linux)、uclinux(用於非 MMU 設(shè)備的 Linux)、Montavista Linux(用於 ARM、MIPS、PPC 的 Linux 分發(fā)版)、ARM-Linux(ARM 上的 Linux)和其他 Linux 系統(tǒng)(請(qǐng)參閱參考資料以鏈結(jié)到本文中提到的這些和其他術(shù)語(yǔ)及?{品。)
嵌入式 Linux 開(kāi)發(fā)大致涉及三個(gè)層次:引導(dǎo)裝載程式、Linux 內(nèi)核和圖形用戶(hù)介面(或稱(chēng) GUI)。在本文中,我們將集中討論涉及這三層的一些基本概念;深入瞭解引導(dǎo)裝載程式、內(nèi)核和文件系統(tǒng)是如何交互的;並將研究可用於文件系統(tǒng)、GUI 和引導(dǎo)裝載程式的?萓h選項(xiàng)中的一部分。
引導(dǎo)裝載程式
引導(dǎo)裝載程式通常是在任何硬體上執(zhí)行的第一段代碼。在象臺(tái)式機(jī)這樣的常規(guī)系統(tǒng)中,通常將引導(dǎo)裝載程式裝入主引導(dǎo)記錄(Master Boot Record,(MBR))中,或者裝入 Linux 駐留的磁片的第一個(gè)磁區(qū)中。通常,在臺(tái)式機(jī)或其他系統(tǒng)上,BIOS 將控制移交給引導(dǎo)裝載程式。這就提出了一個(gè)有趣的問(wèn)題:誰(shuí)將引導(dǎo)裝載程式裝入(在大多數(shù)情況中)沒(méi)有 BIOS 的嵌入式設(shè)備上呢?
解決這個(gè)問(wèn)題有兩種常規(guī)技術(shù):專(zhuān)用軟體和微小的引導(dǎo)代碼(tiny bootcode)。
專(zhuān)用軟體可以直接與遠(yuǎn)端系統(tǒng)上的快閃記憶體設(shè)備進(jìn)行交互並將引導(dǎo)裝載程式安裝在快閃記憶體的給定位置中?扉W記憶體設(shè)備是與存儲(chǔ)設(shè)備功能類(lèi)似的特殊晶片,而且它們能持久存儲(chǔ)資訊 — 即,在重新引導(dǎo)時(shí)不會(huì)擦除其內(nèi)容。
這個(gè)軟體使用目標(biāo)(在嵌入式開(kāi)發(fā)中,嵌入式設(shè)備通常被稱(chēng)?d目標(biāo))上的 JTAG 埠,它是用於執(zhí)行外部輸入(通常來(lái)自主機(jī)機(jī)器)的指令的介面。JFlash-linux 是一種用於直接寫(xiě)快閃記憶體的流行工具。它支援?d數(shù)?萓h的快閃記憶體晶片;它在主機(jī)機(jī)器(通常是 i386 機(jī)器 — 本文中我們把一臺(tái) i386 機(jī)器稱(chēng)?d主機(jī))上執(zhí)行並通過(guò) JTAG 介面使用平行埠訪問(wèn)目標(biāo)的快閃記憶體晶片。當(dāng)然,這意味著目標(biāo)需要有一個(gè)平行介面使它能與主機(jī)通信。Jflash-linux 在 Linux 和 Windows 版本中都可使用,可以在命令行中用以下命令?妍吤式G

Jflash-linux
某些種類(lèi)的嵌入式設(shè)備具有微小的引導(dǎo)代碼 — 根據(jù)幾個(gè)位元組的指令 — 它將初始化一些 DRAM 設(shè)置並?壞峊媦苳W的一個(gè)串列(或者 USB,或者乙太網(wǎng))埠與主機(jī)程式通信。然後,主機(jī)程式或裝入程式可以使用這個(gè)連接將引導(dǎo)裝載程式傳送到目標(biāo)上,並將它寫(xiě)入快閃記憶體。
在安裝它並給予其控制後,這個(gè)引導(dǎo)裝載程式執(zhí)行下列各類(lèi)功能:
·        初始化 CPU 速度
·        初始化記憶體,包括?壞帡O憶體庫(kù)、初始化記憶體配置寄存器等
·        初始化序列埠(如果在目標(biāo)上有的話(huà))
·        ?壞峆?令/資料快取記憶體
·        設(shè)置堆疊指標(biāo)
·        設(shè)置參數(shù)區(qū)域並構(gòu)造參數(shù)結(jié)構(gòu)和標(biāo)記(這是重要的一步,因?d內(nèi)核在標(biāo)識(shí)根設(shè)備、頁(yè)面大小、記憶體大小以及更多內(nèi)容時(shí)要使用引導(dǎo)參數(shù))
·        執(zhí)行 POST(加電自檢)來(lái)標(biāo)識(shí)存在的設(shè)備並報(bào)告任何問(wèn)題
·        ?d電源管理提供掛起/恢復(fù)支援
·        跳轉(zhuǎn)到內(nèi)核的開(kāi)始

帶有引導(dǎo)裝載程式、參數(shù)結(jié)構(gòu)、內(nèi)核和文件系統(tǒng)的系統(tǒng)典型記憶體佈局可能如下所示:
清單 1. 典型記憶體佈局
    /* Top Of Memory */        Bootloader        Parameter Area        Kernel        Filesystem    /* End Of Memory */
嵌入式設(shè)備上一些流行的並可免費(fèi)使用的 Linux 引導(dǎo)裝載程式有 Blob、Redboot 和 Bootldr(請(qǐng)參閱參考資料獲得鏈結(jié))。所有這些引導(dǎo)裝載程式都用於基於 ARM 設(shè)備上的 Linux,並需要 Jflash-linux 工具用於安裝。
一旦將引導(dǎo)裝載程式安裝到目標(biāo)的快閃記憶體中,它就會(huì)執(zhí)行我們上面提到的所有初始化工作。然後,它準(zhǔn)備接收來(lái)自主機(jī)的內(nèi)核和文件系統(tǒng)。一旦裝入了內(nèi)核,引導(dǎo)裝載程式就將控制轉(zhuǎn)給內(nèi)核。
設(shè)置工具鏈
設(shè)置工具鏈在主機(jī)機(jī)器上創(chuàng)建一個(gè)用於編譯將在目標(biāo)上運(yùn)行的內(nèi)核和應(yīng)用程式的構(gòu)建環(huán)境 — 這是因?d目標(biāo)硬體可能沒(méi)有與主機(jī)相容的二進(jìn)位執(zhí)行級(jí)別。
工具鏈由一套用於編譯、彙編和鏈結(jié)內(nèi)核及應(yīng)用程式的元件組成。 這些元件包括:
·        Binutils — 用於操作二進(jìn)位文件的實(shí)用程式集合。它們包括諸如 ar、as、objdump、objcopy 這樣的實(shí)用程式。
·        Gcc — GNU C 編譯器。
·        Glibc — 所有用戶(hù)應(yīng)用程式都將鏈結(jié)到的 C 庫(kù)。避免使用任何 C 庫(kù)函數(shù)的內(nèi)核和其他應(yīng)用程式可以在沒(méi)有該庫(kù)的情況下進(jìn)行編譯。

構(gòu)建工具鏈建立了一個(gè)交叉編譯器環(huán)境。本地編譯器編譯與本機(jī)同類(lèi)的處理器的指令。交叉編譯器運(yùn)行在某一種處理器上,卻可以編譯另一種處理器的指令。重頭設(shè)置交叉編譯器工具鏈可不是一項(xiàng)簡(jiǎn)單的任務(wù):它包括下載源代碼、修補(bǔ)補(bǔ)丁、配置、編譯、設(shè)置頭文件、安裝以及很多很多的操作。另外,這樣一個(gè)徹底的構(gòu)建過(guò)程對(duì)記憶體和硬碟的需求是巨大的。如果沒(méi)有足夠的記憶體和硬碟空間,那?l在構(gòu)建階段由於相關(guān)性、配置或頭文件設(shè)置等問(wèn)題會(huì)突然冒出許多問(wèn)題。
因此能夠從因特網(wǎng)上獲得已預(yù)編譯的二進(jìn)位文件是一件好事(但不太好的一點(diǎn)是,目前它們大多數(shù)只限於基於 ARM 的系統(tǒng),但遲早會(huì)改變的)。一些比較流行的已預(yù)編譯的工具鏈包括那些來(lái)自 Compaq(Familiar Linux )、LART(LART Linux)和 Embedian(基於 Debian 但與它無(wú)關(guān))的工具鏈 — 所有這些工具鏈都用於基於 ARM 的平臺(tái)。
內(nèi)核設(shè)置
Linux 社區(qū)正積極地?d新硬體添加功能部件和支援、在內(nèi)核中修正錯(cuò)誤並且及時(shí)地進(jìn)行常規(guī)改進(jìn)。這導(dǎo)致大約每 6 個(gè)月(或 6 個(gè)月不到)就有一個(gè)穩(wěn)定的 Linux 樹(shù)的新發(fā)行版。不同的維護(hù)者維護(hù)針對(duì)特定體系結(jié)構(gòu)的不同內(nèi)核樹(shù)和補(bǔ)丁。當(dāng)?d一個(gè)專(zhuān)案選擇了一個(gè)內(nèi)核時(shí),您需要評(píng)估最新發(fā)行版的穩(wěn)定性如何、它是否符合專(zhuān)案要求和硬體平臺(tái)、從編程角度來(lái)看它的舒適程度以及其他難以確定的方面。還有一點(diǎn)也非常重要:找到需要應(yīng)用於基本內(nèi)核的所有補(bǔ)丁,以便?d特定的體系結(jié)構(gòu)調(diào)整內(nèi)核。
內(nèi)核佈局
內(nèi)核佈局分?d特定於體系結(jié)構(gòu)的部分和與體系結(jié)構(gòu)無(wú)關(guān)的部分。內(nèi)核中特定於體系結(jié)構(gòu)的部分首先執(zhí)行,設(shè)置硬體寄存器、配置記憶體映射、執(zhí)行特定於體系結(jié)構(gòu)的初始化,然後將控制轉(zhuǎn)給內(nèi)核中與體系結(jié)構(gòu)無(wú)關(guān)的部分。系統(tǒng)的其餘部分在這第二個(gè)階段期間進(jìn)行初始化。內(nèi)核樹(shù)下的目錄 arch/ 由不同的子目錄組成,每個(gè)子目錄用於一個(gè)不同的體系結(jié)構(gòu)(MIPS、ARM、i386、SPARC、PPC 等)。每一個(gè)這樣的子目錄都包含 kernel/ 和 mm/ 子目錄,它們包含特定於體系結(jié)構(gòu)的代碼來(lái)完成象初始化記憶體、設(shè)置 IRQ、?壞峓眹?記憶體、設(shè)置內(nèi)核頁(yè)面表等操作。一旦裝入內(nèi)核並給予其控制,就首先調(diào)用這些函數(shù),然後初始化系統(tǒng)的其餘部分。
根據(jù)可用的系統(tǒng)資源和引導(dǎo)裝載程式的功能,內(nèi)核可以編譯成 vmlinux、Image 或 zImage。vmlinux 和 zImage 之間的主要區(qū)別在於 vmlinux 是實(shí)際的(未壓縮的)可執(zhí)行文件,而 zImage 是或多或少包含相同資訊的自解壓壓縮文件 — 只是壓縮它以處理(通常是 Intel 強(qiáng)制的)640 KB 引導(dǎo)時(shí)間的限制。有關(guān)所有這些的權(quán)威性解釋?zhuān)?qǐng)參閱 Linux Magazine 的文章“Kernel Configuration: dealing with the unexpected”(請(qǐng)參閱參考資料)。
內(nèi)核鏈結(jié)和裝入
一旦?d目標(biāo)系統(tǒng)編譯了內(nèi)核後,通過(guò)使用引導(dǎo)裝載程式(它已經(jīng)被裝入到目標(biāo)的快閃記憶體中),內(nèi)核就被裝入到目標(biāo)系統(tǒng)的記憶體(在 DRAM 中或者在快閃記憶體中)。通過(guò)使用串列、USB 或乙太網(wǎng)埠,引導(dǎo)裝載程式與主機(jī)通信以將內(nèi)核傳送到目標(biāo)的快閃記憶體或 DRAM 中。在將內(nèi)核完全裝入目標(biāo)後,引導(dǎo)裝載程式將控制傳遞給裝入內(nèi)核的位址。
內(nèi)核可執(zhí)行文件由許多鏈結(jié)在一起的物件文件組成。物件文件有許多節(jié),如文本、資料、init 資料、bass 等等。這些物件文件都是由一個(gè)稱(chēng)?d鏈結(jié)器腳本的文件鏈結(jié)並裝入的。這個(gè)鏈結(jié)器腳本的功能是將輸入物件文件的各節(jié)映射到輸出文件中;換句話(huà)說(shuō),它將所有輸入物件文件都鏈結(jié)到單一的可執(zhí)行文件中,將該可執(zhí)行文件的各節(jié)裝入到指定地址處。vmlinux.lds 是存在於 arch// 目錄中的內(nèi)核鏈結(jié)器腳本,它負(fù)責(zé)鏈結(jié)內(nèi)核的各個(gè)節(jié)並將它們裝入記憶體中特定偏移量處。典型的 vmlinux.lds 看起來(lái)象這樣:
清單 2. 典型的 vmlinux.lds 文件
OUTPUT_ARCH()    /* includes architecture type */ ENTRY(stext)        /* stext is the kernel entry point */ SECTIONS        /* SECTIONS command describes the layout        of the output file */ {    . = TEXTADDR;        /* TEXTADDR is LMA for the kernel */    .init : {        /* Init code and data*/        _stext = .;    /* First section is stext followed        by __init data section */        __init_begin = .;        *(.text.init)        __init_end = .;        }    .text : {        /* Real text segment follows __init_data section */        _text = .;        *(.text)        _etext = .;    /* End of text section*/        }    .data :{        _data=.;        /* Data section comes after text section */        *(.data)        _edata=.;        }        /* Data section ends here */    .bss : {        /* BSS section follows symbol table section */        __bss_start = .;        *(.bss)        _end = . ;        /* BSS section ends here */        } }
LMA 是裝入模組位址;它表示將要裝入內(nèi)核的目標(biāo)虛擬記憶體中的位址。TEXTADDR 是內(nèi)核的虛擬起始位址,並且在 arch// 下的 Makefile 中指定它的值。這個(gè)地址必須與引導(dǎo)裝載程式使用的地址相匹配。
一旦引導(dǎo)裝載程式將內(nèi)核複製到快閃記憶體或 DRAM 中,內(nèi)核就被重新定位到 TEXTADDR — 它通常在 DRAM 中。然後,引導(dǎo)裝載程式將控制轉(zhuǎn)給這個(gè)位址,以便內(nèi)核能開(kāi)始執(zhí)行。
參數(shù)傳遞和內(nèi)核引導(dǎo)
stext 是內(nèi)核入口點(diǎn),這意味著在內(nèi)核引導(dǎo)時(shí)將首先執(zhí)行這一節(jié)下的代碼。它通常用組合語(yǔ)言編寫(xiě),並且通常它在 arch// 內(nèi)核目錄下。這個(gè)代碼設(shè)置內(nèi)核頁(yè)面目錄、創(chuàng)建身份內(nèi)核映射、標(biāo)識(shí)體系結(jié)構(gòu)和處理器以及執(zhí)行分支 start_kernel(初始化系統(tǒng)的主常式)。
start_kernel 調(diào)用 setup_arch 作?d執(zhí)行的第一步,在其中完成特定於體系結(jié)構(gòu)的設(shè)置。這包括初始化硬體寄存器、標(biāo)識(shí)根設(shè)備和系統(tǒng)中可用的 DRAM 和快閃記憶體的數(shù)量、指定系統(tǒng)中可用頁(yè)面的數(shù)目、文件系統(tǒng)大小等等。所有這些資訊都以參數(shù)形式從引導(dǎo)裝載程式傳遞到內(nèi)核。
將參數(shù)從引導(dǎo)裝載程式傳遞到內(nèi)核有兩種方法:parameter_structure 和標(biāo)記列表。在這兩種方法中,不贊成使用參數(shù)結(jié)構(gòu),因?d它強(qiáng)加了限制:指定在記憶體中,每個(gè)參數(shù)必須位於 param_struct 中的特定偏移量處。最新的內(nèi)核期望參數(shù)作?d標(biāo)記列表的格式來(lái)傳遞,並將參數(shù)轉(zhuǎn)化?d已標(biāo)記格式。param_struct 定義在 include/asm/setup.h 中。它的一些重要欄位是:
清單 3. 樣本參數(shù)結(jié)構(gòu)
struct param_struct { unsigned long page_size;    /* 0: Size of the page */ unsigned long nr_pages;    /* 4: Number of pages in the system */ unsigned long ramdisk        /* 8: ramdisk size */ unsigned long rootdev;    /* 16: Number representing the root device */ unsigned long initrd_start; /* 64: starting address of initial ramdisk */        /* This can be either in flash/dram */ unsigned long initrd_size; /* 68: size of initial ramdisk */ }
請(qǐng)注意:這些數(shù)表示定義欄位的參數(shù)結(jié)構(gòu)中的偏移量。這意味著如果引導(dǎo)裝載程式將參數(shù)結(jié)構(gòu)放置在位址 0xc0000100,那?l rootdev 參數(shù)將放置在 0xc0000100 + 16,initrd_start 將放置在 0xc0000100 + 64 等等 — 否則,內(nèi)核將在解釋正確的參數(shù)時(shí)遇到困難。
正如上面提到的,因?d從引導(dǎo)裝載程式到內(nèi)核的參數(shù)傳遞會(huì)有一些約束條件,所以大多數(shù) 2.4.x 系列內(nèi)核期望參數(shù)以已標(biāo)記的列表格式傳遞。在已標(biāo)記的列表中,每個(gè)標(biāo)記由標(biāo)識(shí)被傳遞參數(shù)的 tag_header 以及其後的參數(shù)值組成。標(biāo)記列表中標(biāo)記的常規(guī)格式可以如下所示:
清單 4. 樣本標(biāo)記格式。內(nèi)核通過(guò) 頭來(lái)標(biāo)識(shí)每個(gè)標(biāo)記。
#define struct {        u32 ;        u32 ; }; /* Example tag for passing memory information */ #define ATAG_MEM        0x54410002 /* Magic number */ struct tag_mem32 {        u32    size;        /* size of memory */        u32    start;        /* physical start address of memory*/ };
setup_arch 還需要對(duì)快閃記憶體存儲(chǔ)庫(kù)、系統(tǒng)寄存器和其他特定設(shè)備執(zhí)行記憶體映射。一旦完成了特定於體系結(jié)構(gòu)的設(shè)置,控制就返回到初始化系統(tǒng)其餘部分的 start_kernel 函數(shù)。這些附加的初始化任務(wù)包含:
·        設(shè)置陷阱
·        初始化中斷
·        初始化計(jì)時(shí)器
·        初始化控制臺(tái)
·        調(diào)用 mem_init,它計(jì)算各種區(qū)域、高記憶體區(qū)等內(nèi)的頁(yè)面數(shù)量
·        初始化 slab 分配器並?d VFS、緩衝區(qū)快取記憶體等創(chuàng)建 slab 快取記憶體
·        建立各種文件系統(tǒng),如 proc、ext2 和 JFFS2
·        創(chuàng)建 kernel_thread,它執(zhí)行文件系統(tǒng)中的 init 命令並顯示 lign 提示符。 如果在 /bin、/sbin 或 /etc 中沒(méi)有 init 程式,那?l內(nèi)核將執(zhí)行文件系統(tǒng)的 /bin 中的 shell。

設(shè)備驅(qū)動(dòng)程式
嵌入式系統(tǒng)通常有許多設(shè)備用於與用戶(hù)交互,象觸摸屏、小鍵盤(pán)、滾動(dòng)輪、感測(cè)器、RA232 介面、LCD 等等。除了這些設(shè)備外,還有許多其他專(zhuān)用設(shè)備,包括快閃記憶體、USB、GSM 等。內(nèi)核通過(guò)所有這些設(shè)備各自的設(shè)備驅(qū)動(dòng)程式來(lái)控制它們,包括 GUI 用戶(hù)應(yīng)用程式也通過(guò)訪問(wèn)這些驅(qū)動(dòng)程式來(lái)訪問(wèn)設(shè)備。本節(jié)著重討論通常幾乎在每個(gè)嵌入式環(huán)境中都會(huì)使用的一些重要設(shè)備的設(shè)備驅(qū)動(dòng)程式。
幀緩衝區(qū)驅(qū)動(dòng)程式
這是最重要的驅(qū)動(dòng)程式之一,因?d通過(guò)這個(gè)驅(qū)動(dòng)程式才能使系統(tǒng)螢?zāi)伙@示內(nèi)容。幀緩衝區(qū)驅(qū)動(dòng)程式通常有三層。最底層是基本控制臺(tái)驅(qū)動(dòng)程式 drivers/char/console.c,它提供了文本控制臺(tái)常規(guī)介面的一部分。通過(guò)使用控制臺(tái)驅(qū)動(dòng)程式函數(shù),我們能將文本列印到螢?zāi)簧?— 但圖形或動(dòng)畫(huà)還不能(這樣做需要使用視頻模式功能,通常出現(xiàn)在中間層,也就是 drivers/video/fbcon.c 中)。這個(gè)第二層驅(qū)動(dòng)程式提供了視頻模式中繪圖的常規(guī)介面。
幀緩衝區(qū)是顯卡上的記憶體,需要將它記憶體映射到用戶(hù)空間以便可以將圖形和文本能寫(xiě)到這個(gè)記憶體段上:然後這個(gè)資訊將反映到螢?zāi)簧稀徯n區(qū)支援提高了繪圖的速度和整體性能。這也是頂層驅(qū)動(dòng)程式引人注意之處:頂層是非常特定於硬體的驅(qū)動(dòng)程式,它需要支援顯卡不同的硬體方面 — 象?壞峞?禁用顯卡控制器、深度和模式的支援以及調(diào)色板等。所有這三層都相互依賴(lài)以實(shí)現(xiàn)正確的視頻功能。與幀緩衝區(qū)有關(guān)的設(shè)備是 /dev/fb0(主設(shè)備號(hào) 29,次設(shè)備號(hào) 0)。
輸入設(shè)備驅(qū)動(dòng)程式
可觸摸板是用於嵌入式設(shè)備的最基本的用戶(hù)交互設(shè)備之一 — 小鍵盤(pán)、感測(cè)器和滾動(dòng)輪也包含在許多不同設(shè)備中以用於不同的用途。
觸摸板設(shè)備的主要功能是隨時(shí)報(bào)告用戶(hù)的觸摸,並標(biāo)識(shí)觸摸的座標(biāo)。這通常在每次發(fā)生觸摸時(shí),通過(guò)生成一個(gè)中斷來(lái)實(shí)現(xiàn)。
共1 條記錄, 每頁(yè)顯示 10 條, 頁(yè)簽: [1]

Copyright © 2000 - 2009 曙海教育集團(tuán)
Powered By 曙海教育集團(tuán) Version 2.2
Processed in .01367 s, 2 queries.
主站蜘蛛池模板: 好吊妞视频988gao在线播放 | 日韩精品一区二区三区国语自制 | 性生大片免费观看一片黄动漫 | 日本青草视频 | 国产精国产精品 | 久久久久免费看 | 最近中文字幕在线观看 | 欧美日韩一级二级 | 91亚洲精品久久久蜜桃借种 | 色婷婷婷 | 亚洲最黄视频 | 国产一级免费av | 装睡被陌生人摸出水好爽 | 国产成人综合在线 | 国产高清av| 99热r| 国产69精品久久久久久人妻精品 | 国产成人亚洲人欧洲 | 国产99久久久久久免费看 | 亚洲熟妇无码久久精品 | 欧美成人精品在线 | 国产极品美女高潮无套在线观看 | 黄色大片一级片 | 国产精品中文在线 | 日日噜狠狠噜天天噜av | 国产性猛交xxxⅹ交酡全过程 | 亚洲欧美另类在线观看 | 色视频一区 | 国产精品一区亚洲二区日本三区 | 日产91精品卡2卡三卡四 | 开心色怡人综合网站 | 亚洲最大国产成人综合网站 | 国产精品日韩一区二区三区 | 免费大片黄在线观看视频网站 | 动漫av在线免费观看 | 亚洲欧美另类激情综合区 | 中文字幕日韩在线视频 | 人人草超碰 | 天堂中文在线看 | 少妇疯狂做受xxxx高潮台湾 | 久久久无码人妻精品一区 | 91精品综合久久久久久五月天 | 青青网站| 久久精品欧美一区二区三区麻豆 | 欧美精品videosexo极品 | 五月天丁香综合久久国产 | 99久久久久国产精品免费人果冻 | 人妻少妇精品无码专区动漫 | 自拍偷拍视频网 | 精品久久久久久中文字幕大豆网 | 午夜精品福利在线 | 8x8ⅹ国产精品8x红人影库 | 在线播放中文字幕 | 中文天堂资源在线www | 自拍偷拍精品视频 | 777色婷婷视频二三区 | 亚洲精品乱码久久久久久蜜桃 | 91久久国产露脸精品 | 强壮公侵犯使我夜夜高潮 | 99国产精品丝袜久久久久久 | 老色鬼永久视频网站 | 色综合久久综合网 | 风间由美一区 | 精品成人一区二区 | 韩国三级毛片 | 波多野结衣中文一区 | 亚洲乱码中文字幕综合 | 看三级毛片 | 亚洲最大成人网色 | 特黄一毛二片一毛片 | 日韩午夜一区二区在线精品三级伦理 | 色欧美在线视频 | 国产l精品国产亚洲区久久 亚洲欧洲精品成人久久曰影片 | 国产美女久久精品香蕉69 | 欧美成人久久久免费播放 | 91免费看片 | 国产a毛片 | 亚洲男女激情 | 人妻有码av中文字幕久久琪 | 极品熟妇大蝴蝶20p 国产女人高潮叫床视频 | 美国免费黄色片 | 夜夜爽8888 | 国产色91 | 18欧美乱大交hd1984 | 亚洲精品一区二区三区丝袜 | 亚洲网址 | 久久久久久久久久久久久女过产乱 | www国产| 亚洲一区二区三区免费视频 | 国产精品推荐天天看天天爽 | 午夜黄色在线 | 中文字幕久精品免费视频 | 免费一淫片6级 | 国产成人综合久久精品免费 | 国产欧美日韩a片免费软件 九九久久精品无码专区 | 国产精品一二三区在线观看 | 一区国产在线 | 成人免费看吃奶视频网站 | 青青操国产| 77777亚洲午夜久久多人 | 久操国产在线 | 姑娘第5集在线观看免费好剧 | 国产农村乱子伦精品视频 | 午夜第一页 | 91观看在线 | 日本五十路岳乱在线观看 | 亚洲在线中文字幕 | 国产白嫩护士被弄高潮 | 国产精品伦一区二区三级视频 | 尤物视频在线看 | 国产偷自拍 | 久久国产精品久久久 | 免费精品一区 | 日韩久久中文字幕 | 久章草在线精品视频免费观看 | 五月天久久 | 制服丝袜在线视频 | 99久久精品国产片果冻的功能特点 | а√天堂8资源在线官网 | 超碰在线97国产 | 九九热视频免费观看 | 91久久精品一区二区三区大 | 在线观看免费av网址 | 伦人伦xxx国语对白 伦为伦xxxx国语对白 | 欧美人与按摩师xxxx | 亚洲成a v人片在线观看 | 欧美肥老太牲交大战 | 日韩欧美大片在线观看 | 久久日韩乱码一二三四区别 | 国产日韩一区二区三区 | 中文字幕丝袜诱惑 | 亚洲一区二区三区成人 | 国产乱xxxxx987国语对白 | 九色综合狠狠综合久久 | 国产av亚洲精品ai换脸电影 | 欧美少妇xxx | 国产女无套免费网在线观看 | 欧美一级淫片免费 | 四虎影视永久地址www成人 | 九七影院在线观看免费观看电视 | 国产丝袜视频在线观看 | 日本国产乱弄免费视频 | 性高湖久久久久久久久 | av影音在线观看 | 2020久久香蕉国产线看观看 | 成人久久一区 | 老司机在线观看视频 | 国产性av在线 | 中文成人精品久久一区 | 天堂一区二区三区 | 无码h肉动漫在线观看 | 麻豆日产六区 | 无码日韩精品一区二区免费暖暖 | 国产精品第七页 | 日韩在线观看一区二区 | 中文字幕第49页 | 亚洲少妇自拍 | 337p粉嫩日本欧洲亚洲大胆 | 91尤物视频在线观看 | 男人扒开添女人下部免费视频 | 日韩操比 | 国内精品视频一区 | 草草久久久 | 国产午夜在线 | 大香伊人 | 美丽姑娘免费观看在线观看 | 欧美久久一级 | 乱h高h翁欲渴 | 国产免费内射又粗又爽密桃视频 | 国产黄视频在线观看 | 国产精品久久久久不卡 | 国产裸体按摩视频 | 中文字幕乱码亚洲无线三区 | 欧亚av在线 | 欧美精品日韩少妇 | 国产精品成人片在线观看 | 射死你天天日 | 国产露脸ⅹxxxⅹ高清hd | 欧美另类交人妖 | 日韩一级免费毛片 | 男人的私人影院 | 国产精品第四页 | 国产精品一线二线 | x8ⅹ8成人成人少妇 xfplay2023成人资源站 | 美女销魂一区二区 | 污污视频在线观看网站 | av大片在线看 | 久久精品久久久久久噜噜老黄 | 久久伊人成人网 | 免费av成人| 国产吞精囗交高潮 | 自拍一区在线 | 给我免费的视频在线观看 | 91亚洲精品国偷拍自产在线观看 | 国产精品无码制服丝袜 | 亚洲国产精彩中文乱码av | 午夜寂寞福利 | 成人激情视频在线 | 九色精品 | 免费av一区二区 | 日本欧美国产一区二区三区 | 偷拍中国夫妇高潮视频 | 日本少妇毛耸耸毛多水多 | 国产欧美一区二区精品性色 | 亚洲天堂日韩av | 日本大bbb裸体欣赏 日本大尺度吃奶呻吟视频 日本大尺度吃奶做爰过程 日本大尺度吃奶做爰久久久绯色 | 刺激性视频黄页 | 国产精品高清一区二区三区 | 91精品少妇偷拍99 | 久久精品国产久精国产一老狼 | 欧美激情免费观看 | 在线免费激情视频 | 久草在线视频免费资源观看 | 69亚洲精品久久久蜜桃小说 | 国产免费a | 中字幕视频在线永久在线观看免费 | 国内少妇偷人精品视频免费 | 国产全肉乱妇杂乱视频男男 | 二区三区偷拍浴室洗澡视频 | 91成人短视频在线观看 | 国产精品资源 | 成人国产精品免费观看 | 夜夜躁很很躁日日躁2020铜川 | 欧美成人milf | 在线视频三区 | 国产精品久久久久久亚洲 | 奇米7777狠狠狠琪琪视频 | 天干天干天啪啪夜爽爽99 | 放荡的美妇在线播放 | 国产成人啪精品视频免费网 | 日韩精品一区中文字幕 | 在线你懂的视频 | 蜜臀av无码精品人妻色欲 | av日韩天堂 | 五月天天丁香婷婷在线中 | 美女张开腿黄网站免费下载 | 国产手机在线精品 | 一区二区三区无码高清视频 | 欧美一级片免费在线观看 | 欧美日韩在线视频免费 | 国产欧美精品区一区二区三区 | 农村人伦偷精品视频a人人澡 | 老湿午夜免费yin22xyz | 亚洲国产综合视频 | 国产精品久久久久久久久久久久午夜片 | 亚洲国产日韩a在线播放 | 亚洲精品天堂久久久老牛 | av免费在线观看网址 | 亚洲午夜精品a片久久www慈禧 | 青青青在线免费观看 | 久久久久香蕉国产线看观看伊 | 综合五月 | 国产视频一二三 | 精品国产乱码久久久久久口爆网站 | 色拍拍在线精品视频 | 午夜精品久久ed2kmp4 | 不卡黄色 | 与亲女洗澡时伦了毛片 | 国产精品久久久久久久久免费高清 | 蜜臀久久99精品久久久久久宅男 | 日韩成人无码中文字幕 | 人人妻人人澡人人爽人人精品浪潮 | 99riav3国产精品视频 | 91九色视频在线观看 | 中文字幕一区二区三区久久蜜桃 | 波多野结衣视频网址 | 好紧好湿太硬了我太爽了视频 | 成人久久久精品国产乱码一区二区 | 国产乱来乱子视频 | 国产一国产二国产三 | 美女做爰久久久久久 | 国产成人亚洲精品无码h在线 | 最近中文字幕在线播放中 | 亚洲色播爱爱爱爱爱爱爱 | 国精产品一区一区三区有限在线 | 天堂va在线高清一区 | 午夜av资源| 久久五 | 中文字幕亚洲激情 | 男男一级淫片免费播放 | 国产精品99久久久久人中文网介绍 | 国产56页| 国产wwwxxx| 成人午夜免费在线观看 | 男女做www免费高清视频网站 | 人人cao| 国产精品夜夜春夜夜爽久久小 | 真人二十三式性视频(动) | 日本视频三区 | 欧美在线视频你懂的 | 国产成人三级一区二区在线观看一 | 99精品免费视频 | 亚洲国产精品无码一区二区三区 | 亚洲欧美激情另类校园 | 亚洲精品v天堂中文字幕 | 欧美色成人综合影院 | 免看黄大片aa | 日本在线不卡一区二区 | www青草| 亚洲综合中文 | 无码人妻丰满熟妇区96 | 亚洲精品女人久久久 | 国产日韩av免费无码一区二区三区 | 国产乱淫av免费 | 久久久久久香蕉 | 国产又粗又长又硬免费视频 | 18禁美女裸体爆乳无遮挡 | 国产精品成人久久久 | 色哟哟精品一区二区 | 亚洲 欧美 另类 综合 偷拍 | 女人爽到高潮免费视频大全 | 久久久久久国 | 九七超碰在线 | 亚洲阿v天堂在线 | 日韩色网| 亚洲∧v久久久无码精品 | 四虎影视免费永久在线 | 高清18麻豆| 成人性生交免费大片 | 精品国产一区二区三区国产馆杂枝 | 中文字幕乱码免费看电影 | 成熟丰满少妇激情xxxx | 2018天天拍拍天天爽视频 | 国产精品一区二区三区久久久 | 亚洲一区二区影视 | 久久精品人成免费 | 国产精品久久久久久三级 | 国产一级一片免费播放放a 国产一级一片射内视频 | 99re6在线视频精品免费 | 中文字幕第九页 | 欧美色图亚洲色 | 夫の部长が调教中文字幕 | 久久人人人 | 免费一区二区视频 | 在线视频这里只有精品 | 一本色道久久综合亚洲精品不卡 | 亚洲精品无码永久在线观看你懂的 | 久久99免费 | 国产激情网 | 九九在线观看高清免费 | 在线观看av国产一区二区 | 亚洲黄色一区二区三区 | 精品区| 国产美女作爱视频 | 国精品人妻无码一区二区三区性色 | 国产免费无遮挡吸乳视频 | 国产高清一区二区三区四区 | 成人性生交大免费看 | 日本三级三级三级三级 | 日本少妇被黑人xxxxx | 国产精品久久久久久久免费观看 | 国精产品一区一区三区免费视频 | 精品av无码国产一区二区 | 在线免费观看福利 | 少妇高潮伦 | 色av综合av综合无码网站 | 午夜激情视频在线 | 人妻熟女欲求不满在线 | 国产在线播放网站 | 国产一区二三区好的精华液69 | 精品熟女少妇av免费观看 | 在线视频日本 | 国产又滑又嫩又白 | 国产日韩欧美亚欧在线 | 中文字幕第一页在线视频 | 中文字幕在线观看视频免费 | 久精品国产 | 99riav.6国产情侣在线看 | 4h虎影库永久 | 国产精品久久久久久婷婷不卡 | 九九九精品视频 | 天天色天天色天天色 | 开心色怡人综合网站 | 国产精品99久久久久人中文网介绍 | 成年美女黄网色视频免费4399 | 91精品国产人妻国产毛片在线 | 天天草夜夜骑 | 69堂成人精品视频在线观看 | 91丨porny丨对白 | 成人av番号网 | 国产成人精品白浆久久69 | 春色激情站 | 日本一二区视频 | 国产精品a一区二区三区网址 | 橘梨纱av一区二区三区在线观看 | 国产日韩欧美一区二区东京热 | aaaaaav| 午夜快播 | www四虎com| 91青青草 | 精品中文字幕一区二区三区av | 国产农村1级毛片 | 性少妇xxxxx 性少妇裸体野外性xxxhd | 久久人妻天天av | 正在播放酒店约少妇高潮 | 三级全黄做爰在线观看 | 亚洲 欧美 变态 国产 另类 | 超碰人人国产 | 国产欧美va欧美va香蕉在 | 蜜桃视频色 | 消息称老熟妇乱视频一区二区 | 天天免费视频 | 婷婷网色偷偷久久久99超碰 | 色偷偷亚洲男人本色 | 亚洲欧美xxx | 中国免费黄色片 | 亚洲国产精品二区 | 久久久国产乱子伦精品作者 | 人妻丰满熟妇av无码区不卡 | 久久久涩| 中文字幕人妻丝袜乱一区三区 | 激情亚洲网 | 欧美黑人又粗又大高潮喷水 | 午夜福利理论片高清在线 | 风韵多水的老熟妇 | 成人日韩欧美 | 亚洲鲁鲁| 亚洲呦女专区 | 自拍啪啪| 成人区精品一区二区婷婷 | 69成人做爰免费视频 | 天天躁夜夜躁狠狠眼泪 | 久久一级黄色片 | 亚洲视频1| gogo西西人体大尺度大胆伊人 | 日本人毛片 | 性xxxx搡xxxxx搡欧美 | 亚洲免费成人网 | 国产三级毛片 | 国产婷婷色一区二区三区 | 亚洲精品成人片在线观看 | 精品欧美黑人一区二区三区 | 国产成人精品电影在线观看 | 亚洲欧美色一区二区三区 | 羞羞视频成人 | 亚洲欧洲成人在线 | 少妇情理伦片丰满午夜在线观看 | av中文字幕观看 | 嫩草99 | 国内精品久久久久影院优 | 中文字幕日本精品一区二区三区 | 91久久国产露脸精品国产 | 国产对白videos麻豆高潮 | 最近免费中文字幕大全免费版视频 | 成 人 网 站国产免费观看 | 乌克兰极品少妇ⅹxxx做受 | 五月激情婷婷综合 | 欧美黄色特级视频 | 日批黄色片 | 熟女人妻在线视频 | 三浦惠理子aⅴ一二三区 | 日本一区二区网站 | 国产清纯粉嫩学生白丝在线观看 | 欧美成人免费在线视频 | 刘玥91精选国产在线观看 | 这里只有精品视频在线观看 | 日本在线免费 | www男人天堂 | 国产亚洲精品久久yy50 | 91丨九色丨高潮 | 一本色道av立川理惠 | 国产成人精品白浆久久69 | 国产一区二区三区免费播放 | 亚洲精品视屏 | 亚洲老妈激情一区二区三区 | 日本免费毛片 | 国内精品久久久久久久久电影网 | 污污的视频在线观看 | 天天天干干干 | caoporon成人超碰公开网站 | 国产亚av手机在线观看 | 国产成人在线视频网站 | 亚洲免费中文字幕 | 女邻居丰满的奶水 | 蜜臀99久久精品久久久久小说 | 99亚洲国产精品 | 午夜亚洲视频 | 国产精品一区二区久久乐夜夜嗨 | 欧美日韩理论 | 日韩一级性生活片 | 日韩精品在线观看网站 | 亚洲7天堂人人爽人人爽 | 日韩性生活视频 | 三级不卡| 国产一级淫片a按摩推澡按摩 | 亚洲一区精品视频在线观看 | jizzxxxx18高清喷水 | 精品一区二区三区中文字幕 | 国产精品免费视频一区二区三区 | 久久久久久久综合色一本 | 婷婷综合六月 | 波多野结衣不打码视频 | 欧美又粗又长 | 国产主播福利 | 国产精品毛片一区视频播 | 欧美性受xxxx狂喷水 | 91亚洲乱码卡一卡二卡新区豆瓣 | 色综合a怡红院怡红院 | 国产精品一区二区欧美黑人喷潮水 | 四虎av影视 | 免费高清欧美大片在线观看 | 日韩啪啪片 | 色婷婷97 | 91黄色大片 | 中国中文字幕伦av在线看片 | 国产成人综合精品 | 国产三级视频 | 日本黄色xxxx | 岳帮我囗交吞精69 | 午夜精品喷水 | 一区二区精品视频在线观看 | 黑人性较视频免费视频 | 久久精品国产99久久久古代 | 国产美女诱惑 | 精品国产乱码久久久久久影片 | 天堂成人在线视频 | 给个av网站 | 欧美色图19p | 青青草原综合久久大伊人精品 | 中文视频在线 | 久色亚洲 | 亚洲在线一区 | 18成人片黄网站www | 欧美日韩精品一区 | 天天干夜夜爱 | 快色污| 草草网站影院白丝内射 | 亚洲 国产 韩国 欧美 在线 | 成人性生交免费大片2 | xxxⅹ少妇少妇xxxx | 国四虎影永久去哪里了 | 五月天激情婷婷 | 午夜视频在线观看入口 | xx69国产| 在线日韩欧美 | 精品国产一区二区三区av 性色 | 337p嫩模大胆色肉噜噜噜 | 中文天堂在线资源 | 真多人做人爱视频高清免费 | 北条麻妃一二三区 | 丰满女人又爽又紧又丰满 | 国产精华av午夜在线观看 | 神马老子午夜 | 久久精品亚洲国产 | 成人精品亚洲人成在线 | 大黑人交xxxx18视频 | 精品性高朝久久久久久久 | 夜色资源ye321 在线观看 | 午夜精品久久99蜜桃的功能介绍 | 日本精品毛片一区视频播 | 98婷婷狠狠成人免费视频 | 秋霞欧洲| 国产美女作爱全过程免费视频 | 国产人碰人摸人爱视频 | 国产精品一二三级 | 国产乱理伦片在线观看 | 国产精品人人爽人人做我的可爱 | 曰本丰满熟妇xxxx性 | 日日碰狠狠躁久久躁2023 | 青草视频在线播放 | 欧美在线免费看 | 久久久久国产a免费观看rela | 久久99精品久久久久婷婷 | 亚洲午夜久久 | 97在线观看免费观看 | 日韩欧美福利 | 国产精品毛片在线完整版 | 天堂欧美城网站 | 欧美一级淫片aaaaaaa喷水 | 无码国产伦一区二区三区视频 | 男人天堂国产 | 亚洲色图在线播放 | 免费日韩| 亚洲国产成人一区二区精品区 | 黄色一级a毛片 | 久久精品国产一区 | 国产精品青草综合久久久久99 | 成人亚洲精品久久久久 | 欧美一区二区三区成人片在线 | 竹菊影视欧美日韩一区二区三区四区五区 | 日本色一区| 大肉大捧一进一出视频出来呀 | 91精品国产色综合久久不卡98 | 国产成a人亚洲精品在线观看 | 天天摸天天干 | 亚洲欧美日韩一区二区三区四区 | 黑桃tv视频一区二区 | 一级又爽又黄的免费毛片视频 | 亚洲综合另类小说色区一 | 污视频在线观看免费 | 久久精品岛国av一区二区无码 | 欧美日韩在线观看视频 | 日韩不卡中文字幕 | 免费黄色网址在线观看 | 狠狠操欧美 | 97超碰在| 九色中文 | 一级片亚洲| 99国产精品久久久久久久久久久 | 情侣做性视频在线播放 | 亚洲人av在线 | 国产综合无码一区二区色蜜蜜 | 成人欧美一区二区三区黑人 | 中文字幕一二 | 日韩欧美中文一区 | 精品国产乱子伦 | 天天爽天天搞 | 欧美成人手机视频 | 饥渴放荡受np公车奶牛 | 国产人与zoxxxx另类一一 | 欧美日韩精品一区二区视频 | 久久666| 91福利网站| 亚洲一线二线三线写真 | 欧美福利专区 |