



下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、 基于Windows CE的SPI接口驅(qū)動(dòng)程序設(shè)計(jì)摘要:實(shí)現(xiàn)了一種全集成可變帶寬中頻寬帶低通濾波器,討論分析了跨導(dǎo)放大器-電容(OTAC)連續(xù)時(shí)間型濾波器的結(jié)構(gòu)、設(shè)計(jì)和具體實(shí)現(xiàn),使用外部可編程電路對(duì)所設(shè)計(jì)濾波器帶寬進(jìn)行控制,并利用ADS軟件進(jìn)行電路設(shè)計(jì)和仿真驗(yàn)證。仿真結(jié)果表明,該濾波器帶寬的可調(diào)范圍為126 MHz,阻帶抑制率大于35 dB,帶內(nèi)波紋小于05 dB,采用18 V電源,TSMC 018m CMOS工藝庫(kù)仿真,功耗小于21 mW,頻響曲線接近理想狀態(tài)。關(guān)鍵詞:Butte引 言Windows CE為支持多線程、多任務(wù)、搶占式的嵌入式操作系
2、統(tǒng)。隨著Windows CE 60的發(fā)布,其內(nèi)核性能的明顯提升和源代碼開(kāi)放,將促使其在消費(fèi)電子、工業(yè)控制、移動(dòng)通信等領(lǐng)域得到廣泛的應(yīng)用。通常Platform Builder中給出了支持多種CPU常用設(shè)備驅(qū)動(dòng)程序,如LCD驅(qū)動(dòng)、鼠標(biāo)驅(qū)動(dòng)、USB驅(qū)動(dòng)、串口驅(qū)動(dòng)等;但有時(shí)由于平臺(tái)采用了其他特定的硬件設(shè)備,其驅(qū)動(dòng)程序在Platform Builder并沒(méi)有給出,這時(shí)就需要用戶針對(duì)實(shí)際的硬件自行開(kāi)發(fā),以滿足個(gè)性化的需求。本文所涉及的SPI接口驅(qū)動(dòng)就屬于此類(lèi)。 1 SPI總線及S3C2440芯片介紹串行外圍設(shè)備接口SPI(Serial Peripheral Interface)總線是
3、Freescale公司推出的一種三線同步接口。接口采用同步串行34線方式進(jìn)行通信,即1條時(shí)鐘線SCK、1條數(shù)據(jù)輸入線MOSI、1條數(shù)據(jù)輸出線MISO,另外還有1條從選線NSS(可選),用于CPU與各種外圍器件進(jìn)行全雙工、同步串行通信。SPI接口在眾多的移動(dòng)存儲(chǔ)和高速通信芯片上得到廣泛應(yīng)用。根據(jù)時(shí)鐘極性和時(shí)鐘相位的不同,MOSI和MISO上的數(shù)據(jù)支持4種數(shù)據(jù)傳輸格式。SPI的主要特點(diǎn)為:可以同時(shí)發(fā)出和接收串行數(shù)據(jù),可以當(dāng)作主機(jī)或從機(jī)工作,提供頻率可編程時(shí)鐘,發(fā)送結(jié)束中斷標(biāo)志,寫(xiě)沖突保護(hù)和總線競(jìng)爭(zhēng)保護(hù)等。S3C2440是一款基于ARM920T的1632位RISC微處理器,主頻可達(dá)400 MHz。該
4、芯片性?xún)r(jià)比高,功耗低,含有豐富的片內(nèi)外設(shè),主要用于手持設(shè)備和移動(dòng)終端。S3C2440中與SPI相關(guān)的寄存器有: 2 Windows CE的驅(qū)動(dòng)程序 21 Windows CE下驅(qū)動(dòng)程序的基本概念和分類(lèi)驅(qū)動(dòng)程序是一個(gè)抽象物理設(shè)備或者虛擬設(shè)備的功能軟件,驅(qū)動(dòng)程序管理這些設(shè)備的操作并將設(shè)備的功能導(dǎo)出給操作系統(tǒng)和應(yīng)用程序。根據(jù)驅(qū)動(dòng)程序?qū)С鼋涌诘牟煌?,windows CE中驅(qū)動(dòng)可以分為本機(jī)設(shè)備驅(qū)動(dòng)程序(native device driver)和流式驅(qū)動(dòng)程序(streams device driver)。本機(jī)設(shè)備驅(qū)動(dòng)適于集成到基于Windows C
5、E平臺(tái)的設(shè)備。這些設(shè)備驅(qū)動(dòng)程序是一些硬件所必需的,是由原始設(shè)備制造商創(chuàng)建的,用來(lái)驅(qū)動(dòng)如鍵盤(pán)、LED、觸摸屏等。本機(jī)驅(qū)動(dòng)在編譯時(shí)被靜態(tài)鏈接到GWES,系統(tǒng)運(yùn)行時(shí)由GWES加載。流式驅(qū)動(dòng)程序也稱(chēng)"可安裝驅(qū)動(dòng)程序",是由設(shè)備管理器(deviceexe)動(dòng)態(tài)加載用戶模式的DLL。對(duì)流式驅(qū)動(dòng)程序來(lái)說(shuō),不管需要控制的設(shè)備是什么類(lèi)型,所有流式驅(qū)動(dòng)都使用相同的接口并導(dǎo)出一組相同的函數(shù)-流接口函數(shù)。流式驅(qū)動(dòng)適用任何在邏輯上可以被認(rèn)為是一個(gè)數(shù)據(jù)源或者數(shù)據(jù)存儲(chǔ)的IO設(shè)備。 22流式驅(qū)動(dòng)程序工作原理在Window CES中,流式驅(qū)動(dòng)程序負(fù)責(zé)將設(shè)備抽象成一個(gè)文件,應(yīng)用程序便能夠
6、使用系統(tǒng)提供的API(ReadFile、writeFile、IOControl等)對(duì)其進(jìn)行讀寫(xiě)。應(yīng)用程序使用文件API訪問(wèn)設(shè)備時(shí),請(qǐng)求經(jīng)過(guò)文件系統(tǒng)(Filesysexe)過(guò)濾被送到deviceexe;deviceexe根據(jù)請(qǐng)求調(diào)相關(guān)的流式驅(qū)動(dòng)程序接口,從而完成與硬件的交互。 23 設(shè)備驅(qū)動(dòng)的中斷處理在windows CE系統(tǒng)中,當(dāng)中斷發(fā)生時(shí),OEM抽象層(OEM Abstraction Layer,OAL)把物理中斷信號(hào)映射成OEM定義的邏輯中斷供操作系統(tǒng)和驅(qū)動(dòng)程序調(diào)用。為了滿足實(shí)時(shí)性要求,系統(tǒng)將中斷處理過(guò)程分為2個(gè)階段,即處于內(nèi)核模式的中斷服務(wù)例程(Interrupt
7、Service Routine,ISR)和處于用戶模式的中斷服務(wù)線程(Interrupt Service Thread,IST)。ISR主要負(fù)責(zé)將物理中斷映射為邏輯中斷,然后由操作系統(tǒng)根據(jù)邏輯中斷激發(fā)所關(guān)聯(lián)時(shí)間對(duì)象的內(nèi)核,使等待該事件內(nèi)核對(duì)象的線程IST開(kāi)始執(zhí)行中斷處理程序。具體中斷處理過(guò)程如圖1所示。中斷發(fā)生后,信號(hào)發(fā)往異常處理器,并且中斷支持處理器調(diào)用OAL函數(shù)OEMInterruptDisable關(guān)閉來(lái)自該硬件的中斷。ISR被內(nèi)核調(diào)用并返回結(jié)果,且通過(guò)內(nèi)核設(shè)置Event事件來(lái)觸發(fā)IST。IST被喚醒后調(diào)用各種IO函數(shù)完成中斷處理并返回InterruptDone通知內(nèi)核。內(nèi)核調(diào)用OEMIn
8、terruptDone通知硬件重新開(kāi)啟中斷。 3 SPI總線驅(qū)動(dòng)設(shè)計(jì)綜上所述,SPI總線驅(qū)動(dòng)分為2部分,即處于內(nèi)核模式OAL層將物理中斷映射成邏輯中斷的ISR,以及處于用戶模式流式驅(qū)動(dòng)。其中包括執(zhí)行中斷處理線程IST。 31 初始化中斷以及ISR實(shí)現(xiàn)SPI通信是通過(guò)讀寫(xiě)SPI寄存器來(lái)完成的,通過(guò)讀寫(xiě)上述6個(gè)SPI寄存器中的狀態(tài)字可以檢測(cè)和控制SPI總線的行為。在OAL層中需要完成的工作如下:在中斷頭文件oalintrh中添加SPI的中斷宏定義,供ISR返回調(diào)用。#(define SYSINTR_SPIO (SYSINTR_FIRMWARE+22) 注意:定義時(shí)要使中斷號(hào)滿足該文件中MapIrq2SysIntr中所要求的范圍。WinCE4.2版本支持最大中斷數(shù)為32,WinCE5.0版支持最大中斷數(shù)為64。 在OAL實(shí)現(xiàn)文件cfw.c中,添加中斷初始化和禁止中斷實(shí)現(xiàn)代碼。 在中斷處理實(shí)現(xiàn)文件armint.c的OEMInterruptHandler函數(shù)中添加ISR程序代碼,返回邏輯中斷號(hào)。代碼如下: 3.2 流式驅(qū)動(dòng)的實(shí)現(xiàn) 驅(qū)動(dòng)被加載后需要完成設(shè)備的初始化
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 兒童心理發(fā)展的關(guān)鍵階段與護(hù)理
- 詳盡工作經(jīng)歷及職位證明書(shū)(5篇)
- 動(dòng)物們的森林生活童話類(lèi)作文11篇
- 夜空中的星星秘密抒情作文(8篇)
- 數(shù)字化轉(zhuǎn)型助力公路貨運(yùn)行業(yè)效率革命研究報(bào)告
- 大型物流配送中心建設(shè)對(duì)城市能源消耗風(fēng)險(xiǎn)分析報(bào)告
- 2025年可持續(xù)發(fā)展目標(biāo)(SDGs)在虛擬數(shù)字人技術(shù)中的應(yīng)用與發(fā)展報(bào)告
- 共享出行平臺(tái)信用積分體系設(shè)計(jì)與應(yīng)用報(bào)告
- 2025年海上風(fēng)力發(fā)電場(chǎng)運(yùn)維管理與技術(shù)創(chuàng)新策略深度報(bào)告
- 2025年智慧公交系統(tǒng)實(shí)施方案評(píng)估報(bào)告:智能調(diào)度與運(yùn)營(yíng)優(yōu)化分析
- 炸雞店的產(chǎn)品創(chuàng)新與口味調(diào)研
- 風(fēng)機(jī)吊裝安全培訓(xùn)
- 陜西省銅川市2025年八下英語(yǔ)期末監(jiān)測(cè)試題含答案
- 社區(qū)工作者綜合能力考試基礎(chǔ)知識(shí)試題及答案
- 山西焦煤集團(tuán)所屬煤炭子公司招聘筆試題庫(kù)2025
- 墊付醫(yī)療費(fèi)協(xié)議書(shū)
- 2025年福建省廈門(mén)市中考物理模擬試卷
- 2024年陜西省普通高中學(xué)業(yè)水平合格性考試語(yǔ)文試題(原卷版+解析版)
- (高清版)DG∕TJ 08-9-2023 建筑抗震設(shè)計(jì)標(biāo)準(zhǔn)
- DB44-T 2605-2025 生活垃圾焚燒發(fā)電設(shè)施能源消耗計(jì)算與限額
- 代謝相關(guān)脂肪性肝病防治指南2024年版解讀
評(píng)論
0/150
提交評(píng)論