發表於2024-11-15
以往學習USB的過程中大多是由USB的各種理論與基本概念開始,再延伸至程式碼的撰寫。但由於USB的理論規範太多,這樣不僅學習的效果不彰,也將造成學習上的睏難,因此,本書的編排架構是以一邊介紹理論規範,一邊使用C語言撰寫的應用範例來輔助讀者學習與瞭解。如此一來可讓讀者對於USB裝置的設計與應用有著最完整的瞭解與認識。
本書特色
1. 本書以單晶微處理機的學習方嚮來導入高速USB介麵的設計,使讀者在學習過程中,慢慢地剋服艱澀的技術瓶頸。
2. 本書對於復雜與繁瑣的USB通訊,提供瞭EZ-USB韌體函式庫與韌體架構,大幅度地降低瞭我們在撰寫韌體程式碼的睏難度。
3. 為瞭使初學者能快速地學習高速USB介麵設計,本書附贈一片USB 2.0晶片組FX2-56核心單闆的空闆。僅需購買些許零件即可執行高速USB介麵設計及部分實驗單元,應用範圍相當廣泛,並可用於不同的産品或是專題裏一起整閤及測試。
第1章 USB的基本架構與特性
1.1 什麼是USB?
1.2 如何安裝USB裝置?
1.3 USB的匯流排結構
1.4 USB資料流的模式與管綫的概念
1.5 USB傳輸類型
1.6 USB的連接器與纜綫
1.7 USB的編碼方式
1.8 USB介麵的通信協定
1.9 分割資料交易
1.10 USB描述元
1.11 USB標準裝置要求
1.12 裝置群組
1.13 結 論
第2章 EZ-USB FX2晶片組特性
2.1 前 言
2.2 EZ-USB FX2硬體架構圖
2.3 USB內核
2.4 FX2微處理機
2.5 重新裝置列舉
2.6 FX2端點緩衝區
2.7 外部FIFO介麵
2.8 FX2係列 - GPIF(泛用型可程式化的界麵)
2.9 FX2晶片組係列
2.10 Cypress全速與高速晶片組的差異
2.11 暫存器的應用
第3章 EZ-USB FX2 CPU
3.1 增強的8051特性
3.2 執行效率的總覽說明
3.3 軟體相容性
3.4 803x/805x 特性比較
3.5 FX2 CPU/DS80C320差異性
3.6 FX2 CPU暫存器介麵
3.7 FX2 CPU內部RAM
3.8 週邊I/O埠
3.9 中 斷
3.10 電源控製
3.11 特殊功能暫存器 (SFR)
3.12 外部位址 / 資料匯流排
3.13 計時器 / 計數器
第4章 輸入 / 輸齣與記憶體
4.1 輸入 / 輸齣(I/O)簡介
4.2 週邊I/O埠
4.3 週邊I/O埠切換功能
4.4 I2C控製器
4.5 I2C匯流排的應用
4.6 控製位元
4.7 狀態位元
4.8 送齣I2C資料步驟
4.9 接收I2C資料步驟
4.10 EEPROM啓動載入器
4.11 FX2記憶體簡介
4.12 FX2記憶體對映
4.13 “Von-Neumannizing”外接程式與資料記憶體
4.14 在0xE000-0xFFFF位址的內建資料
第5章 軟體發展工具
5.1 FX2發展係統的驅動程式安裝
5.2 控製平颱(Control panel)應用環境的基本操作
5.3 控製平颱總覽
5.4 FX2發展係統的測試軟體及工具
5.5 Keil C51工具軟體-μVisions
第6章 硬體發展工具
6.1 硬體開發工具的基本架構
6.2 硬體工具組介紹
6.3 初步安裝程序
第7章 I/O實驗範例-LED輸齣
7.1 硬體設計與基本概念
7.2 韌體程式碼設計
7.3 程式編譯與鏈結
7.4 七段顯示器輸齣實驗
7.5 結 論
第8章 存取端點緩衝區
8.1 FX2的大容量端點和小容量端點
8.2 高速和全速的差異處
8.3 CPU配置端點
8.4 CPU存取FX2端點資料
8.5 FX2端點的CPU控製
8.6 自動指標器
8.7 存取端點程式設計
第9章 中 斷
9.1 簡 介
9.2 中斷SFR暫存器
9.3 中斷處理
9.4 USB特定中斷
9.5 USB自動嚮量
9.6 I2C中斷
9.7 FIFO/GPIF中斷(INT4)
9.8 FIFO/GPIF-中斷自動嚮量
9.9 USB巨量中斷程式碼撰寫
9.10 SOF中斷
9.11 I2C中斷
第10章 控製傳輸與端點0
10.1 端點0基本概念
10.2 控製端點,EP0
10.3 USB標準要求
10.4 標準裝置要求
10.5 標準介麵要求
10.6 標準端點要求
10.7 FX2 USB標準要求
第11章 重新裝置列舉
11.1 重新裝置列舉基本概念
11.2 裝置列舉步驟
11.3 裝置列舉步驟的實現-使用USB分析儀工具
11.4 預設的FX2 USB裝置
11.5 裝置列舉模式
11.6 無EEPROM或是無效的EEPROM
11.7 存在著EEPROM,第一個位元組是0xC0
11.8 存在著EEPROM,第一個位元組是0xC2
11.9 配置位元組0
11.10 韌體執行重新裝置列舉
11.11 多重-重新裝置列舉
11.12 預設裝置的各個描述元
11.13 裝置列舉程式碼的撰寫
第12章 韌體架構
12.1 韌體架構總覽
12.2 建立韌體架構
12.3 韌體架構之副函式鈎子
12.4 韌體架構之整體變數
12.5 描述元錶格
12.6 韌體架構程式-FW.C
12.7 專案檔案的設計
第13章 巨量傳輸
13.1 簡 介
13.2 巨量傳輸
13.3 中斷傳輸
13.4 巨量IN傳輸
13.5 巨量OUT傳輸
13.6 巨量傳輸程式設計
第14章 泛用型驅動程式
14.1 EZ-USB GPD驅動程式
14.2 載入EZ-USB GPD驅動程式
14.3 連接至 GPD的使用者模式介麵
14.4 I/O控製程式碼(I/O Control Code,IOCTL)參考程式
14.5 控製平颱的實現
第15章 PC應用程式設計
15.1 迴圈測試的巨量傳輸
15.2 USB輸入 / 輸齣控製裝置
15.3 USB 2.0週邊裝置的速度測試
第16章 HID群組
16.1 HID簡介
16.2 HID群組的特性與限製
16.3 HID基本要求
16.4 韌體要求
16.5 辨識HID裝置
16.6 報告描述元
16.7 HID群組要求
第17章 HID I/O韌體程式設計
17.1 設計概念
17.2 韌體程式設計
17.3 韌體程式碼的編譯與鏈結
第18章 HID PC應用程式設計
18.1 PC主機通訊的基本概念
18.2 主機如何發現HID裝置
18.3 所需之API相關文件
18.4 HID裝置驅動程式與DLL的特性
18.5 HID API函式
18.6 Windows與HID通訊的API函式
18.7 打開HID裝置的通訊步驟
18.8 Visual Basic程式設計
18.9 簡化Visual Basic應用程式-DLL 的引用
第19章 Slave FIFO設計與應用
19.1 硬 體
19.2 韌體程式設計
第20章 實現Slave FIFO之CPLD設計
20.1 Altera QuartusII基本介紹
20.2 七段顯示器輸齣測試
20.3 七段顯示器與按鍵測試
20.4 非同步Slave FIFO設計與實現
20.5 非同步PC應用程式設計
20.6 同步Slave FIFO設計與實現
20.7 同步之PC應用程式測試
20.8 討 論
第21章 高速A/D轉換之設計與應用
21.1 高速A/D資料擷取卡
21.2 韌體程式設計
21.3 Slave FIFO的CPLD設計
21.4 PC應用程式測試
附 錄
附錄A 零件錶
參考資料
USB2.0高速週邊裝置設計之實務應用(第三版)(附範例光碟及PCB單闆) pdf epub mobi txt 電子書 下載 2024
USB2.0高速週邊裝置設計之實務應用(第三版)(附範例光碟及PCB單闆) pdf epub mobi txt 電子書 下載