導航:首頁 > 源碼編譯 > xilinx交叉編譯環境源碼

xilinx交叉編譯環境源碼

發布時間:2024-09-10 00:57:39

Ⅰ 嵌入式bootloader和內核在flash上分布問題

這篇文章指引了我,希望它也能指引你

近些年來,嵌入式系統的發展在國內可謂如火如荼,很多公司都急需嵌入式系統方面的開發人員。然而,在高校中,嵌入式系統的教學卻較為滯後,很多高年級的本科生和剛入學的研究生都苦於不知從何學起。在本文中,筆者將根據自己的嵌入式系統開發和教學經驗,簡要介紹嵌入式系統的學習方法,力求能幫助初學者找到一條入門之路。
什麼是嵌入式系統?
學習嵌入式系統,首先應該明確什麼是嵌入式系統,否則費力去學,卻不知所學為何物,豈不惘然?嵌入式系統的定義很多,這也是困擾嵌入式系統學習的一個因素。筆者根據自己開發和教學過程中的理解,以及對各種嵌入式系統的應用進行總結,提出了嵌入式系統的簡單定義:嵌入式系統是嵌入式計算機系統的簡稱,這個定義突出嵌入式計算機系統和普通計算機系統的共性。下表列出了嵌入式系統的一些典型的
應用:
智能機器人(S D R 4,火星登陸車)
娛樂和消費電子(Gameboy Advance,Sony PSP)
網路通信產品(Smartphone)
軍用設備(軍用PDA )
汽車(車載導航,自動駕駛,娛樂系統)
智能儀器(虛擬儀器)
安全防護(防火,防盜)
環境保護(探空氣球)
銀行和商業消費(ATM)
以火星登陸車為例來分析一下嵌入式系統的定義。火星登陸車雖然聽起來感覺在技術上有些高不可測,但是本質就是嵌入式計算機系統的應用,其核心就是一個計算機系統,而這個計算機系統的組成同傳統的計算機系統在本質上沒有什麼差別。兩者的顯著不同之處就在於,用於火星登陸車的計算機系統被安裝到了火星登陸車上。當然,一個計算機系統能夠被安裝在火星登陸車上,是需要進行很多特殊設計的。但是從本質上講,嵌入式系統的核心概念還在計算機系統。嵌入式系統學習的重點也在計算機系統上。一方面,學習者需要牢固掌握計
算機系統本身的概念,更重要的是學習嵌入系統的開發過程同傳統計算機系統開發過程的差別。這里需要指出的是,很多學習者本來就沒有從事過完整計算機系統的開發,高校的教學是以程序設計為中心的,計算機系統的構成,操作系統的原理,編程語言等課程都是為了能夠讓學生更好的使用計算機系統進行程序設計,在現有的計算平台上來設計實現各種應用,學生一般沒有機會學習一個完整的計算機系統是如何構建,並親身參與到構建的每一個過程。而對於嵌入式系統而言,從事平台開發的人就是要親自去開發出一個完整的計算機系統,這個過程包括
l 需求分析
2 硬體設計
3 驅動程序
4 Bootloader & BSP (板級支持包)
5 操作系統的移植
6 應用程序的開發
7 性能檢查
嵌入式系統教學的目的就是教會學生如何根據需求去建立滿足某種特殊行業需求的嵌入式計算機系統。讓學生學會如何構件硬體平台,進行硬體設計,選擇能夠滿足應用要求的最佳的嵌入式操作系統,並完成Bootloader,BSP 和驅動程序的編寫,移植,調試等過程。為了滿足行業需求,最終要在所建立的系統上編寫調試相應的應用程序,並進行性能的測試和檢查。
你是誰,你需要學習哪些東西?
如果你的工作只是需要在PC 機上編寫一個圖片瀏覽程序,那麼你就沒有必要去了解當系統收到一個ARP 請求包後應該如何回應。同樣的道理,嵌入式系統的學習也是有很多方面的。就嵌入式系統的設計和實現而言,基本上需要四種不同的工作:系統設計工作,硬體設計工作,驅動程序和操作系統移植工作和應用程序設計開發工作。
系統設計工作
在系統的設計階段,系統分析師將根據需求確定系統的硬體的基本構成,根據系統的需求選擇使用那種處理器,使用哪種操作系統,使用那些軟體開發工具。系統分析師往往是較為完整的參與過嵌入式系統設計的全過程,對於系統應用的行業較為了解,對於嵌入式系統
本身的開發流程十分清楚的人。
硬體設計工作
系統硬體設計人員需要根據系統分析師的設計結果,進行硬體原理圖的設計。通常需要硬體設計人員熟悉嵌入式系統的硬體構成。硬體設計人員需要了解常用的嵌入式系統處理器,存儲器(Flash,SDRAM),乙太網MAC晶元,音頻/ 視頻編解碼晶元,電源管理晶元,匯流排介面電路 (USB, PCI),液晶顯示模塊,可編程邏輯器件(FPGA/CPLD),無線網路通信模塊(Bluetooth, WLAN,GPRS)等硬體電路構成元素的基本工作原理,連接使用方法,使用注意事項,基本調試方法等內容。在網路上能找到很多公司的評估板的原理圖,對於這些原理圖要仔細研究,摸清處理器同存儲器,網卡,液晶模塊等器件的連接方法和原因。通過對這些電路的研究,能夠較快地了解整個嵌入式系統的構成,這些電路同實際產品中的電路雖有一定差別的,特別是對於手持設備,但這些差別不影響初學者學習嵌入式系統的硬體設計基本構成。
以上這些知識,往往需要較長時間的學習和積累,需要親自參與實踐的機會。對於剛剛接觸嵌入式系統硬體開發的學生來講,一般不可能全部了解這些知識,但也不會是通通一無所知。筆者結合自己開發和教學的經驗認為:首先應該選定一款主流且較為簡單的嵌入式系
統處理器,比如基於ARM7TDMI 內核的AT91M40800,S3C44B0 等嵌入式系統處理器,學習32 位RISC 處理器的編程模型,指令集。高校教學中,單片計算機課程一般以8051系列單片為核心講解,由於現代32位處理器的結構和開發方式同8 位單片機有著較大的差別,學習者還是需要花一點力氣來研究以下32 位處理器的。以ARM處理器為例,學習者就需要理解處理器的多種工作模式,備份寄存器,RISC 指令集的特點,MMU 和虛擬地址,中斷處理過程等內容。在學習指令集的過程中,最好能夠每學習幾條指令,就使用這幾條指令在模擬器上實驗以下,觀察處理器執行的結果。這個過程一方面是學習者對於指令本身的學習能夠取得一個比較好的效果,另外也是對開發工具本身的一種學習。接著,就可以開始學習片上資源的使用和配置方法。這時就需要一個方便使用的開發板,學習者能夠通過JTAG 模擬器將開發板同調試PC 機相連,進行程序的下載,調試。特別是要仔細研究系統的初始化過程和中斷處理的過程。在開發過程中如果遇到問題,應自己分析問題產生的原因,通過分析縮小問題可能產生的范圍,最終找到問題的所在。最重要的就是要保持一種解決問題的信心,面對困難如何處理,往往能夠決定最終系統是否能夠調試成功。然後,學習者可以開始仔細學習處理器同存儲器的連接,存儲空間的配置,各種外擴器件,如網卡,AC97音效卡的工作原理和使用方法。嵌入式系統硬體設計中往往需要使用可編程器件,學習者還需要一定的時間來學習使用常用的可編程器件(C P L D / F P G A ),常用的有Xilinx和Altera公司的產品。進行系統硬體原理圖設計,就需要使用原理圖設計的E D A 工具,常用的E D A 原理圖設計工具主要包括Cadence公司的Capture,Protel公司的Protel99 SE等。接下來就可以參照評估板的電路圖,根據系統的設計要求,開始進行原理圖的繪制了。在原理圖繪制過程中,一定要搞清評估板電路連接的原因,對於一時沒有搞清楚的問題切不可矇混過關。例如,有些處理器的地址線是以位元組位單位的,而另一些處理器的地址線則是以兩個位元組為單位的,當連接16 位的存儲器的時候,切不可想當然的把處理器的A 0 直接連接到存儲器的A 0 上面。另外,學生還應具有一定的P C B 板圖繪制能力,因為在現階段,很多公司還不能完全把原理圖的設計工作和PCB 的繪制工作分開,往往要求硬體設計人員既能進
行原理圖設計又能進行板圖設計。即使是PCB設計和原理圖設計分開的公司,也需要原理圖設計者能為PCB 的設計者對於不同的信號提出布板要求。
驅動程序和操作系統移植工作
現代嵌入式系統的開發同傳統8 位單片機系統的開發相比,一個顯著的區別就是嵌入式操作系統的廣泛使用。在拿到焊接完畢的電路板,並進行基本的測試後,就要進行驅動程序和操作系統的移植工作了。首先要進行的Bootloader的編寫和移植工作。Bootloaer相當於PC系統的BIOS。對於有些嵌入式操作系統,如uc/OSII 沒有bootloader同樣可以開發調試。但是對於Windows CE和嵌入式linux系統而言Bootloader就是必須的了。本文以
Windows CE 為例,做一個簡要的說明。
Windows CE 系統的移植工作主要就是BSP(板級支持包)的開發過程。B S P 將具體的硬體差異同操作系統的核心隔離開來,主要由Bootloaer ,OAL (OEMAbstraction
Layer)和設備驅動程序三部分組成。WindowsCE系統中Bootloader叫做Eboot。Eboot被寫入系統的引導Flash。系統啟動時運行 Eboot,完成通過網卡將調試PC 機中Windows CE 操作系統映像下載到目標系統的S D R A M 中並開始執行的功能。對於一個系統移植人員,首先需要閱讀文檔,了解Windows CE系統Bootloader和BSP的基本概念和開發過
程。(呵,還要做這工作啊,我還沒想到(初學^_^))Windows CE的開發系統Platform Builder提供了詳細的文檔和常式,開發人員需要仔細的閱讀文檔和常式。搞清楚各個函數之間的調用關系。在開發過程中的一個重要的步驟就是打通串口,使得目標板能夠通過PC 機串口向調試PC 機發送數據。由於A R M 系統的模擬器比較昂貴,而且操作系統的調試往往不使用JTAG 調試器進行單步調試。所以能從串口觀察程序的執行過程和結果對於調試就顯得十分重要了。串口打通之後一個比較棘手的問題就是網卡晶元的調試。剛剛接觸嵌入式系統開發的人往往沒有直接在寄存器級上使用網卡晶元的經驗,而網卡晶元的說明一般都較為簡短,這就要求開發者學習一些乙太網的基礎知識,對乙太網的 MAC 層有一個基本的認識。另外,各種網路調試(抓包)工具的使用也能大大降低系統調試的難度。系統的O A L 需要根據具體硬體的不同做出相應的修改,這個部分可次參照文檔進行,在調試過程中根據串口的信息分析出錯的地方。要充分發揮跨文件字元串搜索工具的功能,在浩如煙海的源文件中找到出錯的位置。當然,隨著開發者對系統文件目錄結構的熟悉和了解,錯誤定位的速度會不斷加快。Windows CE 的驅動程序相對而言是比較好寫的。程序結構較為簡單,學習者可參照 MSDN Home > MSDN Library >Mobile and Embedded Development > Embedded Operating
System Development > Columns SPOT the Geek and WindowsCE Drivers 這篇文章。
應用程序的開發
嵌入式系統的應用程序開發同在PC 機上開發應用程序的區別不是很大。對於W i n d o w s C E 系統而言,Microsoft已經提供了較為完善的開發工具。特別是.NET Compact Framework 的使用,使得基於Windows CE.NET Compact Framework的應用程序有了跨平台性。開發人員可以使用Windows 的C# 語言直接在PC 上進行CE .NET應用程序的開發和模擬調試,也可將目標系統同PC 機相連,進行聯機調試。現在有很多系統支持J2ME(JAVA 的嵌入式系統版本) ,這使得JAVA 在嵌入式系統應用開發中佔有較大的
優勢。另外,作為專業的嵌入式系統軟體開發人員,還需要充分了解面向對象技術和設計模式等方面的知識,當然作為初學者可以先不深入研究這方面的內容。
常用嵌入式系統處理器和操作系統
處理器
常用嵌入式系統處理器主要包括A R M 處理器,Power PC 處理器,基於MIPS 內核的嵌入式處理器,軟核處理器(如Alter 的Nios和Xilinx的MicroBlaze等)和D S P(數字信號處理器)等。
A R M 處理器的主要特點是具有較高的性能功耗比。A R M 處理器被廣泛的應用在手機,P D A 等領域,其中較為著名的有Intel 公司生產的基於ARM 內核的XScale系列處理器。由於所有公司生產的基於ARM 內核的處理器具有相同的編程模型,在手持和電池供電的系統中,基於A R M 的嵌入式系統處理器往往被首先選用。PowerPC (簡稱PPC)處理器具有較強的運算性能和數據吞吐能力,在網路和數據通信領域基於PPC 的嵌入式系統處理器有著廣泛的應用。其中Motorola公司生產的MPC860/MPC8260 被大量地應用在嵌入式網路產品中。MIPS 處理器的特點表現在十分強大的處理能力上。作為高性能處理器,MIPS 處理器適用於網路、企業及高級消費類電子應用,特別是在機頂盒系統中,MIPS 處理器具有較高的市場佔有率。隨著可編程器件的規模不斷擴大,使得人們能夠根據需要定製處理器,並方便的將針對某種特殊應用定製的處理器方便的在可編程器件內部實現。除了處理器外,計算機系統還需要許多其他構成部分,比如在多通道媒體數據處理系統中,經常需要使用可編程器件來實現高速的數據處理功能,使用軟核DSP 來實現復雜的數字信號處理演算法,同時還需要處理器進行事務處理,軟核處理器將可編程器件,D S P 同處理器結合在一起,為系統級設計提供了極大的靈活性。D S P (數字信號處理器)有別於通用處理器,集中表現在其強大的數字信號處理能力上。在DSP 內部提供了硬體乘累加器,處理器在設計上對於特殊的定址方式做了優化,一些DSP 還支持零耗循環(Zero OverheadLoop)。為了方便嵌入式系統設計,主流DSP 一般也都提供了豐富的外設。特別值得一提的是A D I 公司的Blackfin 系列DSP 和TI 公司的DM64X 系列DSP,兩種處理器都提供了豐富的片上外設,非常適用嵌入式系統應用。
操作系統
Window CE.NET/5.0
作為Microsoft的產品,Window CE.NE/5.0提供了功能完備的平台開發工具Platform Builder和應用開發工具Embedded Visual C++/Visual Studio 2003。Windows CE由於擁有廣大使用者所熟悉的windows 界面,系統提供了眾多驅動程序,並且有完備的文檔支持。對於應用開發而言,熟悉Windows 系統開發的程序員很容易轉到WindowsCE 應用程序的開發。Windows CE將會是一個非常有前途的嵌入式操作系統。
VxWorks
VxWorks 是由Windriver(風河)公司出品的嵌入式實時操作系統,大名鼎鼎的火星登陸車就是使用了VxWorks。Windriver 為VxWorks 提供了集成開發環境tornado。
υC/OSII
υC/OS是由Jean Labrosse設計編寫的開放源代碼的嵌入式實時操作系統,筆者最早接觸的嵌入式操作系統就是它。閱讀並深入理解υ C/OS 的源代碼對於理解實時系統是大有裨益的。
ARM Linux
ARM linux是由Russell King和其他開發者開發移植的用於ARM 處理器的linux操作系統。 ARM Linux系統在GNU GPL下發布。有興趣的讀者可以參看
的介紹。
υ CLinux
υ Clinux 是適用於沒有MMU 的嵌入式處理的LinuxOS 版本。υ Clinux 同樣在GNU GPL 下發布,有興趣的讀者可以參看

嵌入式系統開發過程中的常見問題和解決方法
Bootloader如何寫入Flash ?
初學者一般都會遇到如何將程序寫入處理器的問題。對於不同的處理器,可以採用不同的方法。例如Intel的Xscale處理器可以使用Intel公司提供的JFlash工具燒寫。對於具有JTAG 調試工具軟體的處理器,可以使用如下思路:編寫一段程序,這段程序能將位於SDRAM/SRAM 固定地址中的數據寫入Flash 中。燒寫時,首先,將這段軟體下載到SDRAM 中,然後通過調試軟體將要寫入Flash的數據下載到S D R A M / S R A M 的某個固定地址開始的緩沖區,然後通過調試器開始執行程序,將數據寫入Flash。除此以外,網路上還提供了很多專用的寫Flash的工具,開發者可以根據自己的需要選用。(現在明白了我在學的那個BF533為什麼先下個flashProgramer.dxe先了)
什麼是arm-elf-gcc?
arm -elf-gcc是一個交叉C語言編譯器。我們在PC平台下編譯程序,編譯器運行的處理器同生成的代碼將要運行的處理器相同。但是,在PC 機上編譯ARM 程序時,編譯器運行的處理器同生成的代碼運行的處理器不同,這種編譯器叫做交叉編譯器。其中的elf是指編譯器生成的目標文件格式。(其實我們平時用的單片機編譯器如GCC—AVR等已是交叉編譯器了,我到現在才弄清楚什麼是交叉編譯器)
走了哪條編譯路徑?
系統程序和驅動程序往往包含很多的編譯選項,很多選項都是在編譯時通過命令行定義的,如果想知道編譯的是那一段程序可以使用如下的方法:
#ifdef PLAT_AAA
#error Code for Platform AAA
#else
#error Code NOT for Platform AAA
#endif
這樣在編譯的時候就知道,編譯的是哪一條路經了。對於支持#pragma message( 「I am here」)的編譯器也可使用#pragma message預編譯指令。
我怎麼知道那段代碼在那個文件中?
系統編程中經常需要使用在多個文件中搜索字元串,在windows平台下可以使用平台提供的多文件字元串搜索工具。在linux平台下,可以使用grep來搜索字元串。Grep 的搜索功能十分強大,支持正則表達式搜索,熟練使用grep對於閱讀系統和驅動程序代碼是很有
幫助的。
系統是從那個文件開始運行的?
對於W i n d o w s C E 系統,一般從
W I N C E 4 2 0 \PLATFORM\YourPlatform\KERNEL\HAL 目錄的某個匯編文件中。對於Linux 系統版本不同會存在一定差異,以arm處理器為例,一般會在linux2.4.x\arch\arm\kernel的head-armv.S中。
程序執行到了那裡?
可以在程序中插入如下代碼來實現
printf( 「I am here %s, %d\n」,__FILE__, __LINE__);
代碼將打出printf語句所在的文件名和行號。
推薦書目
Jean J.Labrosse MicroC/OS-II The Real-Time Kernel,Second Edition
這本書是筆者接觸嵌入式實時系統的入門書,在國內能夠買到中文版。這本書較為清楚地講述了實時系統的概念,各個組成部分的工作原理,特別是公開了實時系統內核的源代碼,仔細研究定會受益匪淺。有個小的提示,對於初學者,這本書可以先不看第一章,直接從
第二章看起。
Abraham Silberschatz, Peter Baer Galvin,Greg Gagne Operating System Concepts
筆者在教學過程中發現,無論是計算機還是電子工程專業都有很多學生對於操作系統的基本概念都沒有搞清,很少有學生有完整的系統編程經驗。Operating SystemConcepts這本書對操作系統的感念講述只能用經典來形容。對於嵌入式系統有興趣深入研究的同學,首先
要把基礎打好,這本書就成了必讀之物了。
Andrew S. Tanenbaum Computer Networks
提起Andrew S. Tanenbaum 學習計算機的同學一定都知道OPERATINGSYSTEMs:Design and Implementation這本書,筆者對於Tanenbaum 這樣的教授由衷佩服。網路協議棧是嵌入式系統中的支柱性組成部分。願意致力於網路深層技術研究的同學,這本書將你們建立一個堅實的網路基礎。
Karim Yaghmour Building Embedded Linux Systems
本書詳盡的介紹了嵌入式linux系統的組成,基本概念和如何去建立各個部分。全書篇幅較小,可謂短小精悍。即可以作為嵌入式linux 系統的入門讀物,又是開發過程各個部分的指南。
Advanced RISC Machines Ltd (ARM) ARM7 TDMI
Data Sheet
Advanced RISC Machines Ltd (ARM) ARM920T
Technical Reference Manual
學習嵌入式系統不了解當前應用最廣泛的嵌入式處理器怎麼行? ARM7 TDMI 的 data sheet是學習ARM編程模型,指令集的好東西。在嵌入式系統中,M M U (內存管理單元)是很重要的部分,又是較難理解和掌握的部分。ARM920T Technical Reference Manual 正好可以幫你講解這方面的內容。
Perter Van Der LinDen Expert C Programming
嵌入式系統級編程最常用的語言還是C 。很多同學都自認為自己的C 語言學的很好,那好,就看看這本書吧,找找自己和Experts差距。
註:這篇文章是我在2004年第12期的學習園地看到的。文章的作者是袁通
作者簡介
袁通,北京工業大學實驗學院嵌入式系統課程教師,曾於2 0 0 4 年以訪問學生身份工作於微軟亞洲研究院。
看完這篇文章後,我就迫不及待得貼出來,因為確實是寫的好啊。我搞嵌入式一年多了,從8051到ARM,學習過,彷徨過,高興過,郁悶過。。。近來甚至有放棄的想法,終歸到底是對嵌入式開發認識不全面造成的,一開始就一頭鑽到技術里,學習各種技術,最終迷失在自己一手造成的泥坑裡。這篇文章非常清晰的講述了嵌入式開發的方方面面,對我這樣迷惑的人起到了醍醐灌頂的作用。
嵌入式開發與桌面開發既有不同,又有非常大的聯系,而且十分注重實際操作能力。搞桌面開發的人在一開始接觸嵌入式的時候,通常轉換不過來,這主要體現在定位上。如文中所說,你是誰,你要做什麼?我對硬體的了解僅限於編程領域,PCB設計一竅不通,但並不能說你不懂硬體就不能從事嵌入式開發。一個系統的開發設計方方面面,在自己感興趣和熟悉的領域做出自己的貢獻才是最主要的。
1。硬體設計: 需要有硬體設計的經驗,對各種嵌入式器件有很好的了解。
2。系統移植:需要匯編經驗,操作系統原理以及底層驅動的了解
3。應用程序:需要桌面編程經驗

Ⅱ opencv不用把庫放到開發板上嗎

由於我本機PC端測試使用的opencv的版本為opencv2.4.6.1.故而我想要移植這個版本的opencv到zedboard板卡上。參考Xilinx出版的《Zynq開發實戰》的第13章以及幾個人的博客進行配置編譯的時候,總是會出現如下的錯誤:
In file included from /usr/include/math.h:409:0,
from /opt/opencv-2.4.6.1/moles/core/include/opencv2/core/types_c.h:94,
from /opt/opencv-2.4.6.1/moles/core/include/opencv2/core/core.hpp:49,
from /opt/opencv-2.4.6.1_forArm/moles/core/precomp.hpp:50:
/usr/include/bits/mathinline.h: In function 'void cv::randnScale_8u(const float*, uchar*, int, int, const float*, const float*, bool)':
/usr/include/bits/mathinline.h:675:3: error: unknown register name 'st' in 'asm'
/usr/include/bits/mathinline.h:675:3: error: unknown register name 'st' in 'asm'
/usr/include/bits/mathinline.h:675:3: error: unknown register name 'st' in 'asm'
/usr/include/bits/mathinline.h: In function 'void cv::randShuffle_(cv::Mat&, cv::RNG&, double) [with T = unsigned char]':
/usr/include/bits/mathinline.h:675:3: error: unknown register name 'st' in 'asm'
/usr/include/bits/mathinline.h: In function 'void cv::randShuffle_(cv::Mat&, cv:
......
在用交叉編譯工具鏈編譯opencv時候,我本來已經將交叉編譯工具鏈寫入了環境變數,那它搜索的時候,應該是遍歷交叉編譯工具鏈下的頭文件,但是 opencv卻默認遍歷到gcc頭文件下,故而出現這樣的錯誤,為何會這樣呢?試了多種方式均不能編譯通過,故而棄用書上編譯opencv的方式,轉向下 面的方式:
我們採用圖形化的cmake進行配置,這樣就可以指定交叉編譯工具鏈的頭文件目錄,下載cmake安裝包(ps:不要下載源代碼),下載地址如下:
http://www.cmake.org/cmake/resources/software.html我使用的系統為32位Centos6.4,故而我選擇的平台為Linux i386,下載其後面的壓縮包。
下載完成後,解壓縮cmake-2.8.12.2-Linux-i386.tar.gz到/usr/local下,使用下面的命令:
tar xvzf cmake-2.8.12.2-Linux-i386.tar.gz -C /usr/local
export PATH=$PATH:/usr/local/cmake-2.8.12.2-Linux-i386/bin
接下來,我們利用cmake-gui進行opencv的配置,創建zedopencv目錄,解壓縮opencv代碼到此目錄下,在opencv的源代碼下創建zed_install,然後進入此目錄。命令如下:
tar xvzf opencv-2.4.6.1.tar.gz -C ./zedopencv
cd ./zedopencv/opencv-2.4.6.1
mkdir zed_install
cd zed_install
cmake-gui
出現如下的界面:

其中,按照提示選擇要編譯的opencv源代碼的路徑以及安裝編譯路徑,這里如圖所示。然後點擊Configure,出現如下的配置界面:

這里一定要注意,選擇Unix Makefile選項,在下面選擇指定編譯器選項,然後點擊next進入下面的界面,按照提示,填入如下的信息:

指定交叉編譯環境的頭文件目錄是/opt/xlinx-arm-gcc/arm-xilinx-linux-gnueabi/libc/usr/,選擇C 與C++的編譯器,還有平台,這里一定要注意Library mode的選項,這里一定要選擇在根目錄與本地系統下均搜索,如上圖所示,點擊Finish完成配置。第三方庫,盡量不用選,如下圖所示:

然後點擊Generate,完成配置,然後執行make,開始編譯,編譯的過程中會出現下面的一個錯誤:
Linking CXX executable ../../bin/opencv_createsamples
../../lib/libcxcore.so: undefined reference to `clock_gettime'
../../lib/libcxcore.so: undefined reference to `pthread_key_create'
../../lib/libcxcore.so: undefined reference to `pthread_getspecific'
../../lib/libcxcore.so: undefined reference to `pthread_setspecific'
按照錯誤的提示,是缺少線程鏈接,我們需要對此目錄下的CmakeCache.txt進行修改,修改的位置如下:
178 //Flags used by the linker.
179 CMAKE_EXE_LINKER_FLAGS:STRING=-lpthread -lrt
然後保存退出,繼續編譯就可以完成所有的編譯。完成後,在此目錄下的lib下發現已經編譯好了所有的庫文件,創建zed-lib-opencv文件夾,拷貝所用的.so文件到此目錄下。
為了便於製作鏡像文件,在此目錄下創建ramdisk文件夾。我寫了個shell腳本,也就是圖中所示的fs.sh,為了便於操作其中的參數$1代表要製作的鏡像的名稱,$2代表要製作鏡像的文件夾,$3代表鏡像的大小,腳本的具體內容如下:
#!/bin/bash
dd if=/dev/zero of=$1.image bs=1M count=$3

mke2fs -F $1.image -L "ramdisk" -b 1024 -m 0
tune2fs $1.image -i 0

chmod 777 $1.image

#mkdir ramdisk

mount -o loop $1.image ./ramdisk

cp -R ./$2/* ./ramdisk

umount ./ramdisk
由於ramdisk文件系統的大小為8M,而Opencv的庫文件顯然大於8M,其接近於25M,故而8M是滿足不了的,SD卡有4G的空間,製作庫文件的鏡像,拷貝到SD卡上,把SD卡掛載到Linux系統,就可以解決空間不夠用的問題。我們進行如下的操作:
首先進入filesys,在usr目錄下創建lib,再進入etc/init.d,對rcS文件進行修改。添加下面幾行代碼:
echo "mount otherlib....."
mount /dev/mmcblk0p1 /mnt
mount /mnt/opencvlib.image /usr/lib

export PATH=$PATH:/usr/local/bin
export LD_LIBRARY_PATH=/usr/local/lib:/lib
然後,我們進行鏡像的製作:
./fs.sh ramdisk8M filesys 8
./fs.sh opecv_lib zed-lib-opencv 80
製作了兩個鏡像文件ramdisk8M.image opecv_lib.image大小分別為8M與80M.
然後對ramdisk進行壓縮:
gzip -9 ramdisk8M.image
然後將新生成的ramdisk8M.image.gz與opencv_lib.image拷 貝到SD卡啟動zedboard即可發現,/usr/lib目錄下已經有了opencv庫文件,至此opencv移植到zedboard工作徹底完成!此 方法也可以用於一般的arm開發板opencv的移植。
要支持第三方庫,可以參照這個博客:ffmpeg支持,在編譯完第三方庫之後,需要重新編譯opencv庫!

Ⅲ 如何使用oprofile對軟體做profiling

一. Oprofile簡介

Profiling是對不同性能特徵的數據的形式化總結或分析,它通常以圖形和表的形式出現。它提供為特定的處理器事件收集的采樣百分數或數量,比如cache miss rate、TLB miss rate等等。一般來說,主要目的是為了找出軟體中的性能瓶頸,然後有針對性的優化以提升軟體的整體性能。

Oprofile 是用於 Linux 的若干種評測和性能監控工具中的一種。它可以工作在不同的體系結構上,包括ARM, PowerPC, MIPS, IA32, IA64 和 AMD Athlon等等。它的開銷很小,從Linux 2.6 版起,它被包含進了Linux內核中。

Oprofile可以收集有關處理器事件的信息,幫助用戶識別諸如循環的展開、cache的使用率低、低效的類型轉換和冗餘操作、錯誤預測轉移等問題。Oprofile是一種細粒度的工具,可以為指令集或者為函數、系統調用或中斷處理常式收集采樣。Oprofile 通過取樣來工作。使用收集到的評測數據,用戶可以很容易地找出性能問題。

通過監察CPU的hardware events,oprofile可以在運行狀態下對整個Linux系統進行profiling。Profiling的對象可以是Linux kernel (包括moles和interrupt handlers), shared libraries或者應用程序。

從0.9.8版本開始,oprofile支持Perf_events profiling mode模式。應用程序operf被用來控制profiling過程;而在legacy mode下,是通過opcontrol腳本和oprofiled daemon來完成的。Operf不再象legacy mode那樣需要OProfile kernel driver,它直接和Linux Kernel Performance Events Subsystem打交道。使用operf,就可以用普通用戶的身份來profiling用戶的應用程序了,當然如果需要對整個系統來profiling的時候還是需要root許可權的。

如果硬體不支持OProfile使用performance counters,OProfile就只能工作在Timer Mode下了。Timer Mode只能在legacy profiling mode下使用,即只能通過opcontrol腳本來控制。
Oprofile的優勢:
Ÿ 比較低的運行開銷
Ÿ 對被profiling的對象影響很小
Ÿ 可以profiling中斷服務程序(interrupt handlers)
Ÿ 可以profiling應用程序和shared libraries
Ÿ 可以profiling dynamically compiled (JIT) code
Ÿ 可以對整個系統做profiling
Ÿ 可以觀察CPU內部的細節,例如cache miss rate
Ÿ 可以多源代碼做annotation
Ÿ 可以支持instruction-level的profiling
Ÿ 可以生成call-graph profiles

不過OProfile也不是萬能的,它也有自己的局限性:
Ÿ 只能在x86, ARM, 和PowerPC架構上生成call graph profiles
Ÿ 不支持100%精確的instruction-level profiling
Ÿ 對dynamically compiled (JIT) code profiling的支持還不完善。

無論如何,Oprofile的功能都比gprof要強很多,代價是配置起來會比較麻煩。


二. 編譯Oprofile

首先最好在Linux kernel裡面選中Oprofile driver,以獲得全面的支持。因為筆者使用的是Xilinx Linux pre-built 14.7,所以這里下載的是linux-xlnx-xilinx-v14.7.tar.gz

解壓縮後,用以下命令調出Linux kernel的配置界面:
export ARCH=arm
export CROSS_COMPILE=arm-xilinx-linux-gnueabi-
make xilinx_zynq_defconfig
make xconfig 或者make menuconfig

在配置界面上將以下兩項勾上:
General setup --->
[*] Profiling support
<*> OProfile system profiling

然後make uImage即可生成新的uImage,用來替換Xilinx Linux pre-built 14.7中的Linux kernel image。同時我們也需要vmlinux來檢查profiling的結果。


Oprofile需要popt, bfd, liberty庫,要在嵌入式單板上使用這些庫,需要手工完成交叉編譯。

針對popt 1.7,用以下命令完成編譯:
./configure --prefix=/home/wave/xilinx/oprofileprj/rootfs --host=arm-xilinx-linux-gnueabi --with-kernel-support --disable-nls && make && make install

針對binutils 2.24,用以下命令完成編譯:
./configure --host=arm-xilinx-linux-gnueabi --prefix=/home/wave/xilinx/oprofileprj/rootfs --enable-install-libbfd --enable-install-libiberty --enable-shared && make && make install
不過--enable-install-libiberty沒有效果,所以需要手工把libiberty.a和libiberty.h拷貝到相應的位置。

針對oprofile 0.9.9,用以下命令完成編譯:
./configure --host=arm-xilinx-linux-gnueabi --prefix=/home/wave/xilinx/oprofileprj/rootfs --with-kernel-support --with-binutils=/home/wave/xilinx/oprofileprj/rootfs && make && make install
配置過程結束後可能會有以下提示,因為沒有打算用GUI和profile JITed code,所以直接忽視之。
config.status: executing libtool commands
Warning: QT version 3 was requested but not found. No GUI will be built.
Warning: The user account 'oprofile:oprofile' does not exist on the system.
To profile JITed code, this special user account must exist.
Please ask your system administrator to add the following user and group:
user name : 'oprofile'
group name: 'oprofile'
The 'oprofile' group must be the default group for the 'oprofile' user.

將編譯完成的uImage,vmlinux,oprofile binary,重新編譯的沒有-pg的libjpeg binary以及tool chain的libc打包放到SD卡中,准備在ZC706開發板上嘗試profile djpeg。

三. 運行Oprofile

正常啟動嵌入式Linux後,在開發板的console上一次輸入以下命令:

mount /dev/mmcblk0p1 /mnt

mkdir -p /home/root/work
cd /home/root/work
tar zxvf /mnt/jpeg-bin-nopg.tar.gz
cd jpeg-bin/bin
cp /mnt/park-2880x1800.jpg .
export LD_LIBRARY_PATH=/home/root/work/jpeg-bin/lib

cd /home/root/work
tar zxvf /mnt/rootfs.tar.gz
cd rootfs
chown root:root -R *
cp -R bin/* /usr/bin
cp -R lib/* /lib
cp /bin/which /usr/bin
cp /bin/dirname /usr/bin
mkdir -p /home/wave/xilinx/oprofileprj/rootfs/share
cp -R ./rootfs/* /home/wave/xilinx/oprofileprj/rootfs

cd /home/root/work
tar zxvf /mnt/libc.tar.gz
cp ./lib/libstdc*.* /lib

mkdir -p /home/wave/xilinx/libjpeg
cd /home/wave/xilinx/libjpeg
tar zxvf /mnt/jpeg-9.tar.gz

cp /mnt/vmlinux /home/root/work

cd /home/root/work/jpeg-bin/bin

opcontrol --init
opcontrol --vmlinux=/home/root/work/vmlinux
opcontrol --setup --event=CPU_CYCLES:100000::0:1 --session-dir=/home/root/

operf --vmlinux /home/root/work/vmlinux ./djpeg -bmp park-2880x1800.jpg > result.bmp
opreport -l ./djpeg

完成這一步後,我們就可以看到profiling的結果了,在筆者的平台上看到的內容的主要部分如下:
root@zynq:~/work/jpeg-bin/bin# opreport -l ./djpeg
Using /home/root/work/jpeg-bin/bin/oprofile_data/samples/ for samples directory.
CPU: ARM Cortex-A9, speed 666667 MHz (estimated)
Counted CPU_CYCLES events (CPU cycle) with a unit mask of 0x00 (No unit mask) count 100000
samples % image name symbol name
15293 58.6253 libc-2.17.so /lib/libc-2.17.so
2044

Ⅳ ARM交叉編譯時鏈接錯誤,提示collect2: ld returned 1 exit status,求解答

libVimbaC.so編譯的不對, 使用arm gcc鏈接so命令:
arm-none-linux-gnueabi-gcc -o libVimbaC.so -shared ..... VimbaC.cpp
就可以編譯出arm下用的動態庫了.

Ⅳ 如何使用oprofile對軟體做profiling

下載的是linux-xlnx-xilinx-v14.7.tar.gz

解壓縮後,用以下命令調出Linux kernel的配置界面:
export ARCH=arm
export CROSS_COMPILE=arm-xilinx-linux-gnueabi-
make xilinx_zynq_defconfig
make xconfig 或者make menuconfig

在配置界面上將以下兩項勾上:
General setup --->
[*] Profiling support
<*> OProfile system profiling

然後make uImage即可生成新的uImage,用來替換Xilinx Linux pre-built 14.7中的Linux kernel image。同時我們也需要vmlinux來檢查profiling的結果。


Oprofile需要popt, bfd, liberty庫,要在嵌入式單板上使用這些庫,需要手工完成交叉編譯。

針對popt 1.7,用以下命令完成編譯:
./configure --prefix=/home/wave/xilinx/oprofileprj/rootfs --host=arm-xilinx-linux-gnueabi --with-kernel-support --disable-nls && make && make install

針對binutils 2.24,用以下命令完成編譯:
./configure --host=arm-xilinx-linux-gnueabi --prefix=/home/wave/xilinx/oprofileprj/rootfs --enable-install-libbfd --enable-install-libiberty --enable-shared && make && make install
不過--enable-install-libiberty沒有效果,所以需要手工把libiberty.a和libiberty.h拷貝到相應的位置。

針對oprofile 0.9.9,用以下命令完成編譯:
./configure --host=arm-xilinx-linux-gnueabi --prefix=/home/wave/xilinx/oprofileprj/rootfs --with-kernel-support --with-binutils=/home/wave/xilinx/oprofileprj/rootfs && make && make install
配置過程結束後可能會有以下提示,因為沒有打算用GUI和profile JITed code,所以直接忽視之。
config.status: executing libtool commands
Warning: QT version 3 was requested but not found. No GUI will be built.
Warning: The user account 'oprofile:oprofile' does not exist on the system.
To profile JITed code, this special user account must exist.
Please ask your system administrator to add the following user and group:
user name : 'oprofile'
group name: 'oprofile'
The 'oprofile' group must be the default group for the 'oprofile' user.

將編譯完成的uImage,vmlinux,oprofile binary,重新編譯的沒有-pg的libjpeg binary以及tool chain的libc打包放到SD卡中,准備在ZC706開發板上嘗試profile djpeg。

三. 運行Oprofile

正常啟動嵌入式Linux後,在開發板的console上一次輸入以下命令:

mount /dev/mmcblk0p1 /mnt

mkdir -p /home/root/work
cd /home/root/work
tar zxvf /mnt/jpeg-bin-nopg.tar.gz
cd jpeg-bin/bin
cp /mnt/park-2880x1800.jpg .
export LD_LIBRARY_PATH=/home/root/work/jpeg-bin/lib

cd /home/root/work
tar zxvf /mnt/rootfs.tar.gz
cd rootfs
chown root:root -R *
cp -R bin/* /usr/bin
cp -R lib/* /lib
cp /bin/which /usr/bin
cp /bin/dirname /usr/bin
mkdir -p /home/wave/xilinx/oprofileprj/rootfs/share
cp -R ./rootfs/* /home/wave/xilinx/oprofileprj/rootfs

cd /home/root/work
tar zxvf /mnt/libc.tar.gz
cp ./lib/libstdc*.* /lib

mkdir -p /home/wave/xilinx/libjpeg
cd /home/wave/xilinx/libjpeg
tar zxvf /mnt/jpeg-9.tar.gz

cp /mnt/vmlinux /home/root/work

cd /home/root/work/jpeg-bin/bin

opcontrol --init
opcontrol --vmlinux=/home/root/work/vmlinux
opcontrol --setup --event=CPU_CYCLES:100000::0:1 --session-dir=/home/root/

operf --vmlinux /home/root/work/vmlinux ./djpeg -bmp park-2880x1800.jpg > result.bmp
opreport -l ./djpeg

完成這一步後,我們就可以看到profiling的結果了,在筆者的平台上看到的內容的主要部分如下:
root@zynq:~/work/jpeg-bin/bin# opreport -l ./djpeg
Using /home/root/work/jpeg-bin/bin/oprofile_data/samples/ for samples directory.
CPU: ARM Cortex-A9, speed 666667 MHz (estimated)
Counted CPU_CYCLES events (CPU cycle) with a unit mask of 0x00 (No unit mask) count 100000
samples % image name symbol name
15293 58.6253 libc-2.17.so /lib/libc-2.17.so
2044

閱讀全文

與xilinx交叉編譯環境源碼相關的資料

熱點內容
怎樣修改壓縮的文件 瀏覽:265
海爾家電寶app為什麼不能用了 瀏覽:301
張家口代駕公司用什麼app 瀏覽:661
哪個視頻軟體可以解壓格式多 瀏覽:77
idea加密殼 瀏覽:261
壓縮泵電容 瀏覽:336
androidactivity上下切換 瀏覽:555
不要惹飆車的程序員 瀏覽:817
怎麼解壓成lmf3格式 瀏覽:310
雲伺服器設置埠轉發 瀏覽:587
數學分析復旦pdf 瀏覽:280
用什麼能改列印伺服器 瀏覽:145
上海不動產權證怎麼加密碼 瀏覽:589
linux推薦版本 瀏覽:576
安卓網格布局有什麼特點 瀏覽:327
生化危機用什麼app看 瀏覽:916
布穀鳥搜索演算法matlab 瀏覽:138
伺服器的燈如何設置 瀏覽:862
單片機控制門流程圖 瀏覽:304
滬漂女程序員跳槽 瀏覽:306