關 閉

新聞中心

EEPW首頁 > 工控自動化 > 設計應用 > 基于PXA255的觸摸屏控制器ADS7843驅(qū)動程序設計

基于PXA255的觸摸屏控制器ADS7843驅(qū)動程序設計

作者: 時間:2012-04-20 來源:網(wǎng)絡 收藏

在便攜式的電子類產(chǎn)品中,由于其便、靈活、占用空間少等優(yōu)點,已經(jīng)逐漸取代鍵盤成為嵌入式計算機系統(tǒng)常選用的人機交互輸入設備。輸入系統(tǒng)由、觸摸屏、微及其相應的程序構(gòu)成。本文從觸摸屏著手,介紹觸摸屏控制器的內(nèi)部結(jié)構(gòu)及工作原理和在嵌入式Linux操作系統(tǒng)中微處理器的。

本文引用地址:http://butianyuan.cn/article/160763.htm

1、觸摸屏控制器的介紹

1.1 ADS7843的內(nèi)部結(jié)構(gòu)

ADS7843 內(nèi)駐一個多路低導通電阻模擬開關組成的供電-測量電路網(wǎng)絡、12bit逐次逼近A/D轉(zhuǎn)換器和異步串行數(shù)據(jù)輸入輸出,ADS7843根據(jù)微控制器發(fā)來的不同測量命令導通相應的模擬開關,以便向觸摸屏電極對提供電壓,并把相應電極上的觸點坐標位置所對應的電壓模擬量引入A/D轉(zhuǎn)換器,圖1為ADS7843內(nèi)部結(jié)構(gòu)圖。X+、Y+、X-、Y-為觸摸屏電極模擬電壓輸入;CS為ADS7843的片選輸入信號,低電平有效;DCLK接外部時鐘輸入,為芯片進行 A/D轉(zhuǎn)換和異步串行數(shù)據(jù)輸入/輸出提供時鐘;DIN串行數(shù)據(jù)輸入端,當CS低電平時,輸入數(shù)據(jù)在時鐘的上升沿將串行數(shù)據(jù)鎖存;DOUT串行數(shù)據(jù)輸出端, 在時鐘下降沿數(shù)據(jù)由此移位輸出,當CS為高電平時,DOUT呈高阻態(tài)。BUSY為系統(tǒng)忙標志端,當CS為低電平,且BUSY為高電平時,表示 ADS7843正在進行數(shù)據(jù)轉(zhuǎn)換;VREF參考電壓輸入端,電壓值在+1V到+VCC之間變化;PENIRQ為筆觸中斷,低電平有效;IN3、IN4為輔助ADC轉(zhuǎn)換輸入通道;+VCC為電源輸入。

30.jpg
圖1 ADS7843內(nèi)部結(jié)構(gòu)

1.2 ADS7843的轉(zhuǎn)換時序

ADS7843 完成一次數(shù)據(jù)轉(zhuǎn)換需要與微控制器進行3次通信,第一次微處理器通過異步數(shù)據(jù)傳送向ADS843發(fā)送控制字,其中包括起始位、通道選擇、8/12位模式、差分/單端選擇和掉電模式選擇,其后的兩次數(shù)據(jù)傳送則是微控制器從ADS7843取出16bitA/D轉(zhuǎn)換結(jié)果數(shù)據(jù)(最后四位自動補零),每次通信需要8個時鐘周期,完成一次數(shù)據(jù)轉(zhuǎn)換共需24個時鐘周期,圖2為ADS7843轉(zhuǎn)換時序。

31.jpg
圖2 ADS7843轉(zhuǎn)換時序

2、ADS7843與硬件接口

微處理器是Intel公司生產(chǎn)的第二代32位XScale微架構(gòu)的集成系統(tǒng)芯片(ISOC),PXA255具有高性能、低功耗等優(yōu)點,它除了 XScale微內(nèi)核外,還集成了許多適用于手持設備市場需要的外圍設備。圖3為ADS7843觸摸屏控制器與PXA255微處理器的硬件連線示意圖。當屏觸發(fā)生時ADS7843向PXA255發(fā)出中斷請求,由PXA255響應該中斷請求,啟動通信過程,讀取ADS7843的轉(zhuǎn)換結(jié)果,從而得到觸摸點的坐標。ADS7843各信號的時序受外部輸入時鐘信號頻率的影響,一旦外部輸入時鐘頻率固定,各信號的時序便完全確定,因此需要配置PXA255的接口信號時序,使之完全符合ADS7843的時序。

32.jpg
圖3 ADS7843觸摸屏控制器與PXA255微處理器的連線示意圖

3、ADS7843驅(qū)動程序的設計

Linux 作為一個宏內(nèi)核操作系統(tǒng),其設備驅(qū)動都在內(nèi)核,即系統(tǒng)空間實現(xiàn),實現(xiàn)方式有兩種,一種是將有關的設備驅(qū)動程序和數(shù)據(jù)結(jié)構(gòu)靜態(tài)地連接在內(nèi)核映像中;另一種是將具體的設備驅(qū)動程序和數(shù)據(jù)結(jié)構(gòu)獨立加以編譯,成為可安裝的模塊,需要時由應用程序通過系統(tǒng)調(diào)用動態(tài)地予以安裝或拆卸。設備驅(qū)動的實現(xiàn)方法也有兩種,一種是輪詢(polling)方式,另一種是中斷(inter-rupt)方式,輪詢方式對設備的操作完全由CPU掌握,外部設備則完全處于被動狀態(tài)。中斷方式是由外部設備主動提出申請,CPU響應申請后對外部設備進行處理,是現(xiàn)在常用的設備驅(qū)動方式。Linux的設備驅(qū)動具有兩個顯著的特點,其一是把所有的設備視為一種設備文件,每個設備都呈現(xiàn)于文件系統(tǒng)的/dev目錄下,設備驅(qū)動與文件操作具有相同的界面和語義,并通過同一組系統(tǒng)調(diào)用進行操作;另一個顯著特點是Linux的設備驅(qū)動有著分明的層次和結(jié)構(gòu)。

Linux內(nèi)核的新近版本為設備入口提供了一種特殊的文件系統(tǒng),即設備文件系統(tǒng) devfs(device file system)。新的devfs機制的優(yōu)點在于:①各種設備驅(qū)動模塊動態(tài)地向系統(tǒng)登記,設備初始化時在/dev目錄下創(chuàng)建設備入口點,移除設備時將其刪除。②設備驅(qū)動程序可以指定設備名、所有者和權限位。③不需要為設備驅(qū)動程序分配主設備號以及次設備號。④當裝載和卸載模塊時,不再需要運行腳本來創(chuàng)建設備文件,驅(qū)動程序自主地管理其設備文件。采用devfs機制的設備驅(qū)動程序調(diào)用下面的函數(shù)來處理設備的創(chuàng)建和刪除工作。

devf s_hander_t devf s_mk_dir ( devf s_ han2 der_t dir ,const char 3 name ,void 3 info)

devf s_hander_t devf s_register ( devf s_ han2 der_t dir ,const char 3 name ,unsigned int flags , unsigned int major ,unsigned int minor ,umode_t mode ,void 3 op s ,void 3 info)

void devf s_unregister (devf s_hander_t de)

在 Linux操作系統(tǒng)編寫設備驅(qū)動程序時有幾個固定的功能模塊:向Linux內(nèi)核注冊該設備時的初始化設備驅(qū)動程序模塊;用于系統(tǒng)卸載模塊時刪除設備驅(qū)動程序的模塊;提供用戶使用該設備驅(qū)動程序的文件操作接口模塊。對于各類具體設備編寫驅(qū)動程序時還應具有對該設備進行操作的應用函數(shù)。下面就以ADS7843 驅(qū)動為例分析以上幾個功能模塊。


上一頁 1 2 3 4 下一頁

評論


相關推薦

技術專區(qū)

關閉