第一篇 嵌入式ARM基础 3
第1章 基础知识 3
1.1 嵌入式系统 4
1.1.1 概念 4
1.1.2 构成 5
1.1.3 特点 5
1.2 知识结构 7
1.2.1 嵌入式基础 7
1.2.2 微处理器与接口 8
1.2.3 嵌入式操作系统 8
1.2.4 嵌入式程序设计 9
1.2.5 开发与维护 9
1.2.6 嵌入式系统设计 9
1.3 项目流程 10
1.4 本章小结 10
1.5 本章习题 11
第2章 开发环境 13
2.1 硬件实验环境 14
2.1.1 ARM参考板 14
2.1.2 硬件仿真器 14
2.2 ADS集成开发环境 16
2.2.1 ADS介绍 16
2.2.2 命令行开发工具 17
2.2.3 armcc用法详解 18
2.2.4 armlink用法详解 20
2.2.5 ARM运行时库 26
2.2.6 库路径的结构 27
2.2.7 CodeWarrior 27
2.2.8 ADS调试器 29
2.2.9 实用程序 30
2.2.10 支持的软件 30
2.3 ADS开发流程 30
2.3.1 创建工程 30
2.3.2 编译与连接 34
2.3.3 代码调试 39
2.4 RealView集成开发环境 42
2.4.1 使用介绍 42
2.4.2 实例分析 46
2.5 嵌入式HelloARM实例入门 50
2.5.1 实验目的 50
2.5.2 实验设备 50
2.5.3 实验原理 50
2.5.4 实验步骤 55
2.6 本章小结 59
2.7 本章习题 59
第二篇 硬件系统设计 63
第3章 硬件设计基础 63
3.1 常用ARM处理器概述 64
3.1.1 ARM应用系统设计概述 64
3.1.2 S3C2410A功能简介 65
3.1.3 S3C2410A CPU内核概述 69
3.1.4 S3C2410A特殊功能寄存器 70
3.1.5 S3C2440概述 70
3.1.6 S3C6410概述 71
3.1.7 S5PV210概述 71
3.1.8 Exynos 4212概述 72
3.1.9 性能对比 73
3.2 硬件电路设计基础 73
3.2.1 需求分析 73
3.2.2 方案确定 75
3.2.3 原理图绘制 76
3.2.4 PCB板图绘制 82
3.2.5 制板与调试 83
3.3 本章小结 84
3.4 本章习题 84
第三篇 ARM体系结构与编程 87
第4章 微处理器概述 87
4.1 常用微处理器概述 88
4.1.1 ARM 88
4.1.2 PowerPC 88
4.1.3 MIPS 89
4.1.4 DSP 89
4.1.5 x86 89
4.1.6 FPGA/CPLD 89
4.2 ARM概述 90
4.2.1 ARM微处理器的特点 91
4.2.2 ARM微处理器的应用领域 91
4.3 ARM版本与命名方法 92
4.3.1 ARM版本介绍 92
4.3.2 ARM体系的变种 93
4.3.3 ARM体系版本的命名格式 94
4.4 常用的ARM微处理器系列介绍 95
4.4.1 经典系列ARM处理器 96
4.4.2 Cortex-A系列 97
4.4.3 Cortex-R系列 97
4.4.4 Cortex-M系列 98
4.4.5 ARM-SecurCore系列 98
4.4.6 ARM-FPGA Cores系列 99
4.5 ARM微处理器的结构 99
4.6 ARM微处理器的应用选型 100
4.6.1 ARM微处理器内核的选择 101
4.6.2 系统的工作频率 101
4.6.3 芯片内存储器的容量 101
4.6.4 内外围电路的选择 101
4.7 新技术扩展 102
4.7.1 ARMv8 102
4.7.2 Thumb-2 102
4.7.3 Thumb执行环境(ThumbEE) 102
4.7.4 高级SIMD(NEON) 102
4.7.5 VFP 103
4.7.6 安全性扩充(TrustZone) 103
4.7.7 Cortex-A50系列 103
4.8 本章小结 104
4.9 本章习题 104
第5章 编程模型 105
5.1 ARM微处理器的工作状态 106
5.2 ARM微处理器的工作模式 106
5.3 寄存器组织 107
5.3.1 ARM状态下的寄存器组织 108
5.3.2 Thumb状态下的寄存器组织 110
5.3.3 程序状态寄存器 111
5.4 ARM数据存储格式 113
5.5 指令长度及数据类型 114
5.6 AMBA规范 115
5.6.1 AMBA片上总线 115
5.6.2 基于AMBA的片上系统 116
5.6.3 AHB简介 116
5.6.4 APB简介 116
5.7 AAPCS规范 116
5.8 异常(Exceptions) 117
5.8.1 异常 117
5.8.2 对异常的响应 118
5.8.3 从异常返回 118
5.9 本章小结 119
5.10 本章习题 119
第6章 指令系统 121
6.1 ARM微处理器的指令集概述 122
6.1.1 指令的分类与格式 122
6.1.2 指令的条件域 122
6.2 ARM指令的寻址方式 123
6.2.1 立即寻址 123
6.2.2 寄存器寻址 124
6.2.3 寄存器间接寻址 124
6.2.4 基址变址寻址 124
6.2.5 多寄存器寻址 125
6.2.6 相对寻址 125
6.2.7 堆栈寻址 125
6.3 ARM指令实验指导 126
6.3.1 汇编基本框架 126
6.3.2 编译链接调试 127
6.3.3 编译工程 129
6.3.4 调试程序 130
6.4 ARM指令集 131
6.4.1 跳转指令 132
6.4.2 数据处理指令 134
6.4.3 乘法指令与乘加指令 139
6.4.4 程序状态寄存器访问指令 142
6.4.5 加载/存储指令 143
6.4.6 批量数据加载/存储指令 145
6.4.7 数据交换指令 146
6.4.8 移位指令 146
6.4.9 协处理器指令 148
6.4.10 异常产生指令 150
6.5 Thumb指令及应用 151
6.6 本章小结 152
6.7 本章习题 152
第7章 程序设计基础 155
7.1 程序设计概述 156
7.1.1 符号定义(Symbol Definition)伪指令 156
7.1.2 数据定义(Data Definition)伪指令 158
7.1.3 汇编控制(Assembly Control)伪指令 161
7.2 汇编语言的程序结构 167
7.2.1 汇编语言程序的基本结构 167
7.2.2 汇编语言的子程序调用 168
7.2.3 汇编语言程序示例 169
7.3 本章小结 172
7.4 本章习题 172
第8章 混合编程 175
8.1 ATPCS介绍 176
8.1.1 寄存器的使用规则 176
8.1.2 数据栈的使用规则 177
8.1.3 参数的传递规则 178
8.1.4 子程序结果返回规则 179
8.1.5 其他特定规则 179
8.1.6 AAPCS扩展 181
8.2 内嵌汇编器的使用 182
8.2.1 内嵌的汇编指令用法 182
8.2.2 内嵌的汇编器和armasm的区别 183
8.2.3 在C/C++程序中使用内嵌的汇编指令 184
8.2.4 内嵌汇编指令的应用举例 186
8.2.5 从汇编程序中访问C变量 188
8.3 在汇编程序中调用C/C++程序 189
8.3.1 在汇编程序中调用C程序 189
8.3.2 在汇编程序中调用C++程序 189
8.3.3 汇编程序完成初始化功能 190
8.3.4 在C/C++程序中调用汇编程序 191
8.4 本章小结 192
8.5 本章习题 192
第9章 异常处理 193
9.1 ARM异常处理概述 194
9.1.1 ARM体系中的异常种类 194
9.1.2 中断向量与异常优先级 195
9.1.3 各种异常状态下使用的寄存器 195
9.2 进入和退出异常的过程 196
9.2.1 ARM处理器对异常的响应过程 196
9.2.2 在应用程序中安装异常处理程序 197
9.2.3 在系统复位时安装异常处理程序 197
9.2.4 在C程序中安装异常处理程序 198
9.3 各类异常的具体描述 200
9.3.1 FIQ和IRQ中断 200
9.3.2 复位异常 205
9.3.3 未定义指令异常 205
9.3.4 指令预取中止异常 205
9.3.5 数据访问中止异常 206
9.3.6 SWI异常 206
9.4 本章小结 206
9.5 本章习题 207
第10章 基本的ATPCS规则及其实践 209
10.1 寄存器的使用规则 210
10.2 数据栈的使用规则 210
10.3 参数传递的规则 211
10.4 子程序结果返回规则 211
10.5 ARM汇编指令编程实验 211
10.5.1 实验目的 211
10.5.2 实验设备 212
10.5.3 实验原理 212
10.5.4 实验步骤 214
10.6 C语言调用汇编语言编程 217
10.6.1 实验目的 217
10.6.2 实验设备 217
10.6.3 实验原理 217
10.6.4 实验步骤 218
10.6.5 实验思考 221
10.7 汇编语言调用C语言编程 221
10.7.1 实验目的 221
10.7.2 实验设备 221
10.7.3 实验原理 221
10.7.4 实验步骤 221
10.7.5 实验思考 224
第四篇 硬件接口及驱动系统设计 227
第11章 嵌入式软件编程基础 227
11.1 学习目标 228
11.2 本章要点 228
11.3 整体设计 228
11.3.1 开发背景 228
11.3.2 整体设计 228
11.3.3 硬件平台 228
11.3.4 交叉环境 229
11.3.5 硬件驱动 229
11.3.6 任务管理 229
11.3.7 面向对象 230
11.4 内存管理 230
11.4.1 数据指针 230
11.4.2 函数指针 231
11.4.3 内存申请 231
11.4.4 关键字const 231
11.4.5 关键字volatile 233
11.4.6 字长与位宽 233
11.4.7 字节对齐 233
11.4.8 字节顺序 236
11.5 人机界面 238
11.5.1 LED 238
11.5.2 按键 238
11.5.3 LCD 238
11.5.4 通信接口 238
11.6 性能优化 238
11.6.1 死循环 238
11.6.2 延时 239
11.6.3 使用宏 239
11.6.4 关键字register 240
11.6.5 内嵌汇编 240
11.6.6 位操作 240
11.6.7 define/typedef 241
11.7 实践:LED驱动系统 242
11.7.1 需求分析 242
11.7.2 详细设计 242
11.7.3 编码设计 244
11.7.4 调试与测试 245
11.7.5 部署 245
11.8 本章小结 245
11.9 本章习题 245
第12章 嵌入式系统的常用接口 247
12.1 学习目标 248
12.2 本章要点 248
12.3 嵌入式系统常用接口概述 248
12.3.1 嵌入式系统的程序设计方法 248
12.3.2 嵌入式测试测量 249
12.3.3 通用I/O口的工作原理与编程示例 250
12.4 串口工作原理与编程示例 256
12.4.1 异步串行通信及其协议 256
12.4.2 串行通信的物理层标准 257
12.4.3 S3C2410内置的UART控制器 258
12.4.4 UART编程举例 260
12.5 中断控制器工作原理与编程示例 267
12.5.1 中断源状态寄存器 267
12.5.2 中断模式寄存器 267
12.5.3 中断屏蔽寄存器 268
12.5.4 优先级寄存器 268
12.5.5 中断状态寄存器 268
12.5.6 中断偏移寄存器 268
12.6 DMA的工作原理与编程示例 272
12.6.1 DMA的工作原理 272
12.6.2 I/O接口到存储器 274
12.6.3 存储器到I/O接口 274
12.6.4 存储器到存储器 274
12.6.5 S3C2410A的DMA控制器 274
12.6.6 编程举例 276
12.7 实时时钟的工作原理与编程示例 282
12.7.1 实时时钟的工作原理 282
12.7.2 S3C2410A实时时钟寄存器介绍 283
12.7.3 实时时钟计数器 283
12.7.4 告警控制寄存器 284
12.7.5 告警时间寄存器 285
12.8 RTC循环复位寄存器 285
12.8.1 实时时钟寄存器 285
12.8.2 S3C2410A实时时钟编程举例 286
12.9 看门狗的工作原理与编程示例 288
12.9.1 看门狗的工作原理 288
12.9.2 S3C2410A的看门狗定时器寄存器 289
12.9.3 看门狗编程举例 290
12.10 I2C工作原理与编程示例 292
12.10.1 I2C工作原理 292
12.10.2 I2C总线的基本结构 292
12.10.3 双向传输的接口特性 292
12.10.4 I2C总线上的时钟信号 293
12.10.5 数据的传送 293
12.10.6 总线竞争的仲裁 294
12.10.7 I2C总线的一次典型工作流程 295
12.10.8 S3C2410A的I2C寄存器 295
12.10.9 I2C总线控制寄存器 296
12.10.10 I2C总线控制/状态寄存器 296
12.10.11 I2C总线地址寄存器 297
12.10.12 移位数据寄存器 297
12.10.13 I2C编程举例 298
12.11 本章小结 302
12.12 本章习题 302
第13章 通用I/O口的应用:跑马灯实验 303
13.1 实验目的 304
13.2 实验设备 304
13.3 实验原理 304
13.3.1 S3C2440A的多功能I/O口 304
13.3.2 端口选择 309
13.3.3 端口控制寄存器 309
13.4 实验步骤 311
13.4.1 设置寄存器 311
13.4.2 跑马灯的实现 311
13.4.3 编译工程 312
13.4.4 建立实验环境 312
13.4.5 下载程序运行 312
13.5 实验思考 313
第14章 中断处理程序设计 315
14.1 实验目的 316
14.2 实验设备 316
14.3 实验原理 316
14.3.1 概述 316
14.3.2 中断模式 316
14.3.3 PSR的F位和I位 316
14.3.4 Pending寄存器 317
14.3.5 INTMSK中断屏蔽寄存器 317
14.3.6 中断源 317
14.3.7 中断优先级产生模块 319
14.3.8 控制中断的寄存器 319
14.4 实验步骤 320
14.4.1 设置I/O口 320
14.4.2 中断寄存器设置 321
14.4.3 中断服务程序的编写 321
14.4.4 编译工程 322
14.4.5 建立实验环境 323
14.4.6 下载程序运行 323
14.5 实验思考 323
第15章 定时器的应用 325
15.1 实验目的 326
15.2 实验设备 326
15.3 实验原理 326
15.3.1 概述 326
15.3.2 定时器操作 327
15.3.3 定时器寄存器 331
15.4 实验步骤 331
15.4.1 打开定时器中断 331
15.4.2 设置定时器中断服务程序的入口地址 332
15.4.3 设置定时器寄存器并启动定时器 332
15.4.4 定时器中断服务子程序 332
15.4.5 判断定时器中断情况 333
15.4.6 编译工程 334
15.4.7 建立实验环境 334
15.4.8 下载程序并运行 334
15.5 实验思考 335
第16章 ADC接口的应用 337
16.1 实验目的 338
16.2 实验设备 338
16.3 实验原理 338
16.3.1 概述 338
16.3.2 S3C2440A具备的ADC 338
16.3.3 ADC转换时间的计算 339
16.3.4 ADC分辨率的计算 339
16.3.5 采样保持器 339
16.3.6 ADC的相关寄存器 340
16.4 实验步骤 340
16.4.1 硬件连接 340
16.4.2 得到预分频值 340
16.4.3 读取A/D转换数值子程序 340
16.4.4 编译工程 341
16.4.5 建立实验环境 341
16.4.6 下载程序并运行 342
16.5 实验思考 342
第17章 LCD接口的编程 343
17.1 实验目的 344
17.2 实验设备 344
17.3 实验原理 344
17.3.1 概述 344
17.3.2 S3C2440A的内部LCD控制器介绍 344
17.3.3 LCD控制器的外部接口信号 345
17.3.4 LCD控制器的操作 346
17.3.5 LCD控制器专用寄存器 348
17.4 实验步骤 352
17.4.1 I/O口LCD功能设置 352
17.4.2 LCD初始化程序 352
17.4.3 LCD测试程序 353
17.4.4 编译工程 354
17.4.5 建立实验环境 355
17.4.6 下载程序并运行 355
17.5 实验思考 355
第18章 触摸屏的应用 357
18.1 实验目的 358
18.2 实验设备 358
18.3 实验原理 358
18.3.1 概述 358
18.3.2 触摸屏的基本原理 358
18.3.3 触摸屏的相关寄存器 359
18.4 实验步骤 361
18.4.1 硬件连接 361
18.4.2 寄存器的设置 362
18.4.3 触摸屏中断服务程序 362
18.4.4 编译工程 363
18.4.5 建立实验环境 363
18.4.6 下载程序并运行 364
18.5 实验思考 364
第19章 I2C接口的编程 365
19.1 实验目的 366
19.2 实验设备 366
19.3 实验原理 366
19.3.1 概述 366
19.3.2 I2C总线通用传输格式 366
19.3.3 S3C2440A的12C接口 368
19.4 实验步骤 371
19.4.1 硬件连接 371
19.4.2 I/O端口I2C功能设置 372
19.4.3 中断使能 372
19.4.4 初始化I2C接口 372
19.4.5 写入数据子程序 372
19.4.6 读出数据子程序 373
19.4.7 中断处理子程序 374
19.4.8 编译工程 375
19.4.9 建立实验环境 375
19.4.10 下载程序运行 375
19.5 实验思考 376
第20章 UART异步串行接口的应用 377
20.1 实验目的 378
20.2 实验设备 378
20.3 实验原理 378
20.3.1 概述 378
20.3.2 UART操作 379
20.3.3 UART寄存器 382
20.4 实验步骤 383
20.4.1 电路连接和I/O口设置 383
20.4.2 UART的初始化 384
20.4.3 串口0发送中断测试 385
20.4.4 串口0接收中断测试 385
20.4.5 编译工程 386
20.4.6 建立实验环境 386
20.4.7 下载程序运行 386
20.5 实验思考 387
第21章 CAN总线通信实验 389
21.1 实验目的 390
21.2 实验设备 390
21.3 实验原理 390
21.3.1 概述 390
21.3.2 CAN总线的技术特点 390
21.3.3 CAN的分层结构 391
21.4 实验步骤 392
21.4.1 电路连接 392
21.4.2 初始化函数 392
21.4.3 MCP2510写函数 393
21.4.4 MCP2510读函数 393
21.4.5 指定地址寄存器修改函数 394
21.4.6 CAN通信主体函数 394
21.4.7 编译工程 395
21.4.8 建立实验环境 395
21.4.9 下载程序并运行 395
21.5 实验思考 396
第五篇 嵌入式系统启动应用分析与设计 399
第22章 ARM系统启动应用分析与设计 399
22.1 Cortex-M3-STM32启动代码分析 400
22.1.1 STM32概述 400
22.1.2 启动代码分析 400
22.2 ARM9-S3C2440-U-Boot移植开发 408
22.2.1 U-Boot工程简介 408
22.2.2 目录结构 409
22.2.3 Makefile分析 410
22.2.4 流程分析 410
22.2.5 配置编译 411
22.2.6 移植开发 414
22.2.7 调试测试 418
22.2.8 常用命令 418
22.2.9 环境变量 420
22.3 ARM-Cortex-A8-S5PV210-uboot分析 421
22.3.1 源码目录结构 421
22.3.2 启动代码start.s分析 423
22.3.3 启动代码lowlevel.s分析 439
22.3.4 启动代码汇编部分总结 453
22.3.5 硬件启动过程 454
22.3.6 内存分配 455
22.4 ARM-Cortex-A9-多核介绍 456
22.4.1 Samsung Exynos 4412 456
22.4.2 Nvidia Tegra 2介绍 457
22.4.3 ARM-Cortex-A9多核启动流程 457
22.4.4 Linux Kemel对多核心的支持 457
22.4.5 软件识别目前所在的处理器 458
22.4.6 多核心的开机 458
22.4.7 Boot Rom 458
22.4.8 多核U-Boot 459
22.5 本章小结 471
22.6 本章习题 471
第六篇 综合项目篇 475
第23章 基于ARM的嵌入式工业控制系统设计 475
23.1 总体需求 476
23.1.1 部署结构 476
23.1.2 主机业务需求 477
23.1.3 终端业务需求 478
23.2 主机设计 479
23.2.1 主机工作流程 480
23.2.2 设置终端模块 480
23.2.3 打开端口模块 481
23.2.4 相关业务模块 482
23.2.5 主机相关任务描述 483
23.2.6 相关定时器举例 486
23.3 通信协议分层 486
23.3.1 物理层 486
23.3.2 数据链路层 486
23.3.3 应用层 488
23.4 PDU集 490
23.4.1 主机召唤终端状态 491
23.4.2 终端返回本机状态 491
23.4.3 主机设置终端状态 492
23.4.4 终端返回设置后的结果 492
23.4.5 终端发送自身状态 492
23.4.6 主机确认收到终端返回 493
23.4.7 主机获得终端的设置值 493
23.4.8 终端返回设置后的结果 494
23.4.9 确认网络状态 494
23.4.10 确认网络状态返回 495
23.5 应用层异常控制 495
23.6 大小端控制 495
23.7 数据字典 496
23.8 项目总结 496
23.9 本章小结 497
23.10 本章习题 497