淺析 Qt Embedded 鍵盤驅動分析 (上)
經(jīng)??吹接腥藛栆浦?strong>Qt Embedded時如何鍵盤響應不靈怎么辦,可能系統(tǒng)介紹這方面知識的文章比較少,這里筆者就盡我所能介紹一下,以填補以往的空白。
我們都知道Qt-x11借助XServer提供對硬件外設的接口,不需要直接和driver打交道,Qt Embedded則顛覆了這個傳統(tǒng)并且摒棄了對XServer的依賴, 所以免不了要有和硬件driver交互的時候。為了保持Qt Embedded 對硬件最小化的依賴程度,Qt Embedded所有硬件相關的操作都采用插件的封裝形式,并且大部分功能都可以從程序外部運用環(huán)境變量的方式來配置。 這樣一來我們只要針對不同的硬件寫好不同的插件,為不同硬件平臺提供不同的啟動腳本就可以了,換了硬件代碼卻不需要修改,這是多么愜意的事啊!簡直是嵌入式開發(fā)的***目標!
Qt Embedded的鍵盤操作是這種插件封裝形式的典范,我們就以此為例,對Qt Embedded的硬件操作一窺究竟。
告訴Qt Embedded你需要哪個驅動
QWS_KEYBOARD這個環(huán)境變量就是你需要了解的全部。
設置該變量的方法為在運行QtE server程序之前用下面的命令設置:
export QWS_KEYBOARD= <driver>[:<driver specific options>]
driver參數(shù)即驅動的鍵值, 如“usb”、“tty”等, 在下篇中我們再詳細討論這個。
options則指定硬件設備名, 如/dev/input/event0, 這個參數(shù)就要按你的硬件實際情況來提供了。
載入用戶需要的驅動插件
這個環(huán)境變量是如何工作的呢? 今天我們講述的重點放在QtE的幾個文件上:
讀取環(huán)境變量, 載入相應的鍵盤驅動插件:src/gui/embedded/qwindowsystem_qws.cpp
創(chuàng)建鍵盤處理函數(shù)類的實例:src/gui/embedded/qkbddriverfactory_qws.cpp
故事從QWSServerPrivate::initServer開始, 這個函數(shù)在QWSServer構造時被調用, 它會完成初始化的工作, 包括按順序初始化各個硬件接口(鼠標、鍵盤等等外設), 這個函數(shù)接近***的幾行代碼調用了openKeyboard來初始化鍵盤。
第二步進到同一源碼文件的QWSServer::openKeyboard(), 該函數(shù)負責解析環(huán)境變量 QWS_KEYBOARD的設定, 從中取得鍵盤設備的名稱和driver handler的類型, 并最終調用QKbdDriverFactory::create函數(shù)載入對應的鍵盤處理插件。
第三步也是本場大戲的重頭, 打開qkbddriverfactory_qws.cpp找到QKbdDriverFactory::create函數(shù)。 前面我們說到過這個函數(shù)包含了創(chuàng)建鍵盤處理函數(shù)的類的實例的代碼, 簡單看一下這個函數(shù)我們發(fā)現(xiàn), 前面大段的code是一堆跟硬件類型相關的宏包裹住的代碼, 這部分代表了Qt里內嵌的driver handler, 而非插件形式提供的。 QtE自身支持的每個鍵盤設備都有一個預定義的宏和預定義的driver handler類與之對應, 根據(jù)代碼顯示, 設備的類型必須在configure階段就確定, 以X86模擬器環(huán)境下為例, 在這個環(huán)境下configure的時候需要加 -qvfb參數(shù), 這個參數(shù)就會去掉 QT_NO_QWS_KBD_QVFB這個宏, 在此函數(shù)中就表示為調用到return new QVFbKeyboardHandler(device);這行。
那么,如果上面所有的QT_NO都被定義了呢? 當然代碼就會跳過這一堆無用的code, 直接調用到
if (QWSKeyboardHandlerFactoryInterface *factory = qobject_cast<QWSKeyboardHandlerFactoryInterface*>(loader()->instance(driver)))
return factory->create(driver, device);
這段代碼就比較有意思了,它代表的是以插件形式存在的各個鍵盤處理插件。在你不使用Qt預定義鍵盤處理的情況下就需要有與環(huán)境變量請求的driver handler鍵值一致的插件。鍵盤處理插件如何定義不是本文探討的內容(請參看下篇),我們只要知道這個插件會提供一個標識自己的鍵值,這樣loader比較創(chuàng)建插件的請求和插件的鍵值就知道該返回哪個插件提供的服務了。
還有幾點有意思的地方:
1、 driver的類型信息不區(qū)分大小寫。
2、 QtE內嵌的driver類型默認是都不支持的, 只有在configure的時候加上-qt-kbd-xxx才能支持某種driver類型。(詳情 configure –help)
3、 同一時刻只能有一個driver處理函數(shù)生效。
4、 由于這部分代碼都在QWSServer構造時調用, 也就是說QtE不支持動態(tài)的更改鍵盤處理。
小結:Qt Embedded 鍵盤驅動分析的內容就介紹到這里,希望本篇文章對你有所幫助!請繼續(xù)參考 淺析 Qt Embedded 鍵盤驅動分析 。