女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當前位置:首頁 > > 充電吧
[導讀]probe是usb子系統(tǒng)自動調用的一個函數(shù),有USB設備接到硬件集線器時,usb子系統(tǒng)會根據(jù)production ID和vendorID的組合或者設備的class、subclass跟protocol的

probe是usb子系統(tǒng)自動調用的一個函數(shù),有USB設備接到硬件集線器時,usb子系統(tǒng)會根據(jù)production ID和vendorID的組合或者設備的class、subclass跟protocol的組合來識別設備調用相應驅動程序的probe(探測)函數(shù),對于skeleton來說,就是skel_probe。系統(tǒng)會傳遞給探測函數(shù)一個usb_interface *跟一個struct usb_device_id*作為參數(shù)。他們分別是該USB設備的接口描述(一般會是該設備的第0號接口,該接口的默認設置也是第0號設置)跟它的設備ID描述(包括VendorID、Production ID等)。Probe函數(shù)比較長,我們分段來分析這個函數(shù):

???? dev->udev = usb_get_dev(interface_to_usbdev(interface));

???? dev->interface = interface;

在初始化了一些資源之后,我們可以看到第一個關鍵的函數(shù)調用——interface_to_usbdev。他同uo一個usb_interface來得到該接口所在設備的設備描述結構。本來,要得到一個usb_device只要用interface_to_usbdev就夠了,但因為要增加對該usb_device的引用計數(shù),我們應該在做一個usb_get_dev的操作,來增加引用計數(shù),并在釋放設備時用usb_put_dev來減少引用計數(shù)。這里要解釋的是,該引用計數(shù)值是對該usb_device的計數(shù),并不是對本模塊的計數(shù),本模塊的計數(shù)要由kref來維護。所以,probe一開始就有初始化kref。事實上,kref_init操作不單只初始化kref,還將其置設成1。所以在出錯處理代碼中有kref_put,它把kref的計數(shù)減1,如果kref計數(shù)已經為0,那么kref會被釋放。Kref_put的第二個參數(shù)是一個函數(shù)指針,指向一個清理函數(shù)。注意,該指針不能位空,或者kfree。該函數(shù)會在最后一個對kref的引用釋放時被調用(如果我的理解不準確,請指正)。下面是內核源碼中的一段注釋及代碼:

/**

?* kref_put - decrement refcount for object.

?* @kref: object.

?* @release: pointer to the function that will clean up the object when the

?*?? ???? last reference to the object is released.

?*?? ???? This pointer is required, and it is not acceptable to pass kfree

?*?? ???? in as this function.

?*

?* Decrement the refcount, and if 0, call release().

?* Return 1 if the object was removed, otherwise return 0.? Beware, if this

?* function returns 0, you still can not count on the kref from remaining in

?* memory.? Only use the return value if you want to see if the kref is now

?* gone, not present.

?*/

int kref_put(struct kref *kref, void (*release)(struct kref *kref))

{

???? WARN_ON(release == NULL);

???? WARN_ON(release == (void (*)(struct kref *))kfree);

?

???? /*

???? ?* if current count is one, we are the last user and can release object

???? ?* right now, avoiding an atomic operation on 'refcount'

???? ?*/

???? if ((atomic_read(&kref->refcount) == 1) ||

???? ??? (atomic_dec_and_test(&kref->refcount))) {

???????? release(kref);

???????? return 1;

???? }

???? return 0;

}

當我們執(zhí)行打開操作時,我們要增加kref的計數(shù),我們可以用kref_get,來完成。所有對struct kref的操作都有內核代碼確保其原子性。

得到了該usb_device之后,我們要對我們自定義的usb_skel各個狀態(tài)跟資源作初始化。這部分工作的任務主要是向usb_skel注冊該usb設備的端點。這里可能要補充以下一些關于usb_interface_descriptor的知識,但因為內核源碼對該結構體的注釋不多,所以只能靠個人猜測。在一個usb_host_interface結構里面有一個usb_interface_descriptor叫做desc的成員,他應該是用于描述該interface的一些屬性,其中bNubEndpoints一個8位(b forbyte)的數(shù)字,他代表了該接口的端點數(shù)。Probe然后遍歷所有的端點,檢查他們的類型跟方向,注冊到usb_skel中。

???? /* set up the endpoint information */

???? /* use only the first bulk-in and bulk-out endpoints */

???? iface_desc = interface->cur_altsetting;

???? for (i = 0; i < iface_desc->desc.bNumEndpoints; ++i) {

???????? endpoint = &iface_desc->endpoint[i].desc;

?

???????? if (!dev->bulk_in_endpointAddr &&

???????? ??? ((endpoint->bEndpointAddress & USB_ENDPOINT_DIR_MASK)

?????????????????????? == USB_DIR_IN) &&

???????? ??? ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK)

?????????????????????? == USB_ENDPOINT_XFER_BULK)) {

????????????? /* we found a bulk in endpoint */

????????????? buffer_size = le16_to_cpu(endpoint->wMaxPacketSize);

????????????? dev->bulk_in_size = buffer_size;

????????????? dev->bulk_in_endpointAddr = endpoint->bEndpointAddress;

????????????? dev->bulk_in_buffer = kmalloc(buffer_size, GFP_KERNEL);

????????????? if (!dev->bulk_in_buffer) {

?????????????????? err("Could not allocate bulk_in_buffer");

?????????????????? goto error;

????????????? }

???????? }

?

???????? if (!dev->bulk_out_endpointAddr &&

???????? ??? ((endpoint->bEndpointAddress & USB_ENDPOINT_DIR_MASK)

?????????????????????? == USB_DIR_OUT) &&

???????? ??? ((endpoint->bmAttributes & USB_ENDPOINT_XFERTYPE_MASK)

?????????????????????? == USB_ENDPOINT_XFER_BULK)) {

????????????? /* we found a bulk out endpoint */

????????????? dev->bulk_out_endpointAddr = endpoint->bEndpointAddress;

???????? }

???? }

???? if (!(dev->bulk_in_endpointAddr && dev->bulk_out_endpointAddr)) {

???????? err("Could not find both bulk-in and bulk-out endpoints");

???????? goto error;

???? }


本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉