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

posts - 297,  comments - 15,  trackbacks - 0
1. 前言: 有的程序可以通過編譯, 但在運(yùn)行時(shí)會(huì)出現(xiàn)Segment fault(段錯(cuò)誤). 這通常都是指針錯(cuò)誤引起的. 但這不像編譯錯(cuò)誤一樣會(huì)提示到文件->行, 而是沒有任何信息, 使得我們的調(diào)試變得困難起來.

    2. gdb: 有一種辦法是, 我們用gdb的step, 一步一步尋找. 這放在短小的代碼中是可行的, 但要讓你step一個(gè)上萬行的代碼, 我想你會(huì)從此厭惡程序員這個(gè)名字, 而把他叫做調(diào)試員. 我們還有更好的辦法, 這就是core file.

    3. ulimit: 如果想讓系統(tǒng)在信號(hào)中斷造成的錯(cuò)誤時(shí)產(chǎn)生core文件, 我們需要在shell中按如下設(shè)置: #設(shè)置core大小為無限 ulimit -c unlimited #設(shè)置文件大小為無限 ulimit unlimited 這些需要有root權(quán)限, 在ubuntu下每次重新打開中斷都需要重新輸入上面的第一條命令, 來設(shè)置core大小為無限.

    4. 用gdb查看core文件: 下面我們可以在發(fā)生運(yùn)行時(shí)信號(hào)引起的錯(cuò)誤時(shí)發(fā)生core dump了. 發(fā)生core dump之后, 用gdb進(jìn)行查看core文件的內(nèi)容, 以定位文件中引發(fā)core dump的行. gdb [exec file] [core file] 如: gdb ./test test.core 在進(jìn)入gdb后, 用bt命令查看backtrace以檢查發(fā)生程序運(yùn)行到哪里, 來定位core dump的文件->行.

1. 什么是Core:

Sam之前一直以為Core Dump中Core是 Linux Kernel的意思. 今天才發(fā)現(xiàn)在這里,Core是另一種意思:

在使用半導(dǎo)體作為內(nèi)存的材料前,人類是利用線圈當(dāng)作內(nèi)存的材料(發(fā)明者為王安),線圈就叫作 core ,用線圈做的內(nèi)存就叫作 core memory。如今 ,半導(dǎo)體工業(yè)澎勃發(fā)展,已經(jīng)沒有人用 core memory 了,不過,在許多情況下, 人們還是把記憶體叫作 core 。

2. 什么是Core Dump:

我們?cè)陂_發(fā)(或使用)一個(gè)程序時(shí),最怕的就是程序莫明其妙地當(dāng)?shù)?。雖然系統(tǒng)沒事,但我們下次仍可能遇到相同的問題。于是這時(shí)操作系統(tǒng)就會(huì)把程序當(dāng)?shù)?時(shí)的內(nèi)存內(nèi)容 dump 出來(現(xiàn)在通常是寫在一個(gè)叫 core 的 file 里面),讓 我們或是 debugger 做為參考。這個(gè)動(dòng)作就叫作 core dump。

3. Core Dump時(shí)會(huì)生成何種文件:

Core Dump時(shí),會(huì)生成諸如 core.進(jìn)程號(hào) 的文件。

4. 為何有時(shí)程序Down了,卻沒生成 Core文件。

Linux下,有一些設(shè)置,標(biāo)明了resources available to the shell and to processes。 可以使用#ulimit -a  來看這些設(shè)置。 (ulimit是bash built-in Command)

              -a     All current limits are reported

              -c     The maximum size of core files created

              -d     The maximum size of a process鈥檚 data segment

              -e     The maximum scheduling priority ("nice")

              -f     The maximum size of files written by the shell and its children

              -i     The maximum number of pending signals

              -l     The maximum size that m ay be locked into memory

              -m     The maximum resident set size (has no effect on Linux)

              -n     The maximum number of open file descriptors (most systems do not allow this value to be set)

              -p     The pipe size in 512-byte blocks (this may not be set)

              -q     The maximum number of bytes in POSIX message queues

              -r     The maximum real-time scheduling priority

              -s     The maximum stack size

              -t     The maximum amount of cpu time in seconds

              -u     The maximum number of processes available to a single user

              -v     The maximum amount of virtual memory available to the shell

              -x     The maximum number of file locks



 從這里可以看出,如果 -c是顯示:core file size          (blocks, -c)  如果這個(gè)值為0,則無法生成core文件。所以可以使用:
#ulimit -c 1024   或者 #ulimit -c unlimited   來使能 core文件。

如果程序出錯(cuò)時(shí)生成Core 文件,則會(huì)顯示Segmentation fault (core dumped) 。

5. Core Dump的核心轉(zhuǎn)儲(chǔ)文件目錄和命名規(guī)則:
/proc/sys/kernel /core_uses_pid可以控制產(chǎn)生的core文件的文件名中是否添加pid作為擴(kuò)展,如果添加則文件內(nèi)容為1,否則為0

6. 如何使用Core文件:
在Linux下,使用:
#gdb -c core.pid program_name
就可以進(jìn)入gdb模式。
輸入where,就可以指出是在哪一行被Down掉,哪個(gè)function內(nèi),由誰調(diào)用等等。
(gdb) where
或者輸入 bt。
(gdb) bt

7. 如何讓一個(gè)正常的程序down:
#kill -s SIGSEGV pid

8. 察看Core文件輸出在何處:
存放Coredump的目錄即進(jìn)程的當(dāng)前目錄,一般就是當(dāng)初發(fā)出命令啟動(dòng)該進(jìn)程時(shí)所在的目錄。但如果是通過腳本啟動(dòng),則腳本可能會(huì)修改當(dāng)前目錄,這時(shí)進(jìn)程真正的當(dāng)前目錄就會(huì)與當(dāng)初執(zhí)行腳本所在目錄不同。這時(shí)可以查看”/proc/<進(jìn)程pid>/cwd“符號(hào)鏈接的目標(biāo)來確定進(jìn)程真正的當(dāng)前目錄地址。通過系統(tǒng)服務(wù)啟動(dòng)的進(jìn)程也可通過這一方法查看。

9. 嵌入式設(shè)備下如何使用Core dump:
linux coredump配置與調(diào)試
Linux

Core Dump 配置與調(diào)試

1.core文件的生成開關(guān)和大小限制

---------------------------------

1)使用ulimit -c 命令可查看core文件的生成開關(guān)。若結(jié)果為0,則表示關(guān)閉了此功能,不會(huì)生成core文件。

2)使用ulimit -c filesize命令,可以限制core文件的大?。╢ilesize的單位為kbyte)。若ulimit -c unlimited,則表示core文件的大小不受限制。如果生成的信息超過此大小,將會(huì)被裁剪,最終生成一個(gè)不完整的core文件。在調(diào)試此core文件的時(shí)候,gdb會(huì)提示錯(cuò)誤。

2.core文件的名稱和生成路徑

----------------------------

若系統(tǒng)生成的core文件不帶其它任何擴(kuò)展名稱,則全部命名為core。新的core文件生成將覆蓋原來的core文件 。

1)/proc/sys /kernel/core_uses_pid可以控制core文件的文件名中是否添加pid作為擴(kuò)展。文件內(nèi)容為1,表示添加pid作為擴(kuò)展名,生成的 core文件格式為core.xxxx;為0則表示生成的core文件同一命名為core。

可通過以下命令修改此文件:
echo"1" >/proc/sys/kernel/core_uses_pid

2)proc/sys/kernel/core_pattern可以控制core文件保存位置和文件名格式。
可通過以下命令修改此文件:
echo"/corefile/core-%e-%p-%t" >core_pattern,可以將core文件統(tǒng)一生成到/corefile目錄下,產(chǎn)生的文件名為core-命令名-pid-時(shí)間戳

以下是參數(shù)列表:
%p - insert pid into filename 添加pid
%u - insert current uid into filename 添加當(dāng)前uid
%g - insert current gid into filename 添加當(dāng)前gid
%s - insert signal that caused the coredump into the filename  添加導(dǎo)致產(chǎn)生core的信號(hào)
%t - insert UNIX time that the coredump occurred into filename  添加core文件生成時(shí)的unix時(shí)間
%h - insert hostname where the coredump happened into filename  添加主機(jī)名
%e - insert coredumping executable name into filename  添加命令名

3.用gdb查看core文件:

下面我們可以在發(fā)生運(yùn)行時(shí)信號(hào)引起的錯(cuò)誤時(shí)發(fā)生core dump了.
發(fā)生 core dump之后,用gdb進(jìn)行查看core文件的內(nèi)容,以定位文件中引發(fā)core dump的行.

gdb [exec file] [core file]
如:gdb ./test test.core

在進(jìn)入gdb后,用 bt命令查看backtrace以檢查發(fā)生程序運(yùn)行到哪里,來定位core dump的文件->行.

4.開發(fā)板上使用core文件調(diào)試

-----------------------------

如果開發(fā)板的操作系統(tǒng)也是linux,core調(diào)試方法依然適用。如果開發(fā)板上不支持gdb,可將開發(fā)板的環(huán)境(頭文件、庫)、可執(zhí)行文件和core文件拷貝到PC的linux下,運(yùn)行相關(guān)命令即可。

注意:待調(diào)試的可執(zhí)行文件,在編譯的時(shí)候需要加-g,core文件才能正常顯示出錯(cuò)信息!

注意的問題:

在Linux下要保證程序崩潰時(shí)生成 Coredump要注意這些問題:

  一、要保證存放Coredump的目錄存在且進(jìn)程對(duì)該目錄有寫權(quán)限。存放Coredump 的目錄即進(jìn)程的當(dāng)前目錄,一般就是當(dāng)初發(fā)出命令啟動(dòng)該進(jìn)程時(shí)所在的目錄。但如果是通過腳本啟動(dòng),則腳本可能會(huì)修改當(dāng)前目錄,這時(shí)進(jìn)程真正的當(dāng)前目錄就會(huì)與當(dāng)初執(zhí)行腳本所在目錄不同。這時(shí)可以查看”/proc/進(jìn)程pid>/cwd“符號(hào)鏈接的目標(biāo)來確定進(jìn)程真正的當(dāng)前目錄地址。通過系統(tǒng)服務(wù)啟動(dòng)的進(jìn)程也可通過這一方法查看。

  二、若程序調(diào)用了seteuid()/setegid()改變了進(jìn)程的有效用戶或組,則在默認(rèn)情況下系統(tǒng)不會(huì)為這些進(jìn)程生成Coredump。很多服務(wù)程序都會(huì)調(diào)用seteuid(),如MySQL,不論你用什么用戶運(yùn)行 mysqld_safe啟動(dòng)MySQL,mysqld進(jìn)行的有效用戶始終是msyql用戶。如果你當(dāng)初是以用戶A運(yùn)行了某個(gè)程序,但在ps里看到的
這個(gè)程序的用戶卻是B的話,那么這些進(jìn)程就是調(diào)用了seteuid了。為了能夠讓這些進(jìn)程生成core dump,需要將/proc/sys/fs/suid_dumpable 文件的內(nèi)容改為1(一般默認(rèn)是0)。

  三、這個(gè)一般都知道,就是要設(shè)置足夠大的Core文件大小限制了。程序崩潰時(shí)生成的 Core文件大小即為程序運(yùn)行時(shí)占用的內(nèi)存大小。但程序崩潰時(shí)的行為不可按平常時(shí)的行為來估計(jì),比如緩沖區(qū)溢出等錯(cuò)誤可能導(dǎo)致堆棧被破壞,因此經(jīng)常會(huì)出現(xiàn)某個(gè)變量的值被修改成亂七八糟的,然后程序用這個(gè)大小去申請(qǐng)內(nèi)存就可能導(dǎo)致程序比平常時(shí)多占用很多內(nèi)存。因此無論程序正常運(yùn)行時(shí)占用的內(nèi)存多么少,要保證生成Core文件還是將大小限制設(shè)為unlimited為好。


ulimit -- 用戶資源限制命令

1、說明 :ulimit用于shell啟動(dòng)進(jìn)程所占用的資源.
2、類別 :shell內(nèi)建命令
3、語法格式 :ulimit [-acdfHlmnpsStvw] [size]
4、參數(shù)介紹 :
-H 設(shè)置硬件資源限制.
-S 設(shè)置軟件資源限制.
-a 顯示當(dāng)前所有的資源限制.
-c size:設(shè)置core文件的最大值.單位:blocks
-d size:設(shè)置數(shù)據(jù)段的最大值.單位:kbytes
-f size:設(shè)置創(chuàng)建文件的最大值.單位:blocks
-l size:設(shè)置在內(nèi)存中鎖定進(jìn)程的最大值.單位:kbytes
-m size:設(shè)置可以使用的常駐內(nèi)存的最大值.單位:kbytes
-n size:設(shè)置內(nèi)核可以同時(shí)打開的文件描述符的最大值.單位:n
-p size:設(shè)置管道緩沖區(qū)的最大值.單位:kbytes
-s size:設(shè)置堆棧的最大值.單位:kbytes
-t size:設(shè)置CPU使用時(shí)間的最大上限.單位:seconds
-v size:設(shè)置虛擬內(nèi)存的最大值.單位:kbytes 5,簡單實(shí)例: 

5、舉例

在Linux下寫程序的時(shí)候,如果程序比較大,經(jīng)常會(huì)遇到“段錯(cuò)誤”(segmentationfault)這樣的問題,這主要就是由于Linux系統(tǒng)初始的堆棧大?。╯tack size)太小的緣故,一般為10M。我一般把stacksize設(shè)置成256M,這樣就沒有段錯(cuò)誤了!命令為:ulimit   -s 262140

如果要系統(tǒng)自動(dòng)記住這個(gè)配置,就編輯/etc/profile文件,在 “ulimit -S -c 0 > /dev/null 2>&1”行下,添加“ulimit   -s 262140”,保存重啟系統(tǒng)就可以了!

1]在RH8的環(huán)境文件/etc/profile中,我們可以看到系統(tǒng)是如何配置ulimit的:
#grep ulimit /etc/profile
ulimit -S -c 0 > /dev/null 2>&1
這條語句設(shè)置了對(duì)軟件資源和對(duì)core文件大小的設(shè)置

2]如果我們想要對(duì)由shell創(chuàng)建的文件大小作些限制,如:

#ll h
-rw-r--r-- 1 lee lee 150062 7月 22 02:39 h

#ulimit -f 100 #設(shè)置創(chuàng)建文件的最大塊(一塊=512字節(jié))
#cat h>newh
File size limit exceeded

#ll newh
-rw-r--r-- 1 lee lee 51200 11月 8 11:47 newh
文件h的大小是150062字節(jié),而我們?cè)O(shè)定的創(chuàng)建文件的大小是512字節(jié)x100塊=51200字節(jié),當(dāng)然系統(tǒng)就會(huì)根據(jù)你的設(shè)置生成了51200字節(jié)的newh文件.

3]可以像實(shí)例1]一樣,把你要設(shè)置的ulimit放在/etc/profile這個(gè)環(huán)境文件中.
用途:設(shè)置或報(bào)告用戶資源極限。
語法:ulimit [ -H ] [ -S ] [ -a ] [ -c ] [ -d ] [ -f ] [ -m ] [ -n ] [ -s ] [ -t ] [ Limit ]
描述:ulimit 命令設(shè)置或報(bào)告用戶進(jìn)程資源極限,如 /etc/security/limits 文件所定義。文件包含以下缺省值極限:
fsize = 2097151
core = 2097151
cpu = -1
data = 262144
rss = 65536
stack = 65536
nofiles = 2000

當(dāng)新用戶添加到系統(tǒng)中時(shí),這些值被作為缺省值使用。當(dāng)向系統(tǒng)中添加用戶時(shí),以上值通過 mkuser 命令設(shè)置,或通過 chuser 命令更改。

極限分為軟性或硬性。通過 ulimit 命令,用戶可將軟極限更改到硬極限的最大設(shè)置值。要更改資源硬極限,必須擁有 root 用戶權(quán)限。

很多系統(tǒng)不包括以上一種或數(shù)種極限。 特定資源的極限在指定 Limit 參數(shù)時(shí)設(shè)定。Limit 參數(shù)的值可以是每個(gè)資源中指定單元中的數(shù)字,或者為值 unlimited。要將特定的 ulimit 設(shè)置為 unlimited,可使用詞 unlimited。

    注:在 /etc/security/limits 文件中設(shè)置缺省極限就是設(shè)置了系統(tǒng)寬度極限, 而不僅僅是創(chuàng)建用戶時(shí)用戶所需的極限。

省略 Limit 參數(shù)時(shí),將會(huì)打印出當(dāng)前資源極限。除非用戶指定 -H 標(biāo)志,否則打印出軟極限。當(dāng)用戶指定一個(gè)以上資源時(shí),極限名稱和單元在值之前打印。如果未給予選項(xiàng),則假定帶有了 -f 標(biāo)志。

由于 ulimit 命令影響當(dāng)前 shell 環(huán)境,所以它將作為 shell 常規(guī)內(nèi)置命令提供。如果在獨(dú)立的命令執(zhí)行環(huán)境中調(diào)用該命令,則不影響調(diào)用者環(huán)境的文件大小極限。以下示例中正是這種情況:

nohup ulimit -f 10000

env ulimit 10000

一旦通過進(jìn)程減少了硬極限,若無 root 特權(quán)則無法增加,即使返回到原值也不可能。

關(guān)于用戶和系統(tǒng)資源極限的更多信息,請(qǐng)參見 AIX 5L Version 5.3 Technical Reference: BaseOperating System and Extensions Volume 1 中的 getrlimit、setrlimit 或vlimit 子例程。

標(biāo)志

-a     列出所有當(dāng)前資源極限。

-c     以 512 字節(jié)塊為單位,指定核心轉(zhuǎn)儲(chǔ)的大小。

-d     以 K 字節(jié)為單位指定數(shù)據(jù)區(qū)域的大小。

-f     使用 Limit 參數(shù)時(shí)設(shè)定文件大小極限(以塊計(jì)),或者在未指定參數(shù)時(shí)報(bào)告文件大小極限。缺省值為 -f 標(biāo)志。

-H     指定設(shè)置某個(gè)給定資源的硬極限。如果用戶擁有 root 用戶權(quán)限,可以增大硬極限。任何用戶均可減少硬極限。

-m     以 K 字節(jié)為單位指定物理存儲(chǔ)器的大小。

-n     指定一個(gè)進(jìn)程可以擁有的文件描述符的數(shù)量的極限。

-s     以 K 字節(jié)為單位指定堆棧的大小。

-S     指定為給定的資源設(shè)置軟極限。軟極限可增大到硬極限的值。如果 -H 和 -S 標(biāo)志均未指定,極限適用于以上二者。

-t     指定每個(gè)進(jìn)程所使用的秒數(shù) 。

退出狀態(tài)

返回以下退出值:

0     成功完成。 


from:
http://blog.chinaunix.net/uid-26707720-id-3256694.html 
posted on 2012-06-30 20:08 chatler 閱讀(4497) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Linux_Coding
<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個(gè)博客還是不錯(cuò),雖然做的東西和我不大相關(guān),覺得看看還是有好處的

network

OSS

  • Google Android
  • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
  • os161 file list

overall

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩和欧美的一区二区| 欧美亚洲一区二区在线| 欧美ed2k| 亚洲精品国产精品国自产在线| 亚洲国产欧美一区| 欧美另类视频| 欧美一区二区视频97| 亚洲女人天堂成人av在线| 欧美国产国产综合| 怡红院精品视频| 久久影院午夜论| 麻豆av一区二区三区| 亚洲精品在线观看免费| 亚洲国产99| 欧美日本免费| 性xx色xx综合久久久xx| 欧美一区91| 99这里只有精品| 香蕉久久夜色精品| 亚洲国产一区在线| 亚洲新中文字幕| 亚洲电影免费观看高清完整版在线观看| 欧美黄色免费| 国产精品乱码久久久久久| 欧美成年人视频| 国产精品超碰97尤物18| 另类天堂视频在线观看| 欧美体内谢she精2性欧美| 久久久久久91香蕉国产| 欧美日韩视频在线第一区| 久久黄色网页| 欧美色欧美亚洲高清在线视频| 久久精品国产99国产精品| 欧美大片在线观看一区二区| 久久精品国产99精品国产亚洲性色 | 亚洲图片欧美午夜| 久久久久88色偷偷免费| 亚洲欧美三级伦理| 欧美大片在线观看一区二区| 久久全球大尺度高清视频| 欧美日韩国产精品成人| 欧美成人一区二区在线| 国产综合久久久久久| 一本到12不卡视频在线dvd| 91久久线看在观草草青青| 亚洲欧美日韩一区| 亚洲欧美电影在线观看| 欧美日韩精品一区二区在线播放| 欧美91视频| 一色屋精品亚洲香蕉网站| 亚洲欧美日韩综合| 欧美一区二区三区免费视频| 欧美特黄一区| 亚洲无亚洲人成网站77777| 一本久久知道综合久久| 欧美大片免费观看| 亚洲高清成人| 亚洲免费精品| 欧美激情视频一区二区三区在线播放 | 久久经典综合| 国产一本一道久久香蕉| 午夜精品久久久久久久| 亚洲麻豆av| 99国产一区| 欧美精品1区2区3区| 亚洲精品久久| 中文国产亚洲喷潮| 国产精品久久久久毛片大屁完整版 | 黄色成人在线观看| 久久九九久精品国产免费直播| 久久精品99国产精品| 国内精品模特av私拍在线观看| 久久国产欧美日韩精品| 久热这里只精品99re8久| 1024日韩| 欧美日韩精品一区视频 | 亚洲黄色在线看| 亚洲永久免费av| 国产欧美精品在线| 狂野欧美激情性xxxx| 亚洲二区免费| 亚洲欧美日韩综合一区| 国产一区二区丝袜高跟鞋图片| 久久免费国产精品1| 亚洲激情在线激情| 亚洲免费在线电影| 黄色av一区| 欧美日本在线播放| 亚洲一区免费| 欧美v国产在线一区二区三区| 99国产精品99久久久久久| 国产精品二区影院| 久久天天综合| 一区二区三区免费看| 久久久久久午夜| 99国产精品视频免费观看| 国产伦精品一区二区三| 嫩草国产精品入口| 亚洲欧美亚洲| 亚洲精品视频免费观看| 久久久久久久久久久久久久一区| 亚洲国产精品一区二区第一页| 欧美日韩妖精视频| 久久永久免费| 亚洲欧美成人综合| 亚洲另类自拍| 欧美不卡视频一区发布| 亚洲欧美国产精品桃花| 亚洲欧洲三级| 国内成人在线| 国产精品入口福利| 欧美激情在线免费观看| 久久久噜噜噜久噜久久| 亚洲香蕉伊综合在人在线视看| 欧美激情一区二区三区全黄| 久久久精品日韩| 午夜精品久久久久久久久| 亚洲精品国产精品国自产观看浪潮| 国产欧美精品日韩| 国产精品久久久久久久久久三级 | 亚洲人成网站精品片在线观看| 国产午夜亚洲精品羞羞网站 | 欧美日韩一区在线观看| 久久综合九色综合欧美狠狠| 羞羞视频在线观看欧美| 一区二区三欧美| 亚洲午夜伦理| 欧美日韩一区二区三区| 欧美高清视频www夜色资源网| 久久精品91久久久久久再现| 亚洲欧美中文字幕| 亚洲综合日韩在线| 亚洲一区二区在线看| 正在播放日韩| 亚洲午夜极品| 亚洲丝袜av一区| 亚洲一区二区免费在线| 亚洲午夜一区二区| 亚洲图片欧洲图片av| 亚洲网站在线| 亚洲一区中文字幕在线观看| 亚洲一区国产一区| 欧美一级在线亚洲天堂| 欧美一区二区三区在| 欧美一区综合| 久久五月激情| 欧美精品大片| 欧美日韩亚洲综合| 国产精自产拍久久久久久| 国产日韩欧美成人| 伊人久久综合| 日韩午夜在线视频| 亚洲欧美激情一区| 久久久不卡网国产精品一区| 久久婷婷成人综合色| 欧美高清不卡| 99综合在线| 午夜精品久久久久久久蜜桃app| 欧美在线观看视频在线| 久久综合色天天久久综合图片| 欧美成人精品1314www| 欧美三区美女| 激情五月***国产精品| 亚洲精品视频免费观看| 亚洲一区二区三区欧美| 久久久久久久久蜜桃| 欧美韩国日本综合| 中文精品视频| 久久人体大胆视频| 欧美日韩在线另类| 精品动漫av| 亚洲一区二区黄| 美女国产一区| 亚洲性感美女99在线| 久久免费视频观看| 国产精品久久久久三级| 亚洲国产精品美女| 性高湖久久久久久久久| 亚洲国产精品久久久久久女王| 亚洲一区二区成人| 欧美电影打屁股sp| 国产性做久久久久久| 日韩一级免费| 久久艳片www.17c.com| 99天天综合性| 欧美电影免费| 狠狠综合久久| 小辣椒精品导航| 亚洲精品国产精品乱码不99按摩| 久久国产加勒比精品无码| 欧美日韩黄色一区二区| 在线观看视频一区| 久久精品视频免费| 亚洲视频视频在线| 欧美日韩国产一级片| 亚洲黄色精品| 美日韩精品免费观看视频| 亚洲午夜国产一区99re久久 | 中日韩美女免费视频网址在线观看 | 亚洲精品一品区二品区三品区|