作者:蝸蝸 發(fā)布于:2014-2-27 17:01 1. 前言在“Linux內核的整體架構”中,蝸蝸有提到,由于Linux支持世界上幾乎所有的、不同功能的硬件設備(這是Linux的優(yōu)點),導致Linux內核中有一半的代碼是設備驅動,而且隨著硬件的快速升級換代,設備驅動的代碼量也在快速增長。個人意見,這種現象打破了“簡潔就是美”的理念,是丑陋的。它導致Linux內核看上去非常臃腫、雜亂、不易維護。但蝸蝸也知道,這不是Linux的錯,Linux是一個宏內核,它必須面對設備的多樣性,并實現對應的驅動。 為了降低設備多樣性帶來的Linux驅動開發(fā)的復雜度,以及設備熱拔插處理、電源管理等,Linux內核提出了設備模型(也稱作Driver Model)的概念。設備模型將硬件設備歸納、分類,然后抽象出一套標準的數據結構和接口。驅動的開發(fā),就簡化為對內核所規(guī)定的數據結構的填充和實現。 本文將會從設備模型的基本概念開始,通過分析內核相應的代碼,一步一步解析Linux設備模型的實現及使用方法。 2. Linux設備模型的基本概念2.1 Bus, Class, Device和Device Driver的概念硬件拓撲描述Linux設備模型中四個重要概念中三個:Bus,Class和Device(第四個為Device Driver,后面會說)。 Bus(總線):Linux認為(可以參考include/linux/device.h中struct bus_type的注釋),總線是CPU和一個或多個設備之間信息交互的通道。而為了方便設備模型的抽象,所有的設備都應連接到總線上(無論是CPU內部總線、虛擬的總線還是“platform Bus”)。 Class(分類):在Linux設備模型中,Class的概念非常類似面向對象程序設計中的Class(類),它主要是集合具有相似功能或屬性的設備,這樣就可以抽象出一套可以在多個設備之間共用的數據結構和接口函數。因而從屬于相同Class的設備的驅動程序,就不再需要重復定義這些公共資源,直接從Class中繼承即可。 Device(設備):抽象系統(tǒng)中所有的硬件設備,描述它的名字、屬性、從屬的Bus、從屬的Class等信息。 Device Driver(驅動):Linux設備模型用Driver抽象硬件設備的驅動程序,它包含設備初始化、電源管理相關的接口實現。而Linux內核中的驅動開發(fā),基本都圍繞該抽象進行(實現所規(guī)定的接口函數)。
注:什么是Platform Bus? 2.2 設備模型的核心思想Linux設備模型的核心思想是(通過xxx手段,實現xxx目的): 1. 用Device(struct device)和Device Driver(struct device_driver)兩個數據結構,分別從“有什么用”和“怎么用”兩個角度描述硬件設備。這樣就統(tǒng)一了編寫設備驅動的格式,使驅動開發(fā)從論述題變?yōu)樘羁阵w,從而簡化了設備驅動的開發(fā)。
2. 同樣使用Device和Device Driver兩個數據結構,實現硬件設備的即插即用(熱拔插)。
3. 通過"Bus-->Device”類型的樹狀結構(見2.1章節(jié)的圖例)解決設備之間的依賴,而這種依賴在開關機、電源管理等過程中尤為重要。 4. 使用Class結構,在設備模型中引入面向對象的概念,這樣可以最大限度地抽象共性,減少驅動開發(fā)過程中的重復勞動,降低工作量。 |
|