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

Linux內(nèi)核加載ELF文件源碼分析,你學(xué)會了嗎?

安全 應(yīng)用安全
每一種系統(tǒng)支持的可執(zhí)行文件都對應(yīng)一個linux_binfmt對象,統(tǒng)一注冊在一個鏈表中,通過register_binfmt和unregister_binfmt函數(shù)編輯鏈表。在執(zhí)行可執(zhí)行程序時,內(nèi)核通過list_for_each_enrty遍歷鏈表中注冊的linux_binfmt對象,使用正確的加載方式進行加載。

一、源碼版本

1)版本:V6.3-rc7,x86
2)elf文件加載源碼:fs/binfmt_elf.c

二、Linux可執(zhí)行文件注冊

Linux支持多種不同格式的可執(zhí)行程序,這些可執(zhí)行 程序的加載方式由linux\binfmts.h文件中的linux_binfmt結(jié)構(gòu)體進行定義:

struct linux_binfmt {
    struct list_head lh;
    struct module *module;
    int (*load_binary)(struct linux_binprm *);
    int (*load_shlib)(struct file *);
#ifdef CONFIG_COREDUMP
    int (*core_dump)(struct coredump_params *cprm);
    unsigned long min_coredump;   /* minimal dump size */
#endif
} __randomize_layout;

結(jié)構(gòu)體定義了可執(zhí)行程序的3中不同的加載模式:

加載模式

備注

load_binary

讀取可執(zhí)行文件內(nèi)容并加載當(dāng)前進程建立新的執(zhí)行環(huán)境

load_shlib

動態(tài)加載共享庫到已有進程

core_dump

存放當(dāng)前進程的執(zhí)行上下文到core文件中

每一種系統(tǒng)支持的可執(zhí)行文件都對應(yīng)一個linux_binfmt對象,統(tǒng)一注冊在一個鏈表中,通過register_binfmt和unregister_binfmt函數(shù)編輯鏈表。在執(zhí)行可執(zhí)行程序時,內(nèi)核通過list_for_each_enrty遍歷鏈表中注冊的linux_binfmt對象,使用正確的加載方式進行加載。
elf文件的linux_binfmt對象結(jié)構(gòu)如下,該結(jié)構(gòu)體定義了elf文件由load_elf_binary函數(shù)加載:

static struct linux_binfmt elf_format = {
    .module     = THIS_MODULE,
    .load_binary    = load_elf_binary,
    .load_shlib = load_elf_library,
#ifdef CONFIG_COREDUMP
    .core_dump  = elf_core_dump,
    .min_coredump   = ELF_EXEC_PAGESIZE,
#endif
};

三、load_elf_binary函數(shù)分析

1、文件格式校驗

struct elfhdr *elf_ex = (struct elfhdr *)bprm->buf;
 
retval = -ENOEXEC;
/* First of all, some simple consistency checks */
if (memcmp(elf_ex->e_ident, ELFMAG, SELFMAG) != 0)
    goto out;
 
    if (elf_ex->e_type != ET_EXEC && elf_ex->e_type != ET_DYN)
        goto out;
    if (!elf_check_arch(elf_ex))
        goto out;
    if (elf_check_fdpic(elf_ex))
        goto out;
    if (!bprm->file->f_op->mmap)
        goto out;

程序首先讀取了e_ident中的魔數(shù)并進行了校驗,elf_ident是ELF文件最頭部的一個長度為16字節(jié)的數(shù)組,不區(qū)分架構(gòu)和系統(tǒng)位數(shù)。e_ident起始的4個字節(jié)固定為\0x7fELF,通過校驗該位可以確定是否為elf文件。
然后識別文件是否為可執(zhí)行文件或動態(tài)鏈接文件,ELF文件當(dāng)前主要有4種格式,分別為可重定位文件(ET_REL)、可執(zhí)行文件(ET_EXEC)、共享目標(biāo)文件(ET_DYN)和core文件(ET_CORE)。load_elf_binary函數(shù)只負(fù)責(zé)解析exec和dyn文件。
最后還解析了文件依賴的系統(tǒng)架構(gòu)等必要項。

2、讀取程序頭

static struct elf_phdr *load_elf_phdrs(const struct elfhdr *elf_ex,
                       struct file *elf_file)
{
    struct elf_phdr *elf_phdata = NULL;
    int retval = -1;
    unsigned int size;
 
    /*
     * If the size of this structure has changed, then punt, since
     * we will be doing the wrong thing.
     */
    if (elf_ex->e_phentsize != sizeof(struct elf_phdr))
        goto out;
 
    /* Sanity check the number of program headers... */
    /* ...and their total size. */
    size = sizeof(struct elf_phdr) * elf_ex->e_phnum;
    if (size == 0 || size > 65536 || size > ELF_MIN_ALIGN)
        goto out;
 
    elf_phdata = kmalloc(size, GFP_KERNEL);
    if (!elf_phdata)
        goto out;
 
    /* Read in the program headers */
    retval = elf_read(elf_file, elf_phdata, size, elf_ex->e_phoff);
 
out:
    if (retval) {
        kfree(elf_phdata);
        elf_phdata = NULL;
    }
    return elf_phdata;
}

程序頭是描述與程序執(zhí)行直接相關(guān)的目標(biāo)文件結(jié)構(gòu)信息,用于在文件中定位各個段的映像,同時包含其他一些用來為程序創(chuàng)建進程映像所必須的信息。

3、讀取解釋器段

elf_ppnt = elf_phdata;
    for (i = 0; i < elf_ex->e_phnum; i++, elf_ppnt++) {
        char *elf_interpreter;
 
        if (elf_ppnt->p_type == PT_GNU_PROPERTY) {
            elf_property_phdata = elf_ppnt;
            continue;
        }
 
        if (elf_ppnt->p_type != PT_INTERP)
            continue;
 
        /*
         * This is the program interpreter used for shared libraries -
         * for now assume that this is an a.out format binary.
         */
        retval = -ENOEXEC;
        if (elf_ppnt->p_filesz > PATH_MAX || elf_ppnt->p_filesz < 2)
            goto out_free_ph;
 
        retval = -ENOMEM;
        elf_interpreter = kmalloc(elf_ppnt->p_filesz, GFP_KERNEL);
        if (!elf_interpreter)
            goto out_free_ph;
 
        retval = elf_read(bprm->file, elf_interpreter, elf_ppnt->p_filesz,
                  elf_ppnt->p_offset);
        if (retval < 0)
            goto out_free_interp;
        /* make sure path is NULL terminated */
        retval = -ENOEXEC;
        if (elf_interpreter[elf_ppnt->p_filesz - 1] != '\0')
            goto out_free_interp;
 
        interpreter = open_exec(elf_interpreter);
        kfree(elf_interpreter);
        retval = PTR_ERR(interpreter);
        if (IS_ERR(interpreter))
            goto out_free_ph;
 
        /*
         * If the binary is not readable then enforce mm->dumpable = 0
         * regardless of the interpreter's permissions.
         */
        would_dump(bprm, interpreter);
 
        interp_elf_ex = kmalloc(sizeof(*interp_elf_ex), GFP_KERNEL);
        if (!interp_elf_ex) {
            retval = -ENOMEM;
            goto out_free_file;
        }
 
        /* Get the exec headers */
        retval = elf_read(interpreter, interp_elf_ex,
                  sizeof(*interp_elf_ex), 0);
        if (retval < 0)
            goto out_free_dentry;
 
        break;
 
out_free_interp:
        kfree(elf_interpreter);
        goto out_free_ph;
    }

如果程序需要動態(tài)鏈接,則需要加載解釋器段(PT_INTERP),程序遍歷所有的程序頭,識別到解釋器段后,讀取該段的內(nèi)容。解釋器段實際上是標(biāo)明解釋器程序文件路徑的字符串,內(nèi)核根據(jù)字符串指向的文件,使用open_exec函數(shù)打開解釋器。

4、棧可執(zhí)行屬性及其他定制信息獲取

elf_ppnt = elf_phdata;
    for (i = 0; i < elf_ex->e_phnum; i++, elf_ppnt++)
        switch (elf_ppnt->p_type) {
        case PT_GNU_STACK:
            if (elf_ppnt->p_flags & PF_X)
                executable_stack = EXSTACK_ENABLE_X;
            else
                executable_stack = EXSTACK_DISABLE_X;
            break;
 
        case PT_LOPROC ... PT_HIPROC:
            retval = arch_elf_pt_proc(elf_ex, elf_ppnt,
                          bprm->file, false,
                          &arch_state);
            if (retval)
                goto out_free_dentry;
            break;
        }

同樣通過for循環(huán)遍歷,如果識別到棧屬性段(PT_GNU_STACK),根據(jù)程序頭中的p_flags標(biāo)志位判定棧的可執(zhí)行屬性。如果識別到處理器專用語義段(PT_LOPROC至PT_HIPROC之間),則調(diào)用arch_elf_pt_proc函數(shù)完成相應(yīng)的配置。

5、讀取解釋器

if (interpreter) {
        retval = -ELIBBAD;
        /* Not an ELF interpreter */
        if (memcmp(interp_elf_ex->e_ident, ELFMAG, SELFMAG) != 0)
            goto out_free_dentry;
        /* Verify the interpreter has a valid arch */
        if (!elf_check_arch(interp_elf_ex) ||
            elf_check_fdpic(interp_elf_ex))
            goto out_free_dentry;
 
        /* Load the interpreter program headers */
        interp_elf_phdata = load_elf_phdrs(interp_elf_ex,
                           interpreter);
        if (!interp_elf_phdata)
            goto out_free_dentry;

解釋器也是一個elf文件,這里讀取解釋器以便于后續(xù)操作

6、加載程序段

for(i = 0, elf_ppnt = elf_phdata;
    i < elf_ex->e_phnum; i++, elf_ppnt++) {
    int elf_prot, elf_flags;
    unsigned long k, vaddr;
    unsigned long total_size = 0;
    unsigned long alignment;
 
    if (elf_ppnt->p_type != PT_LOAD)
        continue;

加載所有類型為PT_LOAD的段,當(dāng)處理第1個PT_LOAD段時,如果文件為dyn類型,還需要對其進行地址隨機化。隨機化時還需要區(qū)分解釋器或者其他普通so文件,對于解釋器,為避免程序發(fā)生沖突,程序固定從ELF_ET_DYN_BASE開始計算偏移進行加載。

if (!first_pt_load) {
    elf_flags |= MAP_FIXED;
} else if (elf_ex->e_type == ET_EXEC) {
    elf_flags |= MAP_FIXED_NOREPLACE;
} else if (elf_ex->e_type == ET_DYN) {
    if (interpreter) {
        load_bias = ELF_ET_DYN_BASE;
        if (current->flags & PF_RANDOMIZE)
            load_bias += arch_mmap_rnd();
        alignment = maximum_alignment(elf_phdata, elf_ex->e_phnum);
        if (alignment)
            load_bias &= ~(alignment - 1);
        elf_flags |= MAP_FIXED_NOREPLACE;
    } else
        load_bias = 0;
 
    load_bias = ELF_PAGESTART(load_bias - vaddr);
    total_size = total_mapping_size(elf_phdata,
                    elf_ex->e_phnum);
    if (!total_size) {
        retval = -EINVAL;
        goto out_free_dentry;
    }
}

一切就緒后,通過elf_map函數(shù)建立用戶空間虛擬地址空間與目標(biāo)映像文件中段的映射

error = elf_map(bprm->file, load_bias + vaddr, elf_ppnt,
                elf_prot, elf_flags, total_size);

7、裝載程序入口地址

if (interpreter) {
        elf_entry = load_elf_interp(interp_elf_ex,
                        interpreter,
                        load_bias, interp_elf_phdata,
                        &arch_state);
        if (!IS_ERR_VALUE(elf_entry)) {
            /*
             * load_elf_interp() returns relocation
             * adjustment
             */
            interp_load_addr = elf_entry;
            elf_entry += interp_elf_ex->e_entry;
        }
        if (BAD_ADDR(elf_entry)) {
            retval = IS_ERR_VALUE(elf_entry) ?
                    (int)elf_entry : -EINVAL;
            goto out_free_dentry;
        }
        reloc_func_desc = interp_load_addr;
 
        allow_write_access(interpreter);
        fput(interpreter);
 
        kfree(interp_elf_ex);
        kfree(interp_elf_phdata);
    } else {
        elf_entry = e_entry;
        if (BAD_ADDR(elf_entry)) {
            retval = -EINVAL;
            goto out_free_dentry;
        }
    }

對于需要解釋器的程序,需要先通過load_elf_interp函數(shù)裝入解釋器的映像,并將程序入口點設(shè)置為解釋器的入口地址,對于不需要解釋器的文件,直接讀取elf_header中的入口點虛擬地址即可。

8、添加參數(shù)和環(huán)境變量等配置信息

retval = create_elf_tables(bprm, elf_ex, interp_load_addr,
               e_entry, phdr_addr);
if (retval < 0)
    goto out;
 
mm = current->mm;
mm->end_code = end_code;
mm->start_code = start_code;
mm->start_data = start_data;

本文作者:jixiaokui, 轉(zhuǎn)載請注明來自

責(zé)任編輯:武曉燕 來源: FreeBuf.COM
相關(guān)推薦

2023-08-26 21:34:28

Spring源碼自定義

2022-10-18 17:59:46

Bootstrap源碼父類

2023-03-08 08:42:55

MySQLcost量化

2023-01-28 10:40:56

Java虛擬機代碼

2022-09-22 12:03:14

網(wǎng)絡(luò)安全事件

2024-01-19 08:25:38

死鎖Java通信

2023-01-10 08:43:15

定義DDD架構(gòu)

2024-02-04 00:00:00

Effect數(shù)據(jù)組件

2023-07-26 13:11:21

ChatGPT平臺工具

2023-06-27 07:21:51

前端開發(fā)坑點

2023-08-01 12:51:18

WebGPT機器學(xué)習(xí)模型

2024-01-02 12:05:26

Java并發(fā)編程

2024-07-31 08:26:47

2023-06-08 07:34:19

HDFS小文件壓縮包

2024-09-30 09:05:46

Linux網(wǎng)絡(luò)延遲

2024-02-06 08:33:54

文件系統(tǒng)SSD

2022-11-06 14:46:28

腳本windows文件

2024-09-27 10:27:50

2023-01-30 09:01:54

圖表指南圖形化

2024-08-06 09:47:57

點贊
收藏

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

精品国产乱码久久久久久牛牛 | 黄色国产在线观看| free性护士videos欧美| 94色蜜桃网一区二区三区| 日本sm极度另类视频| av最新在线观看| 国产色噜噜噜91在线精品| 色网站国产精品| 永久免费网站视频在线观看| 日av在线播放| 国产精品一区二区免费不卡| 青青在线视频一区二区三区| 日本一级特级毛片视频| 曰本一区二区三区视频| 337p亚洲精品色噜噜狠狠| 精品国产一区三区| 国产网友自拍视频导航网站在线观看| www.成人网.com| 国产精品久久中文| 亚洲一区欧美在线| 中文字幕免费一区二区三区| 亚洲欧洲视频在线| 人妻激情偷乱频一区二区三区| 69堂精品视频在线播放| 亚洲大型综合色站| 亚洲美女自拍偷拍| 成年人免费在线视频| 91视视频在线观看入口直接观看www| 国产精品视频导航| 亚洲熟女综合色一区二区三区| 国产精品激情电影| 久久精品国产91精品亚洲| 大又大又粗又硬又爽少妇毛片| 国产精品香蕉| 日韩精品中午字幕| 成人亚洲免费视频| 丰满少妇一区| 欧美视频精品在线观看| 国产精品333| 国产羞羞视频在线播放| 亚洲欧美视频在线观看| 亚洲巨乳在线观看| av在线电影免费观看| www国产精品av| 狠狠色综合色区| 国产xxxx孕妇| 国产乱码精品1区2区3区| 国产欧美中文字幕| 亚洲中文一区二区三区| 老司机精品久久| 日本不卡高字幕在线2019| 亚洲精品中文字幕乱码三区91| 国产精品一区亚洲| 日本在线精品视频| 亚洲精品91天天久久人人| 久久精品九九| 国产精品黄色影片导航在线观看| 免费视频久久久| 免费久久99精品国产自在现线| 91精品国产91久久久久福利| 国产无精乱码一区二区三区| 在线午夜精品| 日韩免费观看网站| 在线观看不卡的av| 国内成人精品2018免费看| 91在线高清视频| 欧美自拍偷拍一区二区| 99久久精品国产毛片| 精品综合在线| а√天堂中文在线资源bt在线| 久久久.com| 一区二区三区四区欧美| 中文字幕中文字幕在线中高清免费版 | www 日韩| 一区二区三区在线看| 91动漫在线看| 91精品韩国| 91精品国产综合久久小美女| 中文字幕 欧美 日韩| 欧美18免费视频| 亚洲女成人图区| 久久久久麻豆v国产| 综合天天久久| 欧美与欧洲交xxxx免费观看| 中文字幕乱码中文字幕| 国产91在线|亚洲| 欧美激情视频一区二区三区| 欧美激情午夜| 午夜精品久久一牛影视| 亚洲激情在线观看视频| 日韩最新av| 国产亚洲精品va在线观看| 午夜三级在线观看| 日韩一区二区免费看| 国产精品久久久久久搜索| 国产三区在线播放| 91麻豆精东视频| 日本黄色播放器| 免费成人直播| 欧美大片一区二区三区| 国产真人做爰视频免费| 精品动漫3d一区二区三区免费| 国产97在线|日韩| 亚洲国产综合一区| 欧美激情一区二区三区四区 | 激情影院在线| 欧美午夜精品一区二区蜜桃| 中文字幕99页| 欧美电影三区| 欧美一级视频在线观看| 国产wwwwwww| 国产精品毛片久久久久久| 免费看日本毛片| 日韩视频一二区| 色吧影院999| 六月丁香婷婷综合| 国产成人8x视频一区二区| 亚洲欧洲精品在线观看| 婷婷午夜社区一区| 精品福利视频一区二区三区| 小早川怜子一区二区的演员表| 噜噜噜久久亚洲精品国产品小说| 粉嫩av免费一区二区三区| 69xxxx欧美| 在线视频一区二区免费| 人人妻人人澡人人爽人人精品| 国产精品久久| 亚洲综合中文字幕在线| 在线激情免费视频| 欧美在线高清视频| 一级性生活大片| 国产欧美一级| 精品国产乱码一区二区三区四区| 日本动漫同人动漫在线观看| 欧美精品在线视频| 欧美aaa级片| 丝袜亚洲另类丝袜在线| 欧美第一黄网| 黑人巨大精品欧美一区二区桃花岛| 亚洲国产精品推荐| 日本三级网站在线观看| 不卡在线观看av| 2018国产在线| 婷婷激情久久| 日本精品久久电影| 精品久久久久一区二区三区| 色综合久久久久综合体桃花网| 黄色片视频免费观看| 亚洲东热激情| 蜜桃在线一区二区三区精品| 在线黄色的网站| 亚洲欧洲av一区二区| 无码人妻丰满熟妇精品| 国产亲近乱来精品视频| 午夜免费一区二区| 日韩欧美一区二区三区在线视频| 国产精品白嫩美女在线观看| 91社区在线高清| 欧美喷潮久久久xxxxx| 蜜桃av免费观看| 免费久久99精品国产| 中文字幕av日韩精品| www.成人| 久久人人爽人人爽人人片av高清| 十八禁一区二区三区| 日本韩国一区二区三区| 大吊一区二区三区| 国产精品系列在线播放| 大胆欧美熟妇xx| 秋霞影视一区二区三区| 国产精品69av| av色综合久久天堂av色综合在| 日韩网站在线看片你懂的| 国产精品日日夜夜| 久久精品在线观看| 中文字幕国产高清| 影音先锋久久| 亚洲精品一区二区三区樱花| 日韩激情精品| 91av在线播放视频| 91成人高清| 亚洲国产97在线精品一区| 国产黄网在线观看| 亚洲日本在线天堂| 双性尿奴穿贞c带憋尿| 久久99精品国产麻豆婷婷洗澡| 91传媒免费视频| 天堂网av2018| 久久久伦理片| 国产精品久久久久久久久久久久久| 日韩在线观看www| 亚洲第一免费播放区| 夜夜躁日日躁狠狠久久av| 亚洲男人天堂一区| 9.1成人看片免费版| 国产一区日韩二区欧美三区| 又粗又黑又大的吊av| 99久久精品网| 美女被啪啪一区二区| 久久99成人| 国产99久久精品一区二区永久免费 | 天堂网一区二区三区| 国产精品人妖ts系列视频| 日本黄色大片在线观看| 日本视频一区二区| 久久国产精品网| 国产精品国内免费一区二区三区| 国产精品久久精品国产| 亚洲视频资源| 欧美尤物巨大精品爽| 影音先锋男人在线资源| 在线亚洲欧美视频| 青梅竹马是消防员在线| 精品区一区二区| 97人妻人人澡人人爽人人精品| 欧美丝袜一区二区三区| 久久久久无码国产精品| 中文字幕在线观看一区| 国产一区二区三区四区五区六区| 国产成都精品91一区二区三| 一区二区三区四区毛片| 蜜臀av一区二区| 乱子伦视频在线看| 亚洲一区黄色| 九一国产精品视频| 欧美午夜国产| 天天操天天干天天玩| 韩日一区二区三区| 免费国产一区二区| 免费日韩一区二区三区| 国产精品入口免费| 91成人午夜| www.一区二区三区| 日韩精品一区国产| 亚洲一区精品电影| 9999精品免费视频| 国产精品视频yy9099| 久久久加勒比| 国产区精品在线观看| 国产激情欧美| 国产在线观看一区二区三区| 国产美女久久| 成人日韩av在线| 成人亚洲精品| 91九色在线观看| 大伊香蕉精品在线品播放| 国产精品视频500部| 136福利精品导航| 999久久久| 国产精品男女| 欧美久久综合性欧美| 欧美日韩水蜜桃| 亚洲人体一区| 中文字幕一区二区三三| 99国产精品白浆在线观看免费| 亚洲天堂成人| 国产最新免费视频| 久久黄色影院| 国产成人在线综合| 国产成人啪午夜精品网站男同| 婷婷五月精品中文字幕| 99精品视频一区| 一级黄色录像毛片| 亚洲同性gay激情无套| 久久免费精彩视频| 色综合久久久久综合体桃花网| 中文字幕无码乱码人妻日韩精品| 欧美久久高跟鞋激| 国产18精品乱码免费看| 亚洲精品中文字幕av| 成人在线免费看| 久久综合网hezyo| 日本不卡1234视频| 国产精品一区二区电影| 日韩视频一区二区三区四区| 国内精品一区二区| 欧美日韩在线二区| av动漫在线免费观看| 亚洲一区一卡| 91香蕉国产线在线观看| 成人av一区二区三区| 国产精品久久久视频| 亚洲国产成人高清精品| 波多野结衣视频在线看| 日韩亚洲欧美成人一区| 天堂a√中文在线| 久久九九国产精品怡红院 | 亚洲福利一二三区| 亚洲第一网站在线观看| 日韩一区和二区| 国产小视频在线| 色在人av网站天堂精品| av亚洲一区二区三区| 成人动漫视频在线观看完整版| 激情综合网五月| 久久久久久久香蕉| 男女男精品视频| 亚洲欧美在线不卡| 亚洲欧美综合另类在线卡通| av大片在线免费观看| 日韩一区二区在线观看视频| 国产一区电影| 97在线观看视频国产| 精品视频在线观看网站| 日韩国产在线一区| 99精品国产在热久久婷婷| а 天堂 在线| 国产精品视频线看| 伦av综合一区| 亚洲高清在线观看| 一区二区三区伦理| 国产欧美日韩综合精品| 色88888久久久久久影院| 欧美视频在线第一页| 麻豆成人综合网| 白白色免费视频| 欧美性xxxxxxxxx| 色屁屁草草影院ccyycom| 欧美成人午夜影院| 日韩一级特黄| 翔田千里亚洲一二三区| 久久久久一区| 国产又黄又粗又猛又爽的视频| 亚洲欧美另类综合偷拍| 亚洲天堂网视频| 中文字幕精品av| 草莓视频成人appios| 欧美一区国产一区| 欧美亚洲一级| 香蕉视频黄色在线观看| 欧美日韩亚洲成人| 神马一区二区三区| 久久免费视频这里只有精品| 日韩区欧美区| 18禁裸男晨勃露j毛免费观看| 国产一区二区女| 欧美黄色免费看| 精品国产一区二区在线观看| 3d玉蒲团在线观看| 亚洲r级在线观看| 欧美一区高清| 日本泡妞xxxx免费视频软件| 一区二区三区四区不卡在线| 国产手机av在线| 九九九热精品免费视频观看网站| 精品久久国产一区| 欧美视频在线第一页| 岛国av在线一区| 日韩在线视频免费播放| 精品中文视频在线| 全亚洲第一av番号网站| 日韩精品一线二线三线| 日本在线播放一区二区三区| 欧美午夜激情影院| 欧美日韩国产一级片| 久久77777| 成人免费视频观看视频| 最新国产拍偷乱拍精品| 亚洲中文字幕无码av| 91九色最新地址| 国产黄a三级三级三级av在线看| 亚洲自拍偷拍第一页| 亚洲国产精品一区制服丝袜| 国产精品无码网站| 在线免费一区三区| 黄av在线播放| 国语精品免费视频| 视频在线观看国产精品| 亚洲精品一区二区三区在线播放| 日韩情涩欧美日韩视频| 深夜av在线| 亚洲午夜在线观看| 国产成人免费在线| 久久久久久久久久久久久av| 正在播放欧美视频| 日韩精品亚洲专区在线观看| 久久综合色视频| 国产精品美女久久久久久久| 亚洲AV午夜精品| 日本免费在线精品| 亚洲精品99| 亚洲欧美色图视频| 91麻豆精品国产91久久久久久久久| sm在线观看| 中日韩在线视频| 99久久亚洲一区二区三区青草| 中文字幕精品无码亚| 欧美激情国产高清| 国内精品久久久久久久影视简单| xxxx视频在线观看| 在线观看日韩高清av| 亚洲七七久久综合桃花剧情介绍| 欧美在线视频一区二区三区| 国产乱码精品一品二品| 在线视频一区二区三区四区| 欧美日韩国产va另类| 精品久久久久久久久久久下田| 亚洲欧美日韩中文字幕在线观看| 91久久精品国产91性色tv| 国产又色又爽又黄刺激在线视频|