亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 服務(wù)器 > Linux服務(wù)器 > 正文

探索Linux內(nèi)核:Kconfig的秘密

2024-09-05 23:05:12
字體:
供稿:網(wǎng)友

深入了解Linux配置/構(gòu)建系統(tǒng)是如何工作的。

自從Linux內(nèi)核代碼遷移到Git之后,Linux內(nèi)核配置/構(gòu)建系統(tǒng)(也稱為Kconfig/kBuild)已經(jīng)存在了很長時間。然而,作為支持基礎(chǔ)設(shè)施,它很少受到關(guān)注;即使在日常工作中使用它的內(nèi)核開發(fā)人員也從未真正考慮過它。

為了探索Linux內(nèi)核是如何編譯的,本文將深入研究Kconfig/kBuild內(nèi)部進(jìn)程,解釋.config文件和vmlinux/bzImage文件是如何生成的,并介紹一個用于依賴性跟蹤的智能技巧。

Kconfig

構(gòu)建內(nèi)核的第一步總是配置。Kconfig幫助使Linux內(nèi)核高度模塊化和可定制。Kconfig為用戶提供了許多配置目標(biāo):

config 使用面向行的程序更新當(dāng)前配置
nconfig 使用基于ncurses菜單的程序更新當(dāng)前配置
menuconfig 使用基于菜單的程序更新當(dāng)前配置
xconfig 利用基于qt的前端更新當(dāng)前配置
gconfig 利用基于GTK+的前端更新當(dāng)前配置
oldconfig 使用提供的.config作為基礎(chǔ)更新當(dāng)前配置
localmodconfig 更新未加載的當(dāng)前配置禁用模塊
localyesconfig 更新當(dāng)前配置,將本地MODS轉(zhuǎn)換為核心
defconfig 從Arch提供的Defconfig中獲得默認(rèn)配置的新配置
Savedefconfig 將當(dāng)前配置保存為./defconfig(最小配置)
allnoconfig 使用“no”回答所有選項(xiàng)的新配置
allyesconfig 新配置,在該配置中,所有選項(xiàng)都以“是”接受
allmodconfig 在可能的情況下選擇新的配置模塊
alldefconfig 將所有符號設(shè)置為默認(rèn)值的新配置
randconfig 具有對所有選項(xiàng)的隨機(jī)答案的新配置
listnewconfig 列出新選項(xiàng)
olddefconfig 與oldconfig相同,但在不提示的情況下將新符號設(shè)置為默認(rèn)值
kvmconfig 為kvm客戶端內(nèi)核支持啟用其他選項(xiàng)
xenconfig 啟用Xen dom0和來賓內(nèi)核支持的其他選項(xiàng)
tinyconfig 配置盡可能小的內(nèi)核

我認(rèn)為menuconfig是這些目標(biāo)中最受歡迎的。目標(biāo)由不同的主機(jī)程序進(jìn)行處理,這些程序由內(nèi)核提供,并在內(nèi)核構(gòu)建過程中生成。一些目標(biāo)有一個GUI(為了用戶的方便),而大多數(shù)沒有。與kconfig相關(guān)的工具和源代碼主要位于scripts/kconfig/在內(nèi)核源代碼中。我們可以從scripts/kconfig/makefile,有幾個主機(jī)程序,包括CONF, mconf,和nconf。除了CONF,它們每個都負(fù)責(zé)基于GUI的配置目標(biāo)之一,因此,CONF和他們中的大多數(shù)人打交道。

從邏輯上講,Kconfig的基礎(chǔ)結(jié)構(gòu)有兩個部分:一個實(shí)現(xiàn)了新語言要定義配置項(xiàng)(請參閱內(nèi)核源代碼下的Kconfig文件),而其他配置項(xiàng)則解析Kconfig語言并處理配置操作。

大多數(shù)配置目標(biāo)的內(nèi)部流程大致相同(如下所示):

Linux,Kconfig

注意,所有配置項(xiàng)都有一個默認(rèn)值。

第一步讀取源根下的Kconfig文件以構(gòu)造初始配置數(shù)據(jù)庫;然后根據(jù)此優(yōu)先級讀取現(xiàn)有配置文件來更新初始數(shù)據(jù)庫:

  • .config
  • /lib/Module/$(shell,uname-r)/.config
  • /etc/kernel-config
  • /boot/config-$(shell,uname-r)
  • ARCH_DEFCONFIG
  • ARCH/$(ARCH)/Defconfig

如果您正在進(jìn)行基于GUI的配置,則通過menuconfig或基于命令行的配置oldconfig,數(shù)據(jù)庫將根據(jù)您的自定義進(jìn)行更新。最后,將配置數(shù)據(jù)庫轉(zhuǎn)儲到.config文件中。

但是.config文件不是內(nèi)核構(gòu)建的最終素材;這就是為什么syncconfig目標(biāo)存在。syncconfig以前是一個名為silentoldconfig,但是它不像舊名字說的那樣,所以它被重命名了。此外,由于它是內(nèi)部使用(而不是為用戶),它被從列表中刪除。

下面是一個例子syncconfig作用:

Linux,Kconfig

syncconfig接受.config作為輸入并輸出許多其他文件,這些文件分為三類:

auto.conf & tristate.conf用于生成文件文本處理。例如,您可能在組件的makefile中看到這樣的語句:

obj-$(CONFIG_GENERIC_CALIBRATE_DELAY) += calibrate.o

autoconf.h在C語言源文件中使用。

空頭文件include/config/用于在kbuild期間進(jìn)行配置依賴項(xiàng)跟蹤,下面將對此進(jìn)行解釋。

配置之后,我們將知道哪些文件和代碼段沒有編譯。

KBuild

組件式建筑,稱為遞歸制作,是GNU的一種常見方式。制作,使管理一個大型項(xiàng)目。KBuild是遞歸make的一個很好的例子。通過將源文件劃分為不同的模塊/組件,每個組件都由自己的Makefile管理。當(dāng)您開始構(gòu)建時,頂級Makefile按正確的順序調(diào)用每個組件的makefile,構(gòu)建組件,并將它們收集到最終的執(zhí)行程序中。

KBuild指的是不同類型的makefile:

  • Makefile位于源根中的頂部makefile。
  • .config是內(nèi)核配置文件。
  • ARCH/$(ARCH)/Makefile是拱形Makefile,這是對頂部makefile的補(bǔ)充。
  • scripts/Makefile*描述所有kbuild makefile的通用規(guī)則。
  • 最后,大約有500個Kbuildmakefiles.

頂部的makefile包含archmakefile,讀取.config文件,進(jìn)入子目錄,調(diào)用制作,使中定義的例程的幫助下實(shí)現(xiàn)每個組件的makefile。scripts/Makefile*,構(gòu)建每個中間對象,并將所有中間對象鏈接到vmlinux。核心文件Documentation/kbuild/makefiles.txt描述這些制作文件的所有方面。

例如,讓我們看看在x86-64上如何生成vmlinux:

Linux,Kconfig

(插圖是根據(jù)理查德·Y·史蒂文(Richard Y.Steven)的博客。經(jīng)提交人許可后予以更新和使用。

所有.o進(jìn)入vmlinux的文件首先進(jìn)入它們自己的built-in.a,這是通過變量表示的。KBUILD_VMLINUX_INIT, KBUILD_VMLINUX_Main, KBUILD_VMLINUX_LIBS,然后收集到vmlinux文件中。

看看如何在Linux內(nèi)核中實(shí)現(xiàn)遞歸make,并借助簡化的Makefile代碼:

# In top Makefilevmlinux: scripts/link-vmlinux.sh $(vmlinux-deps)        +$(call if_changed,link-vmlinux)# Variable assignmentsvmlinux-deps := $(KBUILD_LDS) $(KBUILD_VMLINUX_INIT) $(KBUILD_VMLINUX_MAIN) $(KBUILD_VMLINUX_LIBS)export KBUILD_VMLINUX_INIT := $(head-y) $(init-y)export KBUILD_VMLINUX_MAIN := $(core-y) $(libs-y2) $(drivers-y) $(net-y) $(virt-y)export KBUILD_VMLINUX_LIBS := $(libs-y1)export KBUILD_LDS     := arch/$(SRCARCH)/kernel/vmlinux.ldsinit-y     := init/drivers-y    := drivers/ sound/ firmware/net-y      := net/libs-y     := lib/core-y     := usr/virt-y     := virt/# Transform to corresponding built-in.ainit-y     := $(patsubst %/, %/built-in.a, $(init-y))core-y     := $(patsubst %/, %/built-in.a, $(core-y))drivers-y    := $(patsubst %/, %/built-in.a, $(drivers-y))net-y      := $(patsubst %/, %/built-in.a, $(net-y))libs-y1     := $(patsubst %/, %/lib.a, $(libs-y))libs-y2     := $(patsubst %/, %/built-in.a, $(filter-out %.a, $(libs-y)))virt-y     := $(patsubst %/, %/built-in.a, $(virt-y))# Setup the dependency. vmlinux-deps are all intermediate objects, vmlinux-dirs# are phony targets, so every time comes to this rule, the recipe of vmlinux-dirs# will be executed. Refer "4.6 Phony Targets" of `info make`$(sort $(vmlinux-deps)): $(vmlinux-dirs) ;# Variable vmlinux-dirs is the directory part of each built-in.avmlinux-dirs  := $(patsubst %/,%,$(filter %/, $(init-y) $(init-m) /           $(core-y) $(core-m) $(drivers-y) $(drivers-m) /           $(net-y) $(net-m) $(libs-y) $(libs-m) $(virt-y)))# The entry of recursive make$(vmlinux-dirs):        $(Q)$(MAKE) $(build)=$@ need-builtin=1

遞歸的配方擴(kuò)展,例如:

make -f scripts/Makefile.build obj=init need-builtin=1

這意味著make將進(jìn)入scripts/Makefile.build繼續(xù)建造每一個built-in.a。在.的幫助下scripts/link-vmlinux.sh,vmlinux文件最終位于源根下。

理解vmlinux與bzImage

許多Linux內(nèi)核開發(fā)人員可能不清楚vmlinux和bzImage之間的關(guān)系。例如,以下是它們在x86-64中的關(guān)系:

Linux,Kconfig

源根vmlinux被剝離、壓縮、放入piggy.S,然后將其他對等對象鏈接到arch/x86/boot/compressed/vmlinux。同時,下面生成一個名為setup.bin的文件arch/x86/boot??赡苡幸粋€包含重定位信息的可選的第三個文件,具體取決于config_x86_RELOCS.

一個名為build由內(nèi)核提供,將這兩個(或三個)部分構(gòu)建到最終的bzImage文件中。

依賴跟蹤

KBuild跟蹤三種依賴關(guān)系:

  1. 所有的前提文件(*.c和*.h)
  2. CONFIG_在所有先決條件文件中使用的選項(xiàng)
  3. 用于編譯目標(biāo)的命令行依賴關(guān)系。

第一個很容易理解,但是第二個和第三個呢?內(nèi)核開發(fā)人員經(jīng)??吹竭@樣的代碼片段:

#ifdef CONFIG_SMP__boot_cpu_id = cpu;#endif

什么時候CONFIG_SMP更改后,這段代碼應(yīng)該重新編譯。編譯源文件的命令行也很重要,因?yàn)椴煌拿钚锌赡軐?dǎo)致不同的對象文件。

當(dāng).C文件通過#include指令,您需要編寫這樣的規(guī)則:

main.o: defs.hrecipe...

在管理一個大型項(xiàng)目時,您需要很多這樣的規(guī)則;所有這些規(guī)則都會乏味。幸運(yùn)的是,大多數(shù)現(xiàn)代C編譯器可以通過查看#include源文件中的行。對于GNU編譯器集合(GCC),只需添加一個命令行參數(shù):-MD depfile

# In scripts/Makefile.libc_flags    = -Wp,-MD,$(depfile) $(NOSTDINC_FLAGS) $(LINUXINCLUDE)   /         -include $(srctree)/include/linux/compiler_types.h    /         $(__c_flags) $(modkern_cflags)              /         $(basename_flags) $(modname_flags)

這將生成一個.D文件的內(nèi)容如下:

init_task.o: init/init_task.c include/linux/kconfig.h /include/generated/autoconf.h include/linux/init_task.h /include/linux/rcupdate.h include/linux/types.h /...

然后主機(jī)程序fixdep通過獲取其他兩個依賴項(xiàng)來處理其他兩個依賴項(xiàng)。depfile命令行作為輸入,然后以makefile語法輸出.cmd文件,它記錄目標(biāo)的命令行和所有先決條件(包括配置)??雌饋硎沁@樣的:

# The command line used to compile the targetcmd_init/init_task.o := gcc -Wp,-MD,init/.init_task.o.d -nostdinc ......# The dependency filesdeps_init/init_task.o := /$(wildcard include/config/posix/timers.h) /$(wildcard include/config/arch/task/struct/on/stack.h) /$(wildcard include/config/thread/info/in/task.h) /... include/uapi/linux/types.h / arch/x86/include/uapi/asm/types.h / include/uapi/asm-generic/types.h /...

在遞歸生成過程中將包含一個.cmd文件,提供所有依賴項(xiàng)信息,并幫助決定是否重新構(gòu)建目標(biāo)。

這背后的秘密是,F(xiàn)ixdep將解析depfile(.d文件),然后解析其中的所有依賴文件,搜索所有config_string的文本,將它們轉(zhuǎn)換為相應(yīng)的空頭文件,并將它們添加到目標(biāo)的先決條件中。每次配置更改時,相應(yīng)的空頭文件也將被更新,因此kbuild可以檢測到該更改并重新構(gòu)建依賴于它的目標(biāo)。因?yàn)檫€記錄了命令行,所以很容易比較最后的編譯參數(shù)和當(dāng)前的編譯參數(shù)。

展望未來

Kconfig/kbuild很長一段時間沒有變化,直到新的維護(hù)者山田正一郎(Masahiro Yamada)在2017年初加入,現(xiàn)在KBuild又在積極發(fā)展。如果你很快看到了與本文不同的東西,不要感到驚訝。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對VEVB武林網(wǎng)的支持。


注:相關(guān)教程知識閱讀請移步到服務(wù)器教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
精品91久久久| 2022国产精品视频| 一级黄色片国产| 亚洲免费毛片| y97精品国产97久久久久久| 久久这里只有精品首页| 欧美午夜www高清视频| av免费观看在线| 欧美日韩国产区一| 亚洲一区二区五区| 青春草在线视频观看| y97精品国产97久久久久久| 黄色片在线免费观看| 91精品国产高清自在线看超| 亚洲成av人影院在线观看| 性生交免费视频| 在线免费av播放| 日韩中文字幕在线视频观看| 成人自拍小视频| 男女h黄动漫啪啪无遮挡软件| 91地址最新发布| 免费中文日韩| 伦一区二区三区中文字幕v亚洲| 偷窥自拍亚洲色图精选| 欧美aⅴ99久久黑人专区| 久久久精品久久久久| 欧美午夜性视频| 成人免费观看在线视频| 美女网站视频在线| gogogo免费高清日本写真| 在线亚洲a色| 亚洲一区二区三区黄色| 国产绿帽一区二区三区| 久久久免费网站| 亚洲午夜激情影院| 国产麻豆日韩欧美久久| 性色av一区二区三区在线观看| wwwwxxxx国产| 日本www在线观看视频| 亚洲欧洲精品在线| 色橹橹高清视频在线播放| 日本在线播放一区二区| 在线视频免费在线观看一区二区| 欧美一区综合| 欧美三级自拍| 日本在线观看视频| 黄色免费福利视频| 亚洲在线免费| 久久久久久久久亚洲精品| 国产伦理久久久| 亚洲在线免费观看视频| 黄网站色大毛片| 亚洲大胆人体大胆做受1| 99热一区二区三区| 99re在线视频播放| 3344国产精品免费看| 中文字幕日本视频| 欧美一区二区视频在线观看| 污污免费网站| 好看的av在线| 日韩美女免费视频| 亚洲嫩模很污视频| 国产精品12345| 中文字幕免费观看视频| 午夜av免费观看| 欧美 日韩 国产 一区二区三区| 先锋影音av资源在线| 亚洲综合社区| 激情久久五月| 亚洲精品日韩成人| 懂色av一区二区三区免费看| 91久久爱成人| 91久久夜色精品国产网站| 国产精品久久久久久久午夜| 久久久久久久久久福利| 色偷偷88888欧美精品久久久| 欧美mv日韩| 右手影院亚洲欧美| 韩国av免费在线观看| 日本色七七影院| 久久久久久久久久久久久9999| 激情av在线播放| 欧美视频在线不卡| 中文字幕在线播放| 国产一区香蕉久久| 国产精品免费视频网站| 中文字幕在线观看免费视频| 日韩免费一级| 欧美日韩在线观看一区二区| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲精品成人悠悠色影视| 久久精品国产秦先生| jizzjizz4| 亚洲片av在线| 国产不卡一区二区三区在线观看| 久久精品视频91| 色噜噜狠狠成人中文综合| 超碰成人97| 五月婷婷开心网| 国产sm主人调教女m视频| 奇米影视亚洲色图| 快灬快灬一下爽蜜桃在线观看| 777奇米四色成人影色区| 日韩欧美在线视频日韩欧美在线视频| 日本黄色小说视频| 色爱综合区网| 亚洲成a人片77777kkkk| 午夜国产福利| 被灌满精子的波多野结衣| 妞干网在线视频观看| 丰满少妇大力进入| 最新中文字幕在线视频| 免费在线观看一级片| 中文字幕av久久爽一区| 亚洲国产精品国自产拍久久| 久久久噜噜噜久久中文字幕色伊伊| 亚洲影视在线观看| 精品小视频在线观看| 中文字幕a级片| 日韩av在线一区二区| 极品美女扒开粉嫩小泬| 国产精品一区二区久久久| 成年女人免费毛片视频永久| 又粗又黑又大的吊av| 日本搞黄视频| 午夜精品福利视频网站| 亚洲图片欧美日韩| 桃子视频成人app| 亚洲一二三区在线| 国产精品夜色7777狼人| 欧美大片一区二区| 亚洲a区在线视频| 亚洲经典中文字幕| 黄瓜视频污在线观看| 波多野结衣免费观看| 国产精品免费电影| 国产成人手机视频| 久久综合狠狠综合久久激情| 国产在线一区二区| 手机免费观看av| 亚洲黑人在线| 91国产精品91| 久久日韩粉嫩一区二区三区| 日本高清不卡一区| 色综合天天做天天爱| 国产精品久久精品牛牛影视| 日本69式三人交| 87福利电影网| 这里只有精品久久| 精品电影在线| 亚洲成人av免费在线观看| 亚洲一区二区免费在线观看| 精品中文字幕一区二区三区| 一本色道88久久加勒比精品| 精品视频一区二区三区四区五区| 一本之道久久| 亚洲男人天堂网| 精品久久无码中文字幕| 成人高清av| 最新成人av在线| 熟女人妇 成熟妇女系列视频| 青青草原综合久久大伊人精品| 亚洲а∨天堂久久精品9966| 污网站在线免费看| 国产精品欧美激情| 人妻无码一区二区三区免费| 久久视频一区二区| 自拍偷拍 国产| 欧美成人性色生活仑片| 亚洲欧美另类日韩| 国产成人艳妇aa视频在线| 欧美黑人xx片| 精品动漫一区| 肉肉视频在线观看| 大地资源二中文在线影视观看| 国产人成高清视频观看| 亚欧在线观看视频| 国产精品视频大全| 日本不卡一区二区三区高清视频| 亚洲女人小视频在线观看| 99在线精品一区二区三区| 国产精品高潮呻吟AV无码| 91精品99| 在线播放黄网| 精品国产va久久久久久久| 伊人久久大香线蕉综合热线| 国产夫妻在线视频| 视频在线精品一区| 调教视频免费在线观看| 成人性视频欧美一区二区三区| 一区二区三区电影大全| 日韩精品一区二区三区在线| 蜜臀精品一区二区三区在线观看| 九九久久精品| 操操操com| 超薄肉色丝袜一二三| 久久夜色精品亚洲| 久久久久久国产精品免费免费| 在线精品视频播放| 精品亚洲成a人在线观看| 少妇久久久久| 精品国产制服丝袜高跟| 三年片免费观看大全| 国产精品视频你懂的| 亚洲精品毛片一区二区三区| 亚洲国产成人av| 亚洲黄色网址大全| 激情六月婷婷久久| 阳光姐妹淘韩国版| 亚洲网在线观看| 日韩av电影院| 国产亚洲精品久久久久久打不开| 国产网红女主播精品视频| av一本在线| av在线电影免费观看| av电影在线观看完整版一区二区| 国产羞羞视频在线播放| 朝桐光av在线一区二区三区| 伦xxxx在线| 1插菊花综合| 九九精品在线| 精品国产麻豆免费人成网站| 欧美大胆a级| jizzjizzjizz亚洲女| 亚洲视频第一页| 久久精品一卡二卡| 国产欧美欧洲在线观看| 欧美视频不卡中文| 国产精品啊v在线| av在线日韩国产精品| 成年人视频在线免费观看| 国产一区二区精品福利地址| www一区二区| 国产精品va在线播放| 免费高清在线一区| 中文字幕在线导航| 爱情岛论坛vip永久入口| 欧美日韩精品电影| av无码久久久久久不卡网站| 午夜视频精品| 女人被狂躁c到高潮| 精品国内自产拍在线观看| 手机精品视频在线观看| 中国日本在线视频中文字幕| 欧美人与牲禽动交com| 久久久久久久久久久久久久久久久久久久| 欧美精品一区二| 色伊人久久综合中文字幕| 99视频精品视频高清免费| 久久久精品国产亚洲| 国产黄色在线观看| 97人人模人人爽人人喊38tv| 成人在线视频国产| 99riav视频一区二区| 777亚洲妇女| 丝袜a∨在线一区二区三区不卡| 免费高清成人在线| 亚洲乱码国产乱码精品| 成人福利片在线| 和岳每晚弄的高潮嗷嗷叫视频| 国产精品 欧美激情| 视频一区二区三区在线看免费看| 黄色成人在线观看| av天天在线| 国产亚洲精品中文字幕| 欧美日韩a v| 欧美日韩免费一区二区三区| 欧美私人啪啪vps| 日本久久久久久久久久久| 男人插曲女人的视频| 欧美成人在线免费观看| 日韩在线视频播放| 一区二区三区四区在线播放| 亚洲精品久久久蜜桃| 日本成人小视频| 女人天堂亚洲aⅴ在线观看| 亚洲精品免费av| 亚洲美女精品成人在线视频| 国产网友自拍电影在线| av中文在线观看| 99久久国产免费免费| 日韩理论在线| 日本www在线观看视频| yy111111少妇影院日韩夜片| 中文字幕在线观看第二页| 国内精品国语自产拍在线观看| 久久精品国产亚洲精品| 欧美成人明星100排名| 成人影院在线观看| 91一区二区三区在线播放| 萌白酱国产一区二区| 日韩亚洲欧美成人一区| 曰本色欧美视频在线| 中文字幕欧美人妻精品一区| 欧美精品国产一区二区| 波多野结衣一二三区| 色偷偷777| 久久精品嫩草影院| 精品亚洲一区二区三区| 国产在线综合视频| 蜜臀aⅴ国产精品久久久国产老师| 美国十次了思思久久精品导航| 国产麻豆视频一区二区| 337p日本欧洲亚洲大胆色噜噜| 男女性高潮免费网站| 欧美刺激性大交免费视频| 热门国产精品亚洲第一区在线| 三级在线观看视频| 福利视频在线看| 亚洲激情在线| 亚洲v国产v在线观看| 成人在线视频首页| 97在线影院| 亚洲人成人99网站| 中文字幕久久网| 欧美日韩亚洲网| 91精品一区二区三区综合| 99久久精品免费精品国产| 午夜精品短视频| 亚洲色图狠狠干| 国产免费中文字幕| 国产69精品久久久久久久久久| 久久久综合香蕉尹人综合网| 国产亚洲短视频| 一区二区三区在线观看www| 成人公开免费视频| 久久色.com| 国产调教精品|