當(dāng)前位置:首頁 > 電源 > 數(shù)字電源
[導(dǎo)讀]摘要:簡要介紹了Blackfin561的DMA功能和BMP文件的格式,敘述了在基于Blackfin561的嵌入式操作系統(tǒng)uClinux下并行外部接口(PPI)驅(qū)動程序的框架,以及驅(qū)動程序中各個函數(shù)的具體功能與實現(xiàn)方式。完成了虹膜圖像數(shù)據(jù)的

摘要:簡要介紹了Blackfin561的DMA功能和BMP文件的格式,敘述了在基于Blackfin561的嵌入式操作系統(tǒng)uClinux下并行外部接口(PPI)驅(qū)動程序的框架,以及驅(qū)動程序中各個函數(shù)的具體功能與實現(xiàn)方式。完成了虹膜圖像數(shù)據(jù)的采集,并對圖像數(shù)據(jù)進行了預(yù)處理,提取其中所有亮度信息,生成BMP圖像文件。同時指出了調(diào)試過程中常遇的問題以及解決方法。關(guān)鍵詞:嵌入式系統(tǒng);設(shè)備驅(qū)動程序;虹膜圖像采集;DMA;PPI

0 引言

隨著計算機和網(wǎng)絡(luò)技術(shù)的發(fā)展,信息安全顯示出前所未有的重要性,而身份識別作為保證信息安全的必要前提,也越來越受到重視。虹膜識別技術(shù)是基于眼睛虹膜的生物識別技術(shù)。虹膜的終生不變性以及信息提取的非接觸性等特性,使其成為各項生物識別技術(shù)中最突出的一項。本文論述了在基于Blackfin561的嵌入式操作系統(tǒng)uClinux的虹膜圖像采集以及預(yù)處理。為后期在嵌入式平臺上進行虹膜圖像運算提供了圖像來源。

1 Blackfin561中的DMA

Blackfin系列DSP產(chǎn)品是ADI公司的基于微信號體系結(jié)構(gòu)的DSP,適用于各種視頻、音頻、通信領(lǐng)域。ADSP-BF561有多個獨立的DMA控制器,能夠以最小的DSP內(nèi)核開銷完成數(shù)據(jù)自動傳輸。DMA傳輸可以發(fā)生在ADSP-BF561的內(nèi)部存儲器和任一有DMA能力的外設(shè)之間。此外,DMA傳輸也可以在任一有DMA能力的外設(shè)和已連接到外部存儲器接口的外部設(shè)備之間完成(包括SDRAM控制器、異步存儲器控制器)。有DMA傳輸能力的外設(shè)包括SPORT、SPI端口、UART和PPI端口。每個獨立的有DMA能力的外設(shè)至少有一個專用DMA通道。BF561內(nèi)部專門為適應(yīng)視頻數(shù)據(jù)處理而增加了二維DMA。

2 PPI接口驅(qū)動的具體實現(xiàn)

uClinux是針對微控制領(lǐng)域而設(shè)計的Linux系統(tǒng),面向沒有MMU(Memory Management Unit)的硬件平臺。它是Linux的一個變種,一方面它繼承了Linux的大部分優(yōu)點,例如穩(wěn)定性,強大的網(wǎng)絡(luò)功能;另一方面其內(nèi)核相當(dāng)精簡, 內(nèi)核體積小于512KB, 內(nèi)核加文件系統(tǒng)小于900KB。uClinux同標(biāo)準(zhǔn)Linux主要的區(qū)別在于兩者的內(nèi)存管理機制和進程調(diào)度管理機制,另外它采用了romfs文件系統(tǒng),并對Linux上的C語言庫glibc做了簡化。uClinux完全符合GNU/GPL公約,完全開放源代碼,因此在嵌入式領(lǐng)域得到廣泛應(yīng)用。

為管理各種外圍硬件設(shè)備,uClinux系統(tǒng)對其采取面向?qū)ο蟮姆庋b機制。uClinux將所有的外圍設(shè)備看成是一類特殊文件,稱為“設(shè)備文件”,它抽象了對硬件的處理,用戶進程只需通過標(biāo)準(zhǔn)的系統(tǒng)調(diào)用如open(),read(),write(),close()而無需了解設(shè)備在硬件層上實現(xiàn)的細節(jié)即可實現(xiàn)對設(shè)備的訪問控制。驅(qū)動程序則負(fù)責(zé)這些系統(tǒng)調(diào)用的具體實現(xiàn)。

針對具體應(yīng)用,在驅(qū)動程序中實現(xiàn)了模塊注冊注銷函數(shù),open,release接口函數(shù)和read接口函數(shù)(如圖1所示)。驅(qū)動程序采用了中斷方式,對PPI和DMA進行了配置,采用BF561提供的二維DMA功能。詳細介紹如下:

(1)模塊初始化函數(shù)init_module()。該函數(shù)是每個內(nèi)核模塊加載的時候首先調(diào)用的一個默認(rèn)函數(shù)。程序中使用了module_init()宏來顯式命名模塊的注冊函數(shù)為 ppi_init(),在該函數(shù)中完成了設(shè)備’ppi’的注冊,當(dāng)模塊加載完畢之后,內(nèi)核即知曉該設(shè)備的存在。

(2)模塊卸載函數(shù)cleanup_module(),該函數(shù)與init_module()做相反的工作,在內(nèi)核中取消設(shè)備的登記。與模塊注冊類似,程序中使用module_exit()宏來顯式命名模塊的注銷函數(shù)為 ppi_exit()該函數(shù)在模塊卸載的時候自動調(diào)用。

(3)設(shè)備驅(qū)動程序的file_operations結(jié)構(gòu)。由于所使用的PPI接口只用來做數(shù)據(jù)采集,因此file_operation結(jié)構(gòu)定義如下:

static struct file_operations ppi_fops = {

owner:     THIS_MODULE,

read:        ppi_read,

open:       ppi_open,

release:    ppi_release,

};

(4)open,release接口函數(shù)。在這兩個函數(shù)中分別使用了MOD_INC_USE_COUNT和MOD_DEC_USE_COUNT宏,被操作系統(tǒng)內(nèi)核用來記錄當(dāng)前訪問設(shè)備文件的進程數(shù)。由于要使用中斷方式,所以在open和release中要分別實現(xiàn)中斷的申請和釋放。設(shè)備驅(qū)動程序通過調(diào)用request_irq()函數(shù)申請中斷,將一個硬件處理函數(shù)掛到相應(yīng)的處理隊列中,通過調(diào)用free_irq()函數(shù)釋放中斷。在open函數(shù)中初始化了PPI和DMA的部分相關(guān)寄存器。擇要描述如下:

*pDMA1_0_Y_COUNT = 625; 二維DMA的外層循環(huán)計數(shù)寄存器,用于保存外層循環(huán)的數(shù)目。

*pDMA1_0_X_COUNT = 1728/4; 二維DMA的內(nèi)層循環(huán)計數(shù)寄存器,用于保存內(nèi)層循環(huán)的數(shù)目。

*pDMA1_0_X_MODIFY= *pDMA1_0_Y_MODIFY = 4; 內(nèi)層外層循環(huán)地址增量寄存器。為有效利用DMA帶寬,設(shè)置了PPI使之能處理32位DMA,且數(shù)據(jù)緩沖區(qū)是連續(xù)的,此處兩個增量寄存器都被設(shè)置為4。

*pPPI0_FRAME = 625; 在PPI被設(shè)置成ITU-656輸入模式下,該寄存器用于保存每幀的數(shù)據(jù)線路數(shù)。

(5)read接口函數(shù)。在該函數(shù)中初始化PPI控制寄存器和DMA配置寄存器及DMA地址寄存器。

*pDMA1_0_START_ADDR = buf;

*pDMA1_0_CONFIG = 0x109B;

*pPPI0_CONTROL = 0x01C5;

設(shè)置好寄存器后,使進程進入睡眠隊列,等待DMA結(jié)束產(chǎn)生的中斷將其喚醒。

數(shù)據(jù)緩沖區(qū)在用戶區(qū)定義,因一幀數(shù)據(jù)大小確定,所以在用戶應(yīng)用程序中定義的數(shù)據(jù)存儲區(qū)大小指定為625*1728B。通過調(diào)用函數(shù)時傳遞指針的方式通知數(shù)據(jù)緩沖區(qū)的位置。在該函數(shù)中不再使用copy_to_user()函數(shù),此方式節(jié)省了內(nèi)存空間,對于嵌入式應(yīng)用來說意義重大。事實上每次DMA開始傳送的頭4個字節(jié)總是被忽略掉的,這4個字節(jié)是第一個活動視頻開始(EAV)代碼。即需要的一幀圖像數(shù)據(jù)比實際傳送的要少4個字節(jié),但是為了數(shù)據(jù)處理的方便,仍將數(shù)據(jù)緩存區(qū)定義為完整一幀圖像的大小,這樣數(shù)據(jù)緩存區(qū)的最后4個字節(jié)是下一幀圖像的EAV代碼。到此,虹膜圖像采集的驅(qū)動程序基本完成,可以看出,驅(qū)動程序與應(yīng)用程序聯(lián)系緊密,這也反應(yīng)了嵌入式系統(tǒng)的一個特點,面向應(yīng)用,專用性極強。

[!--empirenews.page--]

3 圖像數(shù)據(jù)的預(yù)處理

在用戶程序中,定義二維數(shù)組buf[625][1728]作為圖像數(shù)據(jù)的數(shù)據(jù)緩沖區(qū),然后通過標(biāo)準(zhǔn)系統(tǒng)調(diào)用獲取一幀虹膜視頻圖像數(shù)據(jù)。虹膜視頻圖像數(shù)據(jù)是以ITU-656模式輸入的,一幀圖像分為奇場和偶場,且原始數(shù)據(jù)中還有顏色信息、消隱信息和控制字等,因此要獲得一幅虹膜圖像還需對原始數(shù)據(jù)進行預(yù)處理。提取原始數(shù)據(jù)中的所有亮度信息,并把兩個場的數(shù)據(jù)有規(guī)則的合并到一起,然后按照BMP的圖像數(shù)據(jù)存放順序重新排列,添加相應(yīng)的文件頭生成灰度BMP圖像文件。

BMP文件是Windows保存圖像的一種通用位圖文件格式,自帶顏色信息,調(diào)色板管理非常容易,在數(shù)字圖像處理方面占有重要的地位。

BMP文件大體上分成如下4個部分,位圖文件頭+位圖信息頭+調(diào)色板+圖像數(shù)據(jù)。

(1)第一部分為位圖文件頭,長度固定,為l4個字節(jié)。

(2)第二部分為位圖信息頭,長度固定,為40個字節(jié)。

(3)第三部分為調(diào)色板。需要注意的是真彩色圖不需要調(diào)色板,它們的位圖信息頭后面直接是圖像數(shù)據(jù)。而其他位圖,包括本文所討論的8位位圖,都需要調(diào)色板。

(4)第四部分就是實際的圖像數(shù)據(jù)。

在實際調(diào)試過程中還要注意字節(jié)對齊問題。比如位圖文件頭長度固定為l4個字節(jié),但若不注意字節(jié)對齊,定義后的結(jié)構(gòu)體實際大小為16個字節(jié),因此定義位圖文件頭時用__attribute__((packed)),使該結(jié)構(gòu)體長度為14個字節(jié)。

4 結(jié)論

本文簡略概述了Blackfin561處理器的DMA相關(guān)寄存器,敘述了在uClinux下PPI接口的驅(qū)動程序?qū)崿F(xiàn)過程及功能,對BMP文件格式進行了簡要介紹。所有代碼已經(jīng)在BF561的嵌入式uClinux平臺上調(diào)試通過,符合設(shè)計要求。

本文作者創(chuàng)新點:完成了嵌入式系統(tǒng)上的虹膜圖像采集及預(yù)處理。在目前國內(nèi)虹膜識別產(chǎn)業(yè)仍處于起步階段的情況下,本文就虹膜識別技術(shù)的實用化做了重要研究,具有重要的實用價值。

下圖是實驗中拍到的兩幅圖片

 

參考文獻

[1]楊瑞亞,肖璋嵌入式uClinux內(nèi)核啟動過程分析與設(shè)計[J].中文核心期刊《微計算機信息》(嵌入式與SOC )2005 年第21 卷第8-2 期32-33

[2]ADSP-BF561 Blackfin Hardware Preliminar.pdf [EB/OL]. /upload/eWebUpload/200705/20070510112235534.pdf

Analog Devices Ine.02/2005.

[3]陳峰.Blackfin系列DSP原理與系統(tǒng)設(shè)計[M].北京:電子工業(yè)出版社,2004. 61-72

[4]JONATHAN CORBET,ALESSANDRO RUBINI,GREG KROAH-HARTMAN.《LINUX DEVICE DRIVERS》[M].東南大學(xué)出版社,2005.1-70,258-287

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉