資料介紹
一、 Linux系統(tǒng)中的USB攝像頭驅(qū)動(dòng)程序
USB攝像頭以其良好的性能和低廉的價(jià)格得到廣泛應(yīng)用。同時(shí)因其靈活、方便的特性,易于集成到嵌入式系統(tǒng)中。但是如果使用現(xiàn)有的符合Video for Linux標(biāo)準(zhǔn)的驅(qū)動(dòng)程序配合通用應(yīng)用程序,難以充分利用USB帶寬,幀速不高,不易滿足實(shí)時(shí)監(jiān)控等要求。本文首先介紹在Linux系統(tǒng)下USB攝像頭驅(qū)動(dòng)編制的一般方法,然后說明在此基礎(chǔ)上如何提高幀速。
USB設(shè)備驅(qū)動(dòng)程序完全符合通用設(shè)備驅(qū)動(dòng)的準(zhǔn)則,不同的是內(nèi)核提供了一些特別的API函數(shù),方便驅(qū)動(dòng)注冊(cè)、銷毀自己,例如usb_reSister()和usb_dereSister();2.4版的內(nèi)核還提供了對(duì)于hotplug的支持。
1.1 USB攝像頭驅(qū)動(dòng)的一般編寫方法
攝像頭屬于視頻類設(shè)備。在目前的Linux核心中,視頻部分的標(biāo)準(zhǔn)是Video for Linux(簡(jiǎn)稱V4L)。這個(gè)標(biāo)準(zhǔn)其實(shí)定義了一套接口,內(nèi)核、驅(qū)動(dòng)、應(yīng)用程序以這個(gè)接口為標(biāo)準(zhǔn)進(jìn)行交流。目前的V4L涵蓋了視、音頻流捕捉及處理等內(nèi)容,USB攝像頭也屬于它支持的范疇。
因此,USB攝像頭的驅(qū)動(dòng)應(yīng)當(dāng)與內(nèi)核提供的視頻驅(qū)動(dòng)掛鉤。即首先在驅(qū)動(dòng)中聲明一個(gè)video_device結(jié)構(gòu),并為其指定文件操作函數(shù)指針數(shù)組.fops,向系統(tǒng)注冊(cè)。在應(yīng)用程序發(fā)出文件操作的相關(guān)命令時(shí),核心根據(jù)這些指針調(diào)用相應(yīng)函數(shù),并將該結(jié)構(gòu)作為參數(shù)傳遞給它們。這樣,就完成了驅(qū)動(dòng)和核心之間的通信。例如:
static struct video_device vdev_template={……};
//聲明video_device,指出掛接驅(qū)動(dòng)
static struct file_operations ov511_fops={……};
?。暶鞅掘?qū)動(dòng)的文件操作函數(shù)指針
struct video_device*vdev=video_devdata(file);
//從文件指針中提取出video_device結(jié)構(gòu)
在video_device結(jié)構(gòu)中,有一個(gè)私有指針priv,可以將它指向一塊保留內(nèi)存。在這塊內(nèi)存中,保存著本驅(qū)動(dòng)、本設(shè)備的相關(guān)初始化信息。這塊內(nèi)存的申請(qǐng)、初始化、指針指向等工作都是在USB驅(qū)動(dòng)的枚舉函數(shù).probe中完成。這樣,在枚舉函數(shù)將控制權(quán)返還給系統(tǒng)后,因?yàn)閮?nèi)核不銷毀保留內(nèi)存,所以驅(qū)動(dòng)仍然保留著自己的信息。這點(diǎn)與Windows系統(tǒng)中WDM驅(qū)動(dòng)有異曲同工之處。當(dāng)然,在驅(qū)動(dòng)卸載函數(shù)中,應(yīng)當(dāng)將申請(qǐng)的各塊內(nèi)存全部釋放。
1.2 使用雙URB輪流通信
眾所周知,USBl.1總線標(biāo)準(zhǔn)定義了控制、中斷、批量、等時(shí)等四種管道。對(duì)于時(shí)間性極強(qiáng)但是準(zhǔn)確度要求不高的視頻捕捉應(yīng)用來說,攝像頭應(yīng)當(dāng)使用等時(shí)傳輸方式。為了盡可能快地得到圖像數(shù)據(jù),應(yīng)當(dāng)在URB中指定USB_ISO_ASAP標(biāo)志。
urb-》transfer_flags=USB_ISO_ASAP;//盡可能快地發(fā)出本URB
Linux系統(tǒng)中任何USB傳輸都通過URB實(shí)現(xiàn)。為提高速度,可以考慮擴(kuò)大URB的緩沖,這樣可以降低每個(gè)USB事務(wù)中握手信息所占比例,提高有效數(shù)據(jù)的傳輸速度。但是受限于總線帶寬和具體的USB設(shè)備芯片,單純擴(kuò)大URB的緩沖不能無限制地解決問題。具體分析一下USB傳輸在操作系統(tǒng)中的實(shí)現(xiàn):每次傳輸都要包括URB的建立、發(fā)出、回收、數(shù)據(jù)整理等階段,這些時(shí)間不產(chǎn)生有效數(shù)據(jù)。因此可以建立兩個(gè)URB,在等待一個(gè)URB被回收時(shí),也就是圖像正在被傳感器采集時(shí),處理、初始化另一個(gè)URB,并在回收后立刻將其發(fā)出。兩個(gè)URB交替使用,大大減少了額外時(shí)間。工作流程如圖1所示。
這個(gè)過程是在URB的完成例程中實(shí)現(xiàn)的,有兩點(diǎn)需要注意:首先處理再次初始化的代碼時(shí)間不能長(zhǎng),否則會(huì)造成完成例程的重人,如果確實(shí)來不及,可以在完成例程中設(shè)定標(biāo)志,例如“數(shù)據(jù)采集好”旗語,由應(yīng)用程序使用阻塞ioctl()來查詢?cè)撈煺Z并做處理;其次由于CPU可能會(huì)在完成例程中停留較長(zhǎng)時(shí)間,系統(tǒng)負(fù)擔(dān)較大,可以在.open函數(shù)中初始化兩個(gè)URB并將其發(fā)出,有限度地減輕系統(tǒng)負(fù)擔(dān)。
1.3 使用雙幀緩沖提高效率
Linux系統(tǒng)中,文件操作通常是由read、write等系統(tǒng)調(diào)用來完成。這些系統(tǒng)調(diào)用在驅(qū)動(dòng)中的解決方法就是用copy_to_user()、copy_from_user()等函數(shù)在核態(tài)、戶態(tài)內(nèi)存空間中互相拷貝。但是對(duì)于大批量的圖像數(shù)據(jù),采用拷貝的方法顯然會(huì)增加時(shí)間開銷,因此用內(nèi)存映射的方法解決。首先使用vmalloc()申請(qǐng)足夠大的核態(tài)內(nèi)存,將其作為圖像數(shù)據(jù)緩沖空間,兩個(gè)URB帶回的圖像數(shù)據(jù)在這里暫存;然后使用remap_page_range()函數(shù)將其逐頁映射到用戶空間中。戶態(tài)的圖像處理程序使用mmap()函數(shù),直接讀寫核態(tài)圖像緩沖內(nèi)存,大大減少額外開銷。
圖像數(shù)據(jù)的處理可能要花費(fèi)比較長(zhǎng)的時(shí)間,不同的算法對(duì)于數(shù)據(jù)保留時(shí)間的要求也不一樣。因此可以申請(qǐng)兩幀圖像緩沖,在處理一幀圖像的同時(shí),將兩個(gè)URB帶回的數(shù)據(jù)全部填充到另一幀緩沖中,這樣可以免去時(shí)間沖突上的麻煩。
值得注意的是:這種方法要求時(shí)刻持有當(dāng)前幀的序號(hào)、每一幀的起始地址等信息,不能將兩幀圖像混淆。這些信息可以保存在保留內(nèi)存中,當(dāng)前幀的數(shù)據(jù)整理、序號(hào)改變?cè)赨RB完成例程中實(shí)現(xiàn)。
二、 V4L標(biāo)準(zhǔn)的改進(jìn)
V4L標(biāo)準(zhǔn)目前已經(jīng)發(fā)展到第二版V4L2,其基本思路與V4L相同。
2.1 標(biāo)準(zhǔn)分析
根據(jù)V4L標(biāo)準(zhǔn),戶態(tài)程序在需要一幀圖像時(shí),CPU的走向如圖2。CPU按照123456的順序完成一個(gè)循環(huán)。在這里,有一個(gè)細(xì)節(jié)被忽略:在完成例程中,也就是圖2中步驟6,該URB被立刻發(fā)出,但是由于這時(shí)用戶程序正在阻塞等待,沒辦法再次提出獲得圖像的申請(qǐng),因此在判斷有無新請(qǐng)求時(shí),判斷的結(jié)果必然是當(dāng)前無請(qǐng)求,導(dǎo)致下一個(gè)URB帶回的數(shù)據(jù)被驅(qū)動(dòng)丟棄;由于核態(tài)、戶態(tài)的切換需要一定的時(shí)間,加上戶態(tài)多進(jìn)程同步等開銷,等到應(yīng)用程序能夠再次發(fā)出獲得一副圖像的申請(qǐng)時(shí),已經(jīng)有不止一個(gè)URB帶回的數(shù)據(jù)被丟棄掉,這些URB包含的數(shù)據(jù)正好是新一幀圖像的開始部分。因此驅(qū)動(dòng)必須等到再下一幀圖像才能保存數(shù)據(jù)、緩沖。這樣憑白損失了一幀圖像,幀速最少下降一半。
USB攝像頭以其良好的性能和低廉的價(jià)格得到廣泛應(yīng)用。同時(shí)因其靈活、方便的特性,易于集成到嵌入式系統(tǒng)中。但是如果使用現(xiàn)有的符合Video for Linux標(biāo)準(zhǔn)的驅(qū)動(dòng)程序配合通用應(yīng)用程序,難以充分利用USB帶寬,幀速不高,不易滿足實(shí)時(shí)監(jiān)控等要求。本文首先介紹在Linux系統(tǒng)下USB攝像頭驅(qū)動(dòng)編制的一般方法,然后說明在此基礎(chǔ)上如何提高幀速。
USB設(shè)備驅(qū)動(dòng)程序完全符合通用設(shè)備驅(qū)動(dòng)的準(zhǔn)則,不同的是內(nèi)核提供了一些特別的API函數(shù),方便驅(qū)動(dòng)注冊(cè)、銷毀自己,例如usb_reSister()和usb_dereSister();2.4版的內(nèi)核還提供了對(duì)于hotplug的支持。
1.1 USB攝像頭驅(qū)動(dòng)的一般編寫方法
攝像頭屬于視頻類設(shè)備。在目前的Linux核心中,視頻部分的標(biāo)準(zhǔn)是Video for Linux(簡(jiǎn)稱V4L)。這個(gè)標(biāo)準(zhǔn)其實(shí)定義了一套接口,內(nèi)核、驅(qū)動(dòng)、應(yīng)用程序以這個(gè)接口為標(biāo)準(zhǔn)進(jìn)行交流。目前的V4L涵蓋了視、音頻流捕捉及處理等內(nèi)容,USB攝像頭也屬于它支持的范疇。
因此,USB攝像頭的驅(qū)動(dòng)應(yīng)當(dāng)與內(nèi)核提供的視頻驅(qū)動(dòng)掛鉤。即首先在驅(qū)動(dòng)中聲明一個(gè)video_device結(jié)構(gòu),并為其指定文件操作函數(shù)指針數(shù)組.fops,向系統(tǒng)注冊(cè)。在應(yīng)用程序發(fā)出文件操作的相關(guān)命令時(shí),核心根據(jù)這些指針調(diào)用相應(yīng)函數(shù),并將該結(jié)構(gòu)作為參數(shù)傳遞給它們。這樣,就完成了驅(qū)動(dòng)和核心之間的通信。例如:
static struct video_device vdev_template={……};
//聲明video_device,指出掛接驅(qū)動(dòng)
static struct file_operations ov511_fops={……};
?。暶鞅掘?qū)動(dòng)的文件操作函數(shù)指針
struct video_device*vdev=video_devdata(file);
//從文件指針中提取出video_device結(jié)構(gòu)
在video_device結(jié)構(gòu)中,有一個(gè)私有指針priv,可以將它指向一塊保留內(nèi)存。在這塊內(nèi)存中,保存著本驅(qū)動(dòng)、本設(shè)備的相關(guān)初始化信息。這塊內(nèi)存的申請(qǐng)、初始化、指針指向等工作都是在USB驅(qū)動(dòng)的枚舉函數(shù).probe中完成。這樣,在枚舉函數(shù)將控制權(quán)返還給系統(tǒng)后,因?yàn)閮?nèi)核不銷毀保留內(nèi)存,所以驅(qū)動(dòng)仍然保留著自己的信息。這點(diǎn)與Windows系統(tǒng)中WDM驅(qū)動(dòng)有異曲同工之處。當(dāng)然,在驅(qū)動(dòng)卸載函數(shù)中,應(yīng)當(dāng)將申請(qǐng)的各塊內(nèi)存全部釋放。
1.2 使用雙URB輪流通信
眾所周知,USBl.1總線標(biāo)準(zhǔn)定義了控制、中斷、批量、等時(shí)等四種管道。對(duì)于時(shí)間性極強(qiáng)但是準(zhǔn)確度要求不高的視頻捕捉應(yīng)用來說,攝像頭應(yīng)當(dāng)使用等時(shí)傳輸方式。為了盡可能快地得到圖像數(shù)據(jù),應(yīng)當(dāng)在URB中指定USB_ISO_ASAP標(biāo)志。
urb-》transfer_flags=USB_ISO_ASAP;//盡可能快地發(fā)出本URB
Linux系統(tǒng)中任何USB傳輸都通過URB實(shí)現(xiàn)。為提高速度,可以考慮擴(kuò)大URB的緩沖,這樣可以降低每個(gè)USB事務(wù)中握手信息所占比例,提高有效數(shù)據(jù)的傳輸速度。但是受限于總線帶寬和具體的USB設(shè)備芯片,單純擴(kuò)大URB的緩沖不能無限制地解決問題。具體分析一下USB傳輸在操作系統(tǒng)中的實(shí)現(xiàn):每次傳輸都要包括URB的建立、發(fā)出、回收、數(shù)據(jù)整理等階段,這些時(shí)間不產(chǎn)生有效數(shù)據(jù)。因此可以建立兩個(gè)URB,在等待一個(gè)URB被回收時(shí),也就是圖像正在被傳感器采集時(shí),處理、初始化另一個(gè)URB,并在回收后立刻將其發(fā)出。兩個(gè)URB交替使用,大大減少了額外時(shí)間。工作流程如圖1所示。
這個(gè)過程是在URB的完成例程中實(shí)現(xiàn)的,有兩點(diǎn)需要注意:首先處理再次初始化的代碼時(shí)間不能長(zhǎng),否則會(huì)造成完成例程的重人,如果確實(shí)來不及,可以在完成例程中設(shè)定標(biāo)志,例如“數(shù)據(jù)采集好”旗語,由應(yīng)用程序使用阻塞ioctl()來查詢?cè)撈煺Z并做處理;其次由于CPU可能會(huì)在完成例程中停留較長(zhǎng)時(shí)間,系統(tǒng)負(fù)擔(dān)較大,可以在.open函數(shù)中初始化兩個(gè)URB并將其發(fā)出,有限度地減輕系統(tǒng)負(fù)擔(dān)。
1.3 使用雙幀緩沖提高效率
Linux系統(tǒng)中,文件操作通常是由read、write等系統(tǒng)調(diào)用來完成。這些系統(tǒng)調(diào)用在驅(qū)動(dòng)中的解決方法就是用copy_to_user()、copy_from_user()等函數(shù)在核態(tài)、戶態(tài)內(nèi)存空間中互相拷貝。但是對(duì)于大批量的圖像數(shù)據(jù),采用拷貝的方法顯然會(huì)增加時(shí)間開銷,因此用內(nèi)存映射的方法解決。首先使用vmalloc()申請(qǐng)足夠大的核態(tài)內(nèi)存,將其作為圖像數(shù)據(jù)緩沖空間,兩個(gè)URB帶回的圖像數(shù)據(jù)在這里暫存;然后使用remap_page_range()函數(shù)將其逐頁映射到用戶空間中。戶態(tài)的圖像處理程序使用mmap()函數(shù),直接讀寫核態(tài)圖像緩沖內(nèi)存,大大減少額外開銷。
圖像數(shù)據(jù)的處理可能要花費(fèi)比較長(zhǎng)的時(shí)間,不同的算法對(duì)于數(shù)據(jù)保留時(shí)間的要求也不一樣。因此可以申請(qǐng)兩幀圖像緩沖,在處理一幀圖像的同時(shí),將兩個(gè)URB帶回的數(shù)據(jù)全部填充到另一幀緩沖中,這樣可以免去時(shí)間沖突上的麻煩。
值得注意的是:這種方法要求時(shí)刻持有當(dāng)前幀的序號(hào)、每一幀的起始地址等信息,不能將兩幀圖像混淆。這些信息可以保存在保留內(nèi)存中,當(dāng)前幀的數(shù)據(jù)整理、序號(hào)改變?cè)赨RB完成例程中實(shí)現(xiàn)。
二、 V4L標(biāo)準(zhǔn)的改進(jìn)
V4L標(biāo)準(zhǔn)目前已經(jīng)發(fā)展到第二版V4L2,其基本思路與V4L相同。
2.1 標(biāo)準(zhǔn)分析
根據(jù)V4L標(biāo)準(zhǔn),戶態(tài)程序在需要一幀圖像時(shí),CPU的走向如圖2。CPU按照123456的順序完成一個(gè)循環(huán)。在這里,有一個(gè)細(xì)節(jié)被忽略:在完成例程中,也就是圖2中步驟6,該URB被立刻發(fā)出,但是由于這時(shí)用戶程序正在阻塞等待,沒辦法再次提出獲得圖像的申請(qǐng),因此在判斷有無新請(qǐng)求時(shí),判斷的結(jié)果必然是當(dāng)前無請(qǐng)求,導(dǎo)致下一個(gè)URB帶回的數(shù)據(jù)被驅(qū)動(dòng)丟棄;由于核態(tài)、戶態(tài)的切換需要一定的時(shí)間,加上戶態(tài)多進(jìn)程同步等開銷,等到應(yīng)用程序能夠再次發(fā)出獲得一副圖像的申請(qǐng)時(shí),已經(jīng)有不止一個(gè)URB帶回的數(shù)據(jù)被丟棄掉,這些URB包含的數(shù)據(jù)正好是新一幀圖像的開始部分。因此驅(qū)動(dòng)必須等到再下一幀圖像才能保存數(shù)據(jù)、緩沖。這樣憑白損失了一幀圖像,幀速最少下降一半。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 嵌入式Linux的攝像頭驅(qū)動(dòng)程序設(shè)計(jì)與實(shí)現(xiàn)
- USB攝像頭設(shè)備驅(qū)動(dòng)的開發(fā)資料下載
- 如何使用Linux內(nèi)核實(shí)現(xiàn)USB驅(qū)動(dòng)程序框架 19次下載
- Linux系統(tǒng)中如何安裝攝像頭驅(qū)動(dòng) 5次下載
- 基于Linux下基于ARM920T的USB攝像頭圖像采集 13次下載
- USB接口驅(qū)動(dòng)程序開發(fā)
- 基于V4L2的Linux攝像頭驅(qū)動(dòng)的實(shí)現(xiàn)
- 攝像頭的WINCE驅(qū)動(dòng)及操作說明
- USB攝像頭驅(qū)動(dòng)資料
- USB攝像頭驅(qū)動(dòng)程序和圖像采集程序的實(shí)現(xiàn)方法
- 基于USB設(shè)備的Linux網(wǎng)絡(luò)驅(qū)動(dòng)程序開發(fā)
- acer Aspire 4315 Bison攝像頭驅(qū)動(dòng)程序下
- 飛視攝像頭驅(qū)動(dòng)程序下載
- 良田攝像頭211驅(qū)動(dòng)程序下載
- 良田攝像頭萬能驅(qū)動(dòng)程序下載
- 用usb攝像頭替換手機(jī)前置攝像頭可以嗎 1508次閱讀
- ROS系統(tǒng)讀取USB相機(jī)圖像數(shù)據(jù) 573次閱讀
- HDF驅(qū)動(dòng)框架中USB DDK的解析與開發(fā)指導(dǎo) 2000次閱讀
- 基于V4L技術(shù)和攝像頭的Linux驅(qū)動(dòng)程序的設(shè)計(jì)與實(shí)現(xiàn) 2811次閱讀
- 微雪電子IMX179超清USB攝像頭簡(jiǎn)介 4480次閱讀
- 米爾科技LINUX設(shè)備驅(qū)動(dòng)程序教程 1965次閱讀
- 基于OmniVision的OV5640設(shè)計(jì)的USB攝像頭模塊 5661次閱讀
- 嵌入式Linux內(nèi)核的驅(qū)動(dòng)程序開發(fā)是怎樣的 1415次閱讀
- USB驅(qū)動(dòng)開發(fā)的步驟及方法解析 1.1w次閱讀
- 盤點(diǎn)屏下攝像頭技術(shù) 7296次閱讀
- 基于Linux2.6.30開發(fā)DS18B20的驅(qū)動(dòng)程序的類型和文件操作接口函數(shù)詳解 1377次閱讀
- 攝像頭芯片型號(hào)有哪些_攝像頭芯片型號(hào)匯總 5.9w次閱讀
- 可動(dòng)態(tài)安裝的Linux設(shè)備驅(qū)動(dòng)程序 957次閱讀
- 深入了解USB驅(qū)動(dòng)之總線驅(qū)動(dòng)程序 8685次閱讀
- PCI驅(qū)動(dòng)程序開發(fā)實(shí)例 6701次閱讀
下載排行
本周
- 1TPS54202H降壓轉(zhuǎn)換器評(píng)估模塊用戶指南
- 1.02MB | 7次下載 | 免費(fèi)
- 2華瑞昇CR215芯片數(shù)字萬用表原理圖
- 0.21 MB | 1次下載 | 3 積分
- 3SMD LED選型目錄 燈珠手冊(cè)
- 5.36 MB | 1次下載 | 免費(fèi)
- 4Tiva C系列DK-TM4C129X入門指南
- 1.69MB | 1次下載 | 免費(fèi)
- 5電涌保護(hù)器(SPD)的選擇、安裝以及裝配
- 4.57 MB | 1次下載 | 免費(fèi)
- 6時(shí)源芯微EMC前車燈案例
- 458.59 KB | 1次下載 | 免費(fèi)
- 7bq25890、bq25892雙級(jí)聯(lián)充電器EVM(PWR692)用戶指南
- 2.02MB | 1次下載 | 免費(fèi)
- 8TPS54426降壓轉(zhuǎn)換器評(píng)估模塊用戶指南
- 847.7KB | 次下載 | 免費(fèi)
本月
- 1ADI高性能電源管理解決方案
- 2.43 MB | 156次下載 | 免費(fèi)
- 22024PMIC市場(chǎng)洞察
- 2.23 MB | 63次下載 | 免費(fèi)
- 3開關(guān)電源設(shè)計(jì)原理手冊(cè)
- 1.83 MB | 30次下載 | 免費(fèi)
- 4智能門鎖原理圖
- 0.39 MB | 28次下載 | 免費(fèi)
- 5OAH0428最新規(guī)格書(中文)
- 2.52 MB | 15次下載 | 7 積分
- 6ST7789V2單芯片控制器/驅(qū)動(dòng)器英文手冊(cè)
- 3.07 MB | 9次下載 | 1 積分
- 7LTH7充電電路和鋰電池升壓5V輸出電路原理圖
- 0.04 MB | 7次下載 | 免費(fèi)
- 8TPS54202H降壓轉(zhuǎn)換器評(píng)估模塊用戶指南
- 1.02MB | 7次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935119次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420061次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233084次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191367次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183334次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81581次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73807次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65987次下載 | 10 積分
評(píng)論
查看更多