extcon驅動及其在USB驅動中的應用

来源:https://www.cnblogs.com/bigfish0506/archive/2022/05/13/16268527.html
-Advertisement-
Play Games

extcon,是External Connector的簡稱,用於抽象外部連接器,比如說Audio Jack、USB MicroB/TypeC介面等。 ...


extcon,是External Connector的簡稱,用於抽象外部連接器,比如說Audio Jack、USB MicroB/TypeC介面等。它的原型是Android的switch-class驅動,經過修改後在kernel 3.4.0版本時被引入內核中。

Extcon (external connector): import Android's switch class and modify.

External connector class (extcon) is based on and an extension of Android kernel's switch class located at linux/drivers/switch/.

https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/commit/drivers/extcon?h=next-20220502&id=de55d8716ac50a356cea736c29bb7db5ac3d0190

extcon驅動的主要功能是識別外部連接器狀態變化,並將狀態變化通知到與外部連接器相關的其他驅動。

使用extcon驅動,有什麼好處呢?之前的內核都沒有extcon驅動,又是怎麼處理這些外部連接器的?不妨以USB驅動為例,看看使用extcon驅動前後的變化。

USB常見的外部介面有TypeA/B/C三種,其中TypeA/B又有標準A/B、Mini A/B和Micro A/B三種,直接上圖:

這三種不同的介面,TypeA/B只是物理信號上的連接,主控晶元內部沒有針對TypeA/B的專用控制器,可通過VBUS和ID兩個腳的狀態來識別是否接入了USB主機或USB外設。接入主機前,VBUS腳上沒有電壓,接入主機後,主機端會在VBUS腳上提供5V電壓;接入外設前,ID腳為高電平,接入外設後,ID腳被拉低。於是軟體可以通過主動讀取這兩個腳的電平或者非同步響應這兩個腳的中斷來獲知狀態的變化。

TypeC就有點特別,從TypeC規範可以看到,TypeC是有一個狀態機的,從Unattached狀態走到Attached Sink狀態(做從設備)或者Attached Source狀態(做主機),主控晶元內部是有相應的控制器的,控制器會通過寄存器彙報狀態變化,並產生中斷通知主控。TypeC控制器需要軟體進行相應的編程來配置和使能它。

截圖來自官方規範:USB Type-C 2.1 Release

https://www.usb.org/document-library/usb-type-cr-cable-and-connector-specification-release-21

 

以上就是USB針對不同外部介面所面臨的狀況。在extcon驅動出現之前,同一份USB控制器驅動代碼,比較常見的做法就是在設備樹(dts)中指明是哪種介面,USB控制器驅動代碼中會解析設備樹中的定義,通過if...else...來走不同的代碼邏輯。如果是MicroB介面,就註冊VBUS和ID腳的中斷、查詢IO腳的電平狀態;如果是TypeC介面,就註冊TypeC的中斷,查詢TypeC的狀態。假設後續又有新的介面出現,工作原理不同於已有的介面,那就又需要在USB控制器驅動中去增加相關代碼。

在extcon驅動出現後,USB控制器驅動就能和外部介面驅動解耦。在USB控制器驅動看來,不管外部介面是什麼,我只需知道外部介面狀態的變化就好了,比如是否接入主機了、是否有設備接入了。使用extcon驅動提供的函數介面來註冊notifier,當外部介面狀態變化時,extcon驅動負責回調notifier,USB控制器驅動代碼無需再針對不同的外部介面改來改去。不同的外部介面,都用extcon來抽象自己的行為。

以上都是原理性的介紹,最後還是要落實到代碼上才夠清晰。以內核原生代碼為例:

drivers\extcon\extcon-usb-gpio.c  //extcon驅動示例drivers\usb\dwc3\dwc3-omap.c  //使用extcon示例

extcon-usb-gpio.c實現了通過IO腳(VBUS和ID)檢測USB插拔的extcon驅動。整個驅動是以platform driver為框架。

在驅動的probe函數中,會從設備樹獲取VBUS和ID腳對應的GPIO。設備樹中定義了這個extcon設備的相關屬性。

接著會分配並註冊一個extcon device。usb_extcon_cable數組定義了這個extcon device所支持的狀態類型,EXTCON_USB表示USB做Device,EXTCON_USB_HOST表示USB做Host。狀態值當然是插入或者拔出。

最後註冊ID腳和VBUS腳的中斷,註意這裡兩個腳的中斷處理函數都是usb_irq_handler。兩個腳的中斷處理函數也不是非要是同一個,這裡設置為同一個,是為了邏輯處理上的方便,因為VBUS和ID腳要聯合判斷。

usb_irq_handler函數里會queue work,這個work對應的處理函數如下圖。通過extcon_set_state_sync函數通知其他驅動,只要有驅動註冊了相應的notifier,就會被通知到。

以上是extcon-usb-gpio.c的實現,類似地,TypeC驅動也可以註冊extcon device,通過extcon_set_state_sync函數向其他驅動彙報狀態,這裡就不再重覆地舉例。

最後看看dwc3-omap.c如何使用extcon。該驅動的probe函數中會調用下圖函數,該函數首先調用extcon_get_edev_by_phandle從設備樹獲取extcon device,然後註冊notifier,當extcon device狀態變化時,notifier被回調;也可以通過extcon_get_state主動查詢extcon device的狀態。

 

------ END ------

作者:bigfish99

博客:https://www.cnblogs.com/bigfish0506/

公眾號:大魚嵌入式


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 以前我們定義類都是用class關鍵詞,但從Java 16開始,我們將多一個關鍵詞record,它也可以用來定義類。record關鍵詞的引入,主要是為了提供一種更為簡潔、緊湊的final類的定義方式。 下麵就來具體瞭解record類的細節。配套視頻教程:Java 16 新特性:使用record聲明類 ...
  • Spring Ioc源碼分析系列--Ioc容器BeanFactoryPostProcessor後置處理器分析 前言 上一篇文章Spring Ioc源碼分析系列--Ioc源碼入口分析已經介紹到Ioc容器的入口refresh()方法,並且分析了refresh()方法裡面的前三個子方法分析了一下。還記得分 ...
  • Predicate<T>:常用的四個方法 boolean test(T t):對給定的參數進行判斷(判斷邏輯由Lambda表達式實現),返回一個布爾值 default Predicate<T>negate():返回一個邏輯的否定,對應邏輯非 default Predicate<T>and(Predi ...
  • 停更這些天,業餘時間和粉絲群的幾個大佬合作寫了一個基於Spring Authorization Server的OAuth2授權伺服器的管理控制台項目Id Server,我覺得這個項目能夠大大降低OAuth2授權伺服器使用難度。可以讓你很方便地去管理OAuth2客戶端信息,甚至可以一鍵生成OAuth2 ...
  • 前言 刷題地址:https://buuoj.cn/challenges 首先打開是一個笑臉,查看源代碼,如下圖發現了,一個文件 一.代碼分析 發現是一堆代碼,需要PHP代碼審計,全部代碼如下。 1 <?php 2 highlight_file(lxx_file); 3 class emmm 4 { ...
  • Python內置函數 | V3.9.1 | 共計155個 還沒學完, 還沒記錄完, 不知道自己能不能堅持記錄下去 1.ArithmeticError 2.AssertionError 3.AttributeError 4.BaseException 5.BlockingIOError 6.Broke ...
  • 1、while迴圈 當指定的條件為真時迴圈執行代碼塊 while 語法: while (condition) { statement; } 比如: <?php $i=1; while($i<=5) { echo "The number is " . $i . "<br>"; $i++; } ?> d ...
  • 最近使用WPF開發項目,為了對WPF知識點進行總結,所以利用業餘時間,開發一個學生信息管理系統【Student Information Management System】。本文主要簡述如何通過WPF+Prism+MAH+WebApi進行開發基於三層架構的桌面版應用程式,僅供學習分享使用,如有不足之... ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...