摘要:簡要介紹了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