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

從進程棧內存底層原理到Segmentation fault報錯

開發 前端
堆棧的物理內存是什么時候分配的?進程在加載的時候只是會給新進程的棧內存分配一段地址空間范圍。而真正的物理內存是等到訪問的時候觸發缺頁中斷,再從伙伴系統中申請的。

大家好,我是飛哥!

棧是編程中使用內存最簡單的方式。例如,下面的簡單代碼中的局部變量 n 就是在堆棧中分配內存的。

#include <stdio.h>
void main()
{
int n = 0;
printf("0x%x\n",&v);
}

那么我有幾個問題想問問大家,看看大家對于堆棧內存是否真的了解。

  • 堆棧的物理內存是什么時候分配的?
  • 堆棧的大小限制是多大?這個限制可以調整嗎?
  • 當堆棧發生溢出后應用程序會發生什么?

如果你對以上問題還理解不是特別深刻,飛哥今天來帶你好好修煉進程堆棧內存這塊的內功!

一、進程堆棧的初始化

前面我們在《你寫的代碼是如何跑起來的?》這篇文章中介紹了進程的啟動過程。進程啟動調用 exec 加載可執行文件過程的時候,會給進程棧申請一個 4 KB 的初始內存。我們今天來專門抽取并看一下這段邏輯。

加載系統調用 execve 依次調用 do_execve、do_execve_common 來完成實際的可執行程序加載。

//file:fs/exec.c
static int do_execve_common(const char *filename, ...)
{
bprm_mm_init(bprm);
...
}

在 bprm_mm_init 中會申請一個全新的地址空間 mm_struct 對象,準備留著給新進程使用。

//file:fs/exec.c
static int bprm_mm_init(struct linux_binprm *bprm)
{
//申請個全新的地址空間 mm_struct 對象
bprm->mm = mm = mm_alloc();
__bprm_mm_init(bprm);
}

還會給新進程的棧申請一頁大小的虛擬內存空間,作為給新進程準備的棧內存。申請完后把棧的指針保存到 bprm->p 中記錄起來。

//file:fs/exec.c
static int __bprm_mm_init(struct linux_binprm *bprm)
{
bprm->vma = vma = kmem_cache_zalloc(vm_area_cachep, GFP_KERNEL);
vma->vm_end = STACK_TOP_MAX;
vma->vm_start = vma->vm_end - PAGE_SIZE;
...

bprm->p = vma->vm_end - sizeof(void *);
}

我們平時所說的進程虛擬地址空間在 Linux 是通過一個個的 vm_area_struct 對象來表示的。

圖片

每一個 vm_area_struct(就是上面 __bprm_mm_init 函數中的 vma)對象表示進程虛擬地址空間里的一段范圍,其 vm_start 和 vm_end 表示啟用的虛擬地址范圍的開始和結束。

//file:include/linux/mm_types.h
struct vm_area_struct {
unsigned long vm_start;
unsigned long vm_end;
...
}

要注意的是這只是地址范圍,而不是真正的物理內存分配。

在上面 __bprm_mm_init 函數中通過 kmem_cache_zalloc 申請了一個 vma 內核對象。vm_end 指向了 STACK_TOP_MAX(地址空間的頂部附近的位置),vm_start 和 vm_end 之間留了一個 Page 大小。也就是說默認給棧準備了 4KB 的大小。最后把棧的指針記錄到 bprm->p 中。

圖片

接下來進程加載過程會使用 load_elf_binary 真正開始加載可執行二進制程序。在加載時,會把前面準備的進程棧的地址空間指針設置到了新進程 mm 對象上。

//file:fs/binfmt_elf.c
static int load_elf_binary(struct linux_binprm *bprm)
{ //ELF 文件頭解析
//Program Header 讀取
//清空父進程繼承來的資源
retval = flush_old_exec(bprm);
...

current->mm->start_stack = bprm->p;
}

圖片

這樣新進程將來就可以使用棧進行函數調用,以及局部變量的申請了。

前面我們說了,這里只是給棧申請了地址空間對象,并沒有真正申請物理內存。我們接著再來看一下,物理內存頁究竟是什么時候分配的。

二、物理頁的申請

當進程在運行的過程中在棧上開始分配和訪問變量的時候,如果物理頁還沒有分配,會觸發缺頁中斷。在缺頁中斷種來真正地分配物理內存。

為了避免篇幅過長,觸發缺頁中斷的過程就先不展開了。我們直接看一下缺頁中斷的核心處理入口 __do_page_fault,它位于 arch/x86/mm/fault.c 文件下。

//file:arch/x86/mm/fault.c
static void __kprobes
__do_page_fault(struct pt_regs *regs, unsigned long error_code)
{
...
//根據新的 address 查找對應的 vma
vma = find_vma(mm, address);

//如果找到的 vma 的開始地址比 address 小
//那么就不調用expand_stack了,直接調用
if (likely(vma->vm_start <= address))
goto good_area;
...
if (unlikely(expand_stack(vma, address))) {
bad_area(regs, error_code, address);
return;
}
good_area:
//調用handle_mm_fault來完成真正的內存申請
fault = handle_mm_fault(mm, vma, address, flags);

}

當訪問棧上變量的內存的時候,首先會調用 find_vma 根據變量地址 address 找到其所在的 vma 對象。接下來調用的 if (vma->vm_start <= address) 是在判斷地址空間還夠不夠用。

圖片

    

如果棧內存 vma 的 start 比要訪問的 address 小,則證明地址空間夠用,只需要分配物理內存頁就行了。如果棧內存 vma 的 start 比要訪問的 address 大,則需要調用 expand_stack 先擴展一下棧的虛擬地址空間 vma。擴展虛擬地址空間的具體細節我們在第三節再講。

這里先假設要訪問的變量地址 address 處于棧內存 vma 對象的 vm_start 和 vm_end 之間。那么缺頁中斷處理就會跳轉到 good_area 處運行。在這里調用 handle_mm_fault 來完成真正物理內存的申請。

//file:mm/memory.c
int handle_mm_fault(struct mm_struct *mm, struct vm_area_struct *vma,
unsigned long address, unsigned int flags)
{
...

//依次查看每一級頁表項
pgd = pgd_offset(mm, address);
pud = pud_alloc(mm, pgd, address);
pmd = pmd_alloc(mm, pud, address);
pte = pte_offset_map(pmd, address);

return handle_pte_fault(mm, vma, address, pte, pmd, flags);
}

Linux 是用四級頁表來管理虛擬地址空間到物理內存之間的映射管理的。所以在實際申請物理頁面之前,需要先 check 一遍需要的每一級頁表項是否存在,不存在的話需要申請。

為了好區分,Linux 還給每一級頁表都起了一個名字。

  • 一級頁表:Page Global Dir,簡稱 pgd
  • 二級頁表:Page Upper Dir,簡稱 pud
  • 三級頁表:Page Mid Dir,簡稱 pmd
  • 四級頁表:Page Table,簡稱 pte

看一下下面這個圖就比較好理解了

圖片

//file:mm/memory.c
int handle_pte_fault(struct mm_struct *mm,
struct vm_area_struct *vma, unsigned long address,
pte_t *pte, pmd_t *pmd, unsigned int flags)
{
...

//匿名映射頁處理
return do_anonymous_page(mm, vma, address,
pte, pmd, flags);
}

在 handle_pte_fault 會處理很多種的內存缺頁處理,比如文件映射缺頁處理、swap缺頁處理、寫時復制缺頁處理、匿名映射頁處理等等幾種情況。我們今天討論的主題是棧內存,這個對應的是匿名映射頁處理,會進入到 do_anonymous_page 函數中。

//file:mm/memory.c
static int do_anonymous_page(struct mm_struct *mm, struct vm_area_struct *vma,
unsigned long address, pte_t *page_table, pmd_t *pmd,
unsigned int flags)
{
// 分配可移動的匿名頁面,底層通過 alloc_page
page = alloc_zeroed_user_highpage_movable(vma, address);
...
}

在 do_anonymous_page 調用 alloc_zeroed_user_highpage_movable 分配一個可移動的匿名物理頁出來。在底層會調用到伙伴系統的 alloc_pages 進行實際物理頁面的分配。

內核是用伙伴系統來管理所有的物理內存頁的。其它模塊需要物理頁的時候都會調用伙伴系統對外提供的函數來申請物理內存。

圖片

關于伙伴系統我們之前在內核內存管理 這篇文章中詳細介紹過,感興趣的同學可以移步到該文中詳細了解。

到了這里,開篇的問題一就有答案了,堆棧的物理內存是什么時候分配的?進程在加載的時候只是會給新進程的棧內存分配一段地址空間范圍。而真正的物理內存是等到訪問的時候觸發缺頁中斷,再從伙伴系統中申請的。

三、棧的自動增長

前面我們看到了,進程在被加載啟動的時候,棧內存默認只分配了 4 KB 的空間。那么隨著程序的運行,當棧中保存的調用鏈,局部變量越來越多的時候,必然會超過 4 KB。

我回頭看下缺頁處理函數 __do_page_fault。如果棧內存 vma 的 start 比要訪問的 address 大,則需要調用 expand_stack 先擴展一下棧的虛擬地址空間 vma。

圖片

回顧 __do_page_fault 源碼,看到擴充棧空間的是由 expand_stack 函數來完成的。

//file:arch/x86/mm/fault.c
static void __kprobes
__do_page_fault(struct pt_regs *regs, unsigned long error_code)
{
...
if (likely(vma->vm_start <= address))
goto good_area;

//如果棧 vma 的開始地址比 address 大,需要擴大棧
if (unlikely(expand_stack(vma, address))) {
bad_area(regs, error_code, address);
return;
}
good_area:
...
}

我們來看下 expand_stack 的內部細節。

其實在 Linux 棧地址空間增長是分兩種方向的,一種是從高地址往低地址增長,一種是反過來。大部分情況都是由高往低增長的。本文只以向下增長為例。

//file:mm/mmap.c
int expand_stack(struct vm_area_struct *vma, unsigned long address)
{
...
return expand_downwards(vma, address);
}

int expand_downwards(struct vm_area_struct *vma, unsigned long address)
{
...
//計算棧擴大后的最后大小
size = vma->vm_end - address;

//計算需要擴充幾個頁面
grow = (vma->vm_start - address) >> PAGE_SHIFT;

//判斷是否允許擴充
acct_stack_growth(vma, size, grow);

//如果允許則開始擴充
vma->vm_start = address;

return ...
}

在 expand_downwards 中先進行了幾個計算。

  • 計算出新的堆棧大小。計算公式是 size = vma->vm_end - address;
  • 計算需要增長的頁數。計算公式是 grow = (vma->vm_start - address) >> PAGE_SHIFT;

然后會判斷此次棧空間是否被允許擴充, 判斷是在 acct_stack_growth 中完成的。如果允許擴展,則簡單修改一下 vma->vm_start 就可以了!

圖片

我們再來看 acct_stack_growth 都進行了哪些限制判斷。

//file:mm/mmap.c
static int acct_stack_growth(struct vm_area_struct *vma, unsigned long size, unsigned long grow)
{
...
//檢查地址空間是否超出限制
if (!may_expand_vm(mm, grow))
return -ENOMEM;

//檢查是否超出棧的大小限制
if (size > ACCESS_ONCE(rlim[RLIMIT_STACK].rlim_cur))
return -ENOMEM;
...
return 0;
}

在 acct_stack_growth 中只是進行一系列的判斷。may_expand_vm? 判斷的是增長完這幾個頁后是否超出整體虛擬地址空間大小的限制。rlim[RLIMIT_STACK].rlim_cur 中記錄的是棧空間大小的限制。這些限制都可以通過 ulimit 命令查看到。

# ulimit -a
......
max memory size (kbytes, -m) unlimited
stack size (kbytes, -s) 8192
virtual memory (kbytes, -v) unlimited

上面的這個輸出表示虛擬地址空間大小沒有限制,棧空間的限制是 8 MB。如果進程棧大小超過了這個限制,會返回 -ENOMEM。如果覺得系統默認的大小不合適可以通過 ulimit 命令修改。

# ulimit -s 10240
# ulimit -a
stack size (kbytes, -s) 10240

到這里開篇的第二個問題也有答案了,堆棧的大小限制是多大?這個限制可以調整嗎?進程堆棧大小的限制在每個機器上都是不一樣的,可以通過 ulimit 命令來查看,也同樣可以使用該命令修改。

至于開篇的問題3,當堆棧發生溢出后應用程序會發生什么?寫個簡單的無限遞歸調用就知道了,估計你也遇到過。報錯結果就是

'Segmentation fault (core dumped)

本文總結

來總結下本文的內容,本文討論了進程棧內存的工作原理。

第一,進程在加載的時候給進程棧申請了一塊虛擬地址空間 vma 內核對象。vm_start 和 vm_end 之間留了一個 Page ,也就是說默認給棧準備了 4KB 的空間。第二,當進程在運行的過程中在棧上開始分配和訪問變量的時候,如果物理頁還沒有分配,會觸發缺頁中斷。在缺頁中斷中調用內核的伙伴系統真正地分配物理內存。第三,當棧中的存儲超過 4KB 的時候會自動進行擴大。不過大小要受到限制,其大小限制可以通過 ?ulimit -s來查看和設置。

圖片

注意,今天我們討論的都是進程棧。線程棧和進程棧有些不一樣。等后面有空我們再單獨看線程棧。

在回顧和總結下開篇我們拋出的三個問題: 

問題一:堆棧的物理內存是什么時候分配的?進程在加載的時候只是會給新進程的棧內存分配一段地址空間范圍。而真正的物理內存是等到訪問的時候觸發缺頁中斷,再從伙伴系統中申請的。 

問題二:堆棧的大小限制是多大?這個限制可以調整嗎?進程堆棧大小的限制在每個機器上都是不一樣的,可以通過 ulimit 命令來查看,也同樣可以使用該命令修改。 

問題3:當堆棧發生溢出后應用程序會發生什么?當堆棧溢出的時候,我們會收到報錯 “Segmentation fault (core dumped)”

最后,拋個問題大家一起思考吧。你覺得內核為什么要對進程棧的地址空間進行限制呢?

責任編輯:武曉燕 來源: 開發內功修煉
相關推薦

2025-09-29 05:00:00

Linux線程棧內存

2021-05-11 07:51:30

React ref 前端

2025-04-07 03:02:00

電腦內存數據

2025-09-08 07:14:25

2024-07-07 21:49:22

2025-04-02 07:29:14

2018-05-17 15:18:48

Logistic回歸算法機器學習

2025-11-13 08:08:15

2021-01-18 09:42:41

C語言底層技巧

2024-12-17 08:04:04

2024-03-27 10:14:48

2010-06-29 14:20:52

2025-10-27 01:22:00

HTTP接口API

2025-11-07 04:00:00

2025-09-15 01:45:00

2021-07-20 10:26:53

源碼底層ArrayList

2025-09-02 03:33:00

2022-02-28 10:05:12

組件化架構設計從原組件化模塊化

2020-04-28 22:12:30

Nginx正向代理反向代理

2023-08-03 08:03:05

點贊
收藏

51CTO技術棧公眾號

国产日韩精品视频一区二区三区| 91sp网站在线观看入口| 欧美精品久久久久久| 色视频成人在线观看免| 欧美精品一区二区三区在线看午夜| 国产精彩视频在线观看| 久久精品国产亚洲blacked| 色偷偷久久人人79超碰人人澡| 久久亚裔精品欧美| 97在线视频人妻无码| 亚洲美女少妇无套啪啪呻吟| 中文字幕欧美日韩| 精品人妻在线视频| 国产精品99久久久久久董美香| 一区二区三区免费| 日韩精品在在线一区二区中文| 亚洲国产成人精品一区二区三区| 三级成人在线视频| 欧美激情免费看| 国产一区二区三区视频播放| 老牛国内精品亚洲成av人片| 欧美性videos高清精品| 黄色影视在线观看| 国产剧情在线观看| www久久精品| 成人综合电影| 国产乱码精品一区二区| 日韩在线一区二区| 国语自产精品视频在线看一大j8 | 国产毛片一区二区三区va在线| 99国产精品自拍| 久久国产精品电影| 九九热久久免费视频| 天天躁日日躁狠狠躁欧美巨大小说| 91精品啪在线观看国产60岁| 无码内射中文字幕岛国片| 成人在线高清免费| 亚洲黄色录像片| 在线看视频不卡| 阿v免费在线观看| 久久久蜜桃精品| 黑人巨大精品欧美一区二区小视频| 99草在线视频| 国产自产视频一区二区三区| 国产精品嫩草视频| 欧美日韩 一区二区三区| 毛片一区二区| 日韩免费在线免费观看| youjizz在线视频| 午夜在线精品偷拍| 日韩av理论片| 中文文字幕一区二区三三| 老司机一区二区三区| 欧美亚洲国产视频| 免费av网站在线| 麻豆精品网站| 国产精品丝袜久久久久久高清 | 高清电影在线免费观看| 亚洲精品视频观看| 美女扒开大腿让男人桶| 怡红院红怡院欧美aⅴ怡春院| 日韩美女视频19| 亚洲精品偷拍视频| 99视频免费在线观看| 悠悠色在线精品| 精品无码国产一区二区三区av| 国内在线视频| 欧美日韩视频免费播放| 人妻熟女一二三区夜夜爱| 日本综合字幕| 欧美日本韩国一区二区三区视频| 伊人成人222| 久久久国产精品入口麻豆| 欧美一区二区在线免费观看| 一卡二卡三卡四卡五卡| 国偷自产视频一区二区久| 日韩电影中文字幕av| 极品人妻videosss人妻| 婷婷亚洲五月色综合| 欧美第一淫aaasss性| 国产 日韩 欧美 在线| 日韩在线a电影| 成人激情在线观看| 日本波多野结衣在线| 国产日韩欧美精品电影三级在线| 一区二区三区四区国产| 欧美另类tv| 日本韩国视频一区二区| 日本美女久久久| 亚洲电影一级片| 日韩视频免费在线| 日韩xxxxxxxxx| 蜜桃精品视频在线| 国产精品一区二区a| 日本一级在线观看| 中文字幕欧美一区| heyzo国产| 亚洲欧美专区| 日韩精品中文字幕在线观看| 国产精品综合激情| 99亚洲一区二区| 成人国产精品日本在线| 网站黄在线观看| 亚洲人成网站色在线观看 | 三级精品在线观看| 国产精品青青草| 老司机精品视频在线观看6| 欧美日韩国产精品| 性高潮久久久久久| 欧美中文一区二区| 欧美一级bbbbb性bbbb喷潮片| 亚洲专区第一页| 久久蜜桃av一区二区天堂| 4444亚洲人成无码网在线观看| 欧美日韩电影免费看| 欧美精品一区二区三区高清aⅴ| 欧美巨胸大乳hitomi| 在线午夜精品| 国产精品裸体一区二区三区| 三区四区在线视频| 在线观看国产一区二区| 性色av蜜臀av色欲av| 国内综合精品午夜久久资源| 国产精品丝袜视频| av在线资源站| 色呦呦一区二区三区| 欧美大片免费播放器| 国产精品草草| 91在线在线观看| 国产黄色在线网站| 欧美裸体一区二区三区| 国产黄色大片免费看| 噜噜噜在线观看免费视频日韩| 成人欧美一区二区三区黑人免费| av在线官网| 91精品国产色综合久久久蜜香臀| 成人性视频免费看| 美女免费视频一区二区| 日韩欧美第二区在线观看| 成人福利视频| 亚洲视频在线观看免费| 中文字幕第四页| 91老司机福利 在线| 欧美视频在线观看网站| 林ゆな中文字幕一区二区| 久久人人看视频| 日本人妻丰满熟妇久久久久久| 亚洲电影在线播放| 校园激情久久| 亚洲国产成人高清精品| wwwxxx色| 欧美精品一卡| 国产91色在线|亚洲| 日韩经典av| 亚洲国产97在线精品一区| 日本一级淫片免费放| 不卡免费追剧大全电视剧网站| 六月婷婷在线视频| 日本一道高清一区二区三区| 2019中文字幕免费视频| 男操女在线观看| 欧美自拍丝袜亚洲| 尤物在线免费视频| 国产suv精品一区二区6| 免费看日本毛片| 免费看日本一区二区| 国产精品美女免费| free性欧美hd另类精品| 日韩欧美不卡一区| 日韩精品1区2区| 国产丝袜美腿一区二区三区| 中文字幕av专区| 欧美在线三区| 久久精品成人一区二区三区蜜臀| 视频二区不卡| 久久久精品久久| 日本精品一区二区在线观看| 在线看一区二区| 天堂网avav| 91在线国产福利| 日本 片 成人 在线| 欧美~级网站不卡| 久久日韩精品| 国产精品欧美一区二区三区不卡| 久久久久久久久网站| 毛片网站在线观看| 91精品国产高清一区二区三区| 日韩欧美三级在线观看| 国产精品网站在线观看| 欧美图片自拍偷拍| 日韩中文字幕区一区有砖一区| 视频一区二区视频| 日韩精品丝袜美腿| 成人免费看吃奶视频网站| 黄色漫画在线免费看| 精品国产自在精品国产浪潮| 性xxxx视频播放免费| 制服丝袜中文字幕一区| 男人天堂2024| 亚洲综合在线观看视频| 日韩毛片无码永久免费看| 成人黄色大片在线观看| 午夜免费看视频| 香蕉成人久久| 丁香六月激情网| 91日韩视频| 欧美在线视频二区| 精品一区二区男人吃奶| 91在线观看欧美日韩| 日韩欧美精品电影| 亚洲3p在线观看| 在线观看av免费| 视频在线一区二区| 免费在线黄色电影| 亚洲国产精品中文| 精品久久久中文字幕人妻| 欧美性一区二区| 800av免费在线观看| 一区二区日韩电影| 污软件在线观看| 亚洲国产精品99久久久久久久久| 黄色av网址在线观看| 国产成人av一区二区三区在线 | 小说区视频区图片区| 久久91成人| 精品欧美一区二区久久久伦| 中文一区二区三区四区| 亚洲www在线观看| 国产麻豆一区| 国产精品日本精品| 中文字幕在线视频久| 久久免费精品视频| 国产啊啊啊视频在线观看| 久久97久久97精品免视看| 黄网站在线免费| 久久亚洲私人国产精品va| 青青青青在线| 日韩中文字幕国产精品| 色老头视频在线观看| 色香阁99久久精品久久久| a中文在线播放| 在线观看成人黄色| 尤物在线视频| 精品国产视频在线| 国产精品久久久久久福利| x99av成人免费| 免费黄网站在线| 大量国产精品视频| 色老头在线观看| 久久久久女教师免费一区| hd国产人妖ts另类视频| 午夜精品视频在线| 在线观看涩涩| 国产精品极品尤物在线观看| 国产亚洲欧美日韩精品一区二区三区| 国产成人精品综合久久久| 懂色aⅴ精品一区二区三区| 国产精品xxx视频| 日韩五码电影| 91精品国产91久久久久青草| av日韩精品| 久久久久久久久久码影片| 国产一区二区欧美| 伊人久久大香线蕉精品| 伊人久久大香线| 水蜜桃色314在线观看| 美女被久久久| 午夜视频在线观| 丁香婷婷深情五月亚洲| 菠萝菠萝蜜网站| 欧美国产一区二区| 免费在线观看一级片| 午夜精品免费在线观看| 中文字幕在线欧美| 7777精品伊人久久久大香线蕉| 亚洲成人中文字幕在线| 日韩精品视频在线观看免费| 1769在线观看| 欧美黑人性生活视频| 一区二区乱码| 亚洲自拍中文字幕| 日韩欧美在线精品| 手机成人av在线| 亚洲一区二区三区四区五区午夜| 白嫩少妇丰满一区二区| 激情深爱一区二区| 欧美一区二区三区成人精品| 国产精品久久影院| 亚洲国产综合久久| 欧美日韩国产一级片| 三级小视频在线观看| 综合久久五月天| av蜜臀在线| 国产在线拍揄自揄视频不卡99| 中文字幕一区图| 亚洲免费视频一区| 国产欧美日本| 91香蕉视频在线观看视频| 久久日韩精品一区二区五区| 久久免费看少妇高潮v片特黄| 欧美午夜精品久久久久久人妖 | 成人h动漫精品一区二区| 国产精品久久久视频| 亚洲国产综合在线| 91肉色超薄丝袜脚交一区二区| 日韩av在线不卡| 羞羞的视频在线观看| 国产精品中文字幕在线| 日本中文字幕在线一区| 成年在线观看视频| 久久精品99久久久| 国产精品三级在线观看无码| 亚洲一级二级在线| 国产精品欧美综合亚洲| 丝袜亚洲另类欧美重口| 中文不卡1区2区3区| 国产精品日韩欧美一区二区| 五月天久久网站| 91看片在线免费观看| 91一区二区三区在线播放| 久久久久久欧美精品se一二三四| 欧美日韩的一区二区| 国产高清一级毛片在线不卡| 5566成人精品视频免费| 久久婷婷国产| av免费看网址| 国产成人av电影在线播放| 最新黄色av网址| 欧美日韩国产高清一区| 999在线视频| 国产精品久久久久久久久久久久久| 亚洲ab电影| 欧美在线观看成人| 91香蕉国产在线观看软件| 日本少妇性生活| 亚洲第一精品夜夜躁人人躁 | 日本中文字幕久久看| 欧美日韩一区二区三区在线电影 | 久久99久久久久| 日本美女bbw| 欧美片网站yy| 黄a在线观看| 999视频在线免费观看| 午夜精品久久| zjzjzjzjzj亚洲女人| 亚洲一区在线观看视频| 亚洲免费一级片| 国内成人精品一区| 天美av一区二区三区久久| 大肉大捧一进一出好爽视频| 91在线国内视频| 国产精品熟女视频| 最近2019中文免费高清视频观看www99| 黄色精品视频| 成年人黄色在线观看| 国产乱码精品一区二区三区五月婷| wwwav国产| 精品国产不卡一区二区三区| 国产不卡123| 日本一区二区三区免费看| 捆绑调教一区二区三区| www青青草原| 亚洲成人黄色在线| 亚洲欧美一区二区三区| 亚洲欧美日韩精品在线| 国产中文一区二区三区| 久久亚洲av午夜福利精品一区| 欧美精品一区二区精品网| 原纱央莉成人av片| 亚洲欧美日韩在线综合 | 山东少妇露脸刺激对白在线| 91精品久久久久久久99蜜桃| 日本在线视频www鲁啊鲁| 久久精品美女| 久久激情综合网| 日韩福利片在线观看| 国产小视频国产精品| 国产高清亚洲| 日韩少妇内射免费播放18禁裸乳| 国产亚洲1区2区3区| 国产麻豆免费观看| 国产91精品久| 91精品一区二区三区综合在线爱 | 亚洲精品3区| 一区二区三区视频网| 亚洲国产成人av好男人在线观看| 黄色片在线免费看| 99在线视频播放| 日韩精品亚洲专区| 久久免费视频99| 国产亚洲精品高潮| 在线播放一区二区精品视频| 日韩一级片播放| 天天av天天翘天天综合网| 日韩伦理在线观看| 久久精品国产一区二区三区日韩 | 亚洲久久一区二区| 日韩福利在线视频| 亚洲国产精品yw在线观看| 欧美国产视频|