出版時間:2009-1 出版社:北京航空航天大學出版社 作者:張瑜 等 著 頁數(shù):255
前言
隨著嵌入式系統(tǒng)的發(fā)展和普及,吸引越來越多的大學電類專業(yè)的學生和業(yè)余愛好者投入到ARM的學習和開發(fā)中。ARM是一門應用性和實踐性很強的技術(shù),然而,目前市場上的ARM書籍主要側(cè)重于理論介紹,而與之相應的實驗類教材非常少。針對這個問題,本書以實例為主線,從初識ARM體系結(jié)構(gòu)、開發(fā)環(huán)境及編寫第一個ARM程序開始,到最后完成異常處理程序設(shè)計以及μC/OSⅡ和Linux內(nèi)核在ARM上的操作系統(tǒng)移植,由易到難,由簡到繁,循序漸進,從而使嵌入式初學者能輕松入門,為以后進一步從事嵌入式系統(tǒng)的開發(fā)打下扎實的基礎(chǔ)。本書具有以下特點: (1) 方法新穎 面向ARM的初學者,采用了“比較”的方法,即從熟悉的Intel 8086處理器入手,引導讀者逐步深入學習ARM。通過對Intel 8086與ARM的層層比較和分析,幫助ARM初學者在總結(jié)Intel 8086體系結(jié)構(gòu)和編程模式的基礎(chǔ)上能夠較快地掌握ARM編程?! 。?) 通俗易懂 文字表述淺顯易懂,所選的35個ARM編程和操作系統(tǒng)在ARM上的移植實例,由淺入深,循序漸進,通用性強,并配以大量圖表說明,尤其適合于沒有硬件基礎(chǔ)的嵌入式系統(tǒng)的初學者,對于具有一定基礎(chǔ)的ARM開發(fā)人員也有相當大的參考價值。全書共分13章。 第1章介紹了ARM基礎(chǔ)知識及處理器體系結(jié)構(gòu)實驗?! 〉?章初步介紹了ARM開發(fā)工具ADS及 ADS下簡單C語言程序?qū)嶒灐! 〉?章介紹了簡單的ARM匯編程序設(shè)計及ADS下簡單ARM匯編程序?qū)嶒?。 ?章介紹了尋址方式及ARM尋址方式實驗。 第5章介紹了數(shù)據(jù)處理指令及ARM數(shù)據(jù)處理指令實驗?! 〉?章介紹了數(shù)據(jù)加載與存儲指令及ARM數(shù)據(jù)加載與存儲指令程序?qū)嶒?。 ?章介紹了控制轉(zhuǎn)移指令及ARM控制轉(zhuǎn)移指令程序?qū)嶒?。 ?章介紹了子程序設(shè)計及ARM子程序設(shè)計實驗。 第9章介紹了處理器的工作模式及ARM工作模式切換程序?qū)嶒?。 ?0章介紹了匯編語言和C語言混合編程及其實驗?! 〉?1章介紹了中斷處理及ARM異常處理程序?qū)嶒?。 ?2章介紹了μC/OSⅡ基礎(chǔ)及μC/OSⅡ在ARM上的移植實驗?! 〉?3章介紹了嵌入式Linux基礎(chǔ)及Linux在ARM上的移植與開發(fā)實驗。本書由張瑜、王益涵任主編,張崇明、郭榮任副主編。第1、8、11章由張瑜、王益涵編寫,第9、10、12章由王益涵編寫,第2~4章及第13章由張崇明編寫,第5~7章及8.1.3小節(jié)由郭榮編寫。張瑜對各章進行了修改和統(tǒng)稿。劉啟中教授對全書進行了審定。本書編寫中,作者參考了大量的有關(guān)書籍,從同行中學到了很多知識,并參考了相關(guān)網(wǎng)站資料,而且得到了上海工程技術(shù)大學、上海師范大學、中北大學、北京航空航天大學等單位教師和領(lǐng)導的大力支持,中國電子學會嵌入式專委會和博創(chuàng)科技為本書組稿做了大量工作,汪春梅副教授對本書的編寫提供了技術(shù)方面的協(xié)作,并提出了許多寶貴的建議,在此一并表示衷心的感謝。作者雖然從事嵌入式系統(tǒng)的教學和研究工作多年,但由于ARM的發(fā)展極為迅速及作者研究方向的限制,本書難免有疏漏和錯誤之處,敬請讀者和同行批評指正?! ∽髡摺 ?008年9月
內(nèi)容概要
《ARM嵌入式程序設(shè)計》從理論和實驗兩方面系統(tǒng)介紹了ARM體系結(jié)構(gòu)、開發(fā)環(huán)境、ARM匯編程序設(shè)計、ARM工作模式切換程序、異常處理程序設(shè)計、匯編和C語言混合編程以及uC/OS-Ⅱ和Linux內(nèi)核在ARM上的操作系統(tǒng)移植等。每章最后都附有實驗思考,以鞏固所學內(nèi)容,激發(fā)讀者的創(chuàng)新意識?! 禔RM嵌入式程序設(shè)計》可作為普通高校計算機、自動化、電子信息類等專業(yè)學生的實驗教材,也可作為從事嵌入式系統(tǒng)相熒領(lǐng)域技術(shù)人員的參考用書。
書籍目錄
第1章 ARM基礎(chǔ)知識1.1 發(fā)展歷史1.1.1 Intel80x86的發(fā)展歷史1.1.2 ARM的發(fā)展歷史1.2 功能結(jié)構(gòu)1.2.1 Intel8086功能結(jié)構(gòu)1.2.2 ARM功能結(jié)構(gòu)1.3 寄存器組1.3.1 Intel8086寄存器組1.3.2 ARM寄存器組1.4 存儲器組織1.4.1 Intel8086存儲器組織1.4.2 ARM存儲器組織1.5 指令系統(tǒng)1.5.1 一般計算機的指令系統(tǒng)1.5.2 Intel8086指令系統(tǒng)1.5.3 ARM指令系統(tǒng)1.6 實驗1處理器體系結(jié)構(gòu)實驗1.6.1 實驗目的1.6.2 實驗環(huán)境1.6.3 實驗內(nèi)容1.6.4 實驗過程1.6.5 實驗思考第2章 初識ARM開發(fā)工具ADS2.1 從MASM到ADS2.1.1 MASM簡介2.1.2 ADS簡介2.1.3 MASM與ADS命令行開發(fā)工具的比較2.2 ARM圖形化界面CodeWarrior2.3 ARM調(diào)試工具AXD2.4 實驗2ADS下簡單C語言程序?qū)嶒?.4.1 實驗目的2.4.2 實驗環(huán)境2.4.3 實驗內(nèi)容2.4.4 實驗過程2.4.5 實驗思考第3章 簡單的ARM匯編程序設(shè)計3.1 ARM匯編程序設(shè)計的一般過程3.2 ARM程序的編輯3.3 ARM編譯器設(shè)置3.4 ARM鏈接器設(shè)置3.5 ARM程序的編譯和鏈接3.6 ARM程序執(zhí)行過程的跟蹤和調(diào)試3.7 實驗3ADS下簡單ARM匯編程序?qū)嶒?.7.1 實驗目的3.7.2 實驗環(huán)境3.7.3 實驗內(nèi)容3.7.4 實驗過程3.7.5 實驗思考第4章 尋址方式4.1 尋址方式的基本概念4.2 Intel8086的尋址方式4.3 ARM的尋址方式4.4 實驗4ARM尋址方式實驗4.4.1 實驗目的4.4.2 實驗環(huán)境4.4.3 實驗內(nèi)容4.4.4 實驗過程4.4.5 實驗思考第5章 數(shù)據(jù)處理指令5.1 Intel8086的數(shù)據(jù)處理指令5.1.1 數(shù)據(jù)傳送指令5.1.2 算術(shù)運算指令5.1.3 邏輯運算指令5.1.4 移位指令5.2 ARM數(shù)據(jù)處理指令5.2.1 寄存器傳送指令5.2.2 移位指令5.2.3 算術(shù)運算指令5.2.4 邏輯運算指令5.2.5 比較和測試指令5.2.6 乘法指令5.3 實驗5ARM數(shù)據(jù)處理指令實驗5.3.1 實驗目的5.3.2 實驗環(huán)境5.3.3 實驗內(nèi)容5.3.4 實驗過程5.3.5 實驗思考第6章 數(shù)據(jù)加載與存儲指令第7章 控制轉(zhuǎn)移指令第8章 子程序設(shè)計第9章 處理器的工作模式第10章 匯編和C語言混合編程第11章 中斷處理第12章 霤/OSⅡ基礎(chǔ)第13章 嵌入式Linux基礎(chǔ)附錄A ARM指令表附錄B ARM偽指令表附錄C ARM偽操作表附錄D 實驗思考參考答案參考文獻
章節(jié)摘錄
第1章 ARM基礎(chǔ)知識 80x86是美國Intel公司開發(fā)的微處理器系列芯片。ARM(Advanced RISC Machines)既是成立于英國劍橋?qū)iT從事出售芯片設(shè)計技術(shù)授權(quán)的公司名字,也是對一類微處理器的通稱。基于ARM體系結(jié)構(gòu)的處理器,除了具有ARM體系結(jié)構(gòu)的共同特點以外,每一個系列的ARM微處理器都還具有各自的特點及應用領(lǐng)域?! ?.1 發(fā)展歷史 1.1.1 Intel 80x86的發(fā)展歷史 1971年,Intel公司開發(fā)出了第一代微處理器4004,它是一款4位微處理器;1972年,Intel公司推出了第一款8位微處理器8008;1974年,Intel公司又推出了為多種應用而設(shè)計的8位微處理器8080,它是Intel公司的第二代微處理器,也是第一款通用微處理器,其功能相當強。8080為Intel公司成為當今CPU的主流打下了堅實的基礎(chǔ)。1976年,Intel公司公布了8080的變種8080A,之后還公布了作為8080A增強型的8085。 1978年,Intel公司率先推出了第三代微處理器——16位微處理器8086。它具有兩個關(guān)鍵的結(jié)構(gòu)概念:存儲器分段和指令譯碼表。Intel公司的80x86家族也由此開始誕生。8086內(nèi)部分成兩部分:總線接口部件BIU(Bus Interface Unit)和執(zhí)行部件EU(Execution Unit)?! 榱朔奖闩c8位外部接口或設(shè)備相連,Intel公司于1979年又推出了8088。8088是8086的8位版,它具有與8086相同的內(nèi)部結(jié)構(gòu),包括EU、BIU和16位的寄存器,所不同的是8088對外只有8根數(shù)據(jù)線,總是按字節(jié)取內(nèi)存單元。8088也稱為準16位微處理器。 1981年,Intel公司又推出了80186。除了8086所具有的特性外,80186還集成了若干通用系統(tǒng)所需的部件,包括1個片選邏輯部件、2個獨立的高速直接存儲器訪問通道、3個可編程時鐘和1個可編程中斷控制器,這些部件使80186功能更強。
編輯推薦
《ARM嵌入式程序設(shè)計》中的ARM是一門應用性和實踐性很強的技術(shù),然而,目前市場上的ARM書籍主要側(cè)重于理論介紹,而與之相應的實驗類教材非常少。針對這個問題,《ARM嵌入式程序設(shè)計》以實例為主線,從初識ARM體系結(jié)構(gòu)、開發(fā)環(huán)境及編寫第一個ARM程序開始,到最后完成異常處理程序設(shè)計以及μC/OSⅡ和Linux內(nèi)核在ARM上的操作系統(tǒng)移植,由易到難,由簡到繁,循序漸進,從而使嵌入式初學者能輕松入門,為以后進一步從事嵌入式系統(tǒng)的開發(fā)打下扎實的基礎(chǔ)。
圖書封面
評論、評分、閱讀與下載