网站首页  软件下载  游戏下载  翻译软件  电子书下载  电影下载  电视剧下载  教程攻略

请输入您要查询的图书:

 

书名 跟工程师学嵌入式开发
分类 科学技术-自然科学-物理
作者 谭贵,易确,熊立宇编
出版社 电子工业出版社
下载
简介
作者简介
谭贵,男,北京大学计算机科学与技术学士毕业,现供职于富士康科技集团,热爱嵌入式开发技术,精通C、Java语言,Tcl和bash脚本应用;熟悉从MCU裸板外设驱动开发和uCosII实时操作系统的移植,以及基于Linux系统的嵌入式应用开发。
目录
第1章开发利器:STM32库和MDKKeil1
1.1学习启航:闪烁的跑马灯1
1.1.1实验结果呈现1
1.1.2实验分析2
1.1.3配置GPIO引脚5
1.1.4实验控制逻辑6
1.2STM32库结构和CMSIS标准8
1.2.1STM32库层次结构9
1.2.2CMSIS层次结构9
1.2.3STM32库结构中的文件关系10
1.2.4STM32库函数命名规则13
1.2.5STM32库常见的几个状态类型13
1.3工程开发环境设置14
1.3.1有关MDK14
1.3.2使用MDK建立工程的步骤15
第2章STM32体系结构25
2.1总线与通信接口25
2.1.1总线组成25
2.1.2重要的总线术语26
2.2STM32功能框架27
2.2.1系统组成27
2.2.2总线单元及挂接设备28
2.3STM32存储器映射29
2.3.1独立编址30
2.3.2统一编址(存储器映像编址)31
2.3.3CM3外设地址空间映射32
2.3.4地址空间映射详解34
2.4STM32时钟结构39
2.4.1STM32F103ZET6的时钟树39
2.4.2时钟树二级框架40
2.4.3时钟启用过程41
2.5系统时钟树与地址空间映射的关系43
第3章STM32系统启动过程分析44
3.1CM3的复位序列44
3.1.1堆栈45
3.1.2向量表47
3.2STM32启动代码分析49
3.3STM32系统时钟初始化52
3.3.1时钟源的选择52
3.3.2系统时钟设置56
3.4程序运行环境初始化函数__main()60
3.4.1回顾编译和链接过程60
3.4.2映像文件的组成61
3.4.3映像的加载过程63
3.4.4由MDK集成环境自动生成的分散加载文件65
3.4.5_main()函数的作用66
第4章通用GPIO操作68
4.1实验结果预览:LED跑马灯68
4.2GPIO基本知识68
4.2.1GPIO分组管理及其引脚69
4.2.2GPIO工作模式及其配置69
4.2.3GPIO引脚的写入和读出71
4.3实验代码解析74
4.3.1实验现象原理分析74
4.3.2源代码分析78
4.4创建工程81
4.4.1建立工程目录结构81
4.4.2导入源代码文件81
4.4.3编译执行82
4.5编译调试82
4.5.1调试方法82
4.5.2栈和变量观察窗口83
4.5.3运行程序并调试:一个函数一个断点84
4.5.4运行程序并调试:多个函数多个断点86
第5章外部中断EXTI操作90
5.1实验结果预览:LED跑马灯_中断控制90
5.2异常与中断91
5.2.1Cortex-M3的异常向量91
5.2.2异常向量表92
5.3NVIC与中断控制93
5.3.1NVIC简述93
5.3.2NVIC与外部中断93
5.3.3NVIC中断的优先级94
5.3.4NVIC初始化95
5.4EXTI基本知识97
5.4.1EXTI简介97
5.4.2EXTI控制器组成结构97
5.4.3GPIO引脚到EXTI_Line的映射100
5.4.4EXTI_Line到NVIC的映射102
5.5实验代码解析103
5.5.1工程源码的逻辑结构103
5.5.2实验代码软硬件原理104
5.5.3实验代码分析107
5.6创建工程109
5.6.1建立工程目录结构109
5.6.2导入源代码文件109
5.6.3编译执行110
5.7编译调试111
5.7.1打开内存窗口111
5.7.2设置断点111
5.7.3运行程序并调试112
第6章USART接口115
6.1实验结果预览115
6.1.1实验准备工作115
6.1.2实验现象描述116
6.2USART基本知识117
6.2.1串行异步通信协议117
6.2.2USART与接口标准RS-232118
6.3STM32USART结构119
6.3.1USART工作模式119
6.3.2精简的USART结构119
6.3.3USART单字节收发过程120
6.4USART寄存器位功能定义121
6.4.1状态寄存器(USART_SR)121
6.4.2数据寄存器(USART_DR)122
6.4.3控制寄存器1(USART_CR1)122
6.4.4控制寄存器2(USART_CR2)123
6.4.5控制寄存器3(USART_CR3)123
6.4.6分数波特率寄存器USART_BRR124
6.4.7USART模块寄存器组125
6.4.8USART模块初始化函数126
6.4.9USART常用函数功能说明127
6.5USART实验代码分析128
6.5.1实验电路(硬件连接关系)128
6.5.2工程源代码文件层次结构130
6.5.3应用层(主程序控制逻辑)131
6.5.4用户驱动层133
6.5.5函数printf()重定向135
6.6创建工程135
6.6.1建立工程目录结构135
6.6.2创建文件组和导入源文件136
6.6.3编译执行137
第7章USART综合应用:命令行外壳程序Shell138
7.1实验结果预览138
7.2基于USART的I/O函数139
7.2.1字符及字符串获取函数:xgetc()和xgets()139
7.2.2字符及字符串打印函数:xputc()和xputs()141
7.3可变参数输出函数xprintf()142
7.3.1可变参数142
7.3.2可变参数宏的使用与作用143
7.3.3用可变参数宏实现自己的格式化输出函数xprintf()144
7.4Shell外壳145
7.4.1Shell命令管理结构146
7.4.2Shell命令解析过程147
7.4.3命令函数之参数解析150
7.5建立工程,编译和运行151
7.5.1创建和配置工程151
7.5.2编译执行153
第8章I2C接口154
8.1实验结果预览:轮询写入/读出EEPROM数据154
8.2I2C总线协议155
8.2.1总线特点155
8.2.2I2C应用结构155
8.2.3总线信号时序分析156
8.3STM32I2C模块158
8.3.1I2C组成框图158
8.3.2I2C主模式工作流程159
8.3.3I2C中断及DMA请求161
8.4I2CEEPROM读写示例及分析162
8.4.1示例电路连接162
8.4.2app.c文件中的main()函数163
8.4.3eeprom.h文件166
8.4.4eeprom.c文件167
8.4.5shell.c文件174
8.5建立工程,编译及运行175
8.5.1创建和配置工程175
8.5.2编译执行176
第9章DMA接口177
9.1实验结果预览177
9.2通用DMA的作用及特征178
9.3STM32DMA基本知识178
9.3.1DMA与系统其他模块关系图178
9.3.2STM32DMA组成179
9.4实验示例分析183
9.4.1main.c文件中的main()函数184
9.4.2USART1的初始化184
9.4.3DMA通道中断处理函数189
9.4.4sysTick中断处理函数190
9.4.5DMA通道配置的其他寄存器191
9.4.6DMA用户测试命令及其执行函数192
9.5建立工程,编译和执行193
9.5.1建立以下工程文件夹194
9.5.2创建文件组和导入源文件194
9.5.3编译运行194
第10章实时时钟RTC195
10.1实验结果预览195
10.2STM32RTC模块196
10.2.1STM32后备供电区域196
10.2.2RTC组成199
10.3RTC实验设计与源码分析204
10.3.1硬件连接和GPIO资源204
10.3.2实验源代码逻辑结构204
10.3.3源代码分析205
10.4建立工程,编译和执行212
10.4.1建立以下工程文件夹212
10.4.2创建文件组和导入源文件212
10.4.3编译执行213
第11章系统定时器SysTick214
11.1SysTick简述214
11.2SysTick工作过程214
11.3SysTick寄存器位功能定义215
11.3.1控制和状态寄存器:STK_CTRL215
11.3.2重载寄存器:STK_LOAD216
11.3.3当前计数值寄存器:STK_VAL217
11.3.4校正寄存器:STK_CALIB217
11.3.5SysTick模块寄存器组217
11.3.6配置SysTick定时器218
11.4基于SysTick的延时函数代码分析220
11.4.1实现原理220
11.4.2实现代码分析220
11.4.3基于SysTick延时的LED闪烁命令223
11.5建立工程,编译和执行224
11.5.1建立以下工程文件夹224
11.5.2创建文件组和导入源文件224
11.5.3编译运行226
第12章SPI接口227
12.1实验现象预览:轮询写入/读出SPIFlash数据227
12.2SPI总线协议228
12.2.1总线信号及其应用结构228
12.2.2SPI内部结构与工作原理229
12.3STM32SPI模块231
12.3.1SPI组成框图231
12.3.2STM32SPI主模式数据收发过程232
12.3.3SPI中断及DMA请求234
12.4W25Q128FV规格说明234
12.4.1W25Q128FV状态和控制管理235
12.4.2W25Q128FV常用指令236
12.5程序入口与SPI初始化代码237
12.5.1实验硬件资源237
12.5.2工程入口文件main.c238
12.5.3spiflash.c文件中的spiFlash_Init()函数239
12.6SPIFlash测试代码分析243
12.6.1spiflash.c文件中的SPIFlash测试函数spiTest()244
12.6.2SPIFlashID读取函数sFLASH_readID()245
12.6.3扇区擦除函数sFLASH_eraseSector()246
12.6.4Flash页写函数sFLASH_writePage()246
12.6.5Flash读函数sFLASH_readBuffer()247
12.6.6Flash字节发送函数sFLASH_SendByte()248
12.7向Shell添加SPI测试指令spitest249
12.8建立工程,编译和执行250
12.8.1建立以下工程文件夹250
12.8.2创建文件组和导入源文件250
12.8.3编译运行252
第13章网络接口:以太网253
13.1网络体系结构简介253
13.1.1三种网络模型253
13.1.2以太网标准(Ethernet)256
13.2ENC28J60知识257
13.2.1ENC28J60概述257
13.2.2控制寄存器259
13.2.3以太网缓冲器260
13.2.4PHY寄存器261
13.2.5ENC28J60SPI指令集261
13.2.6ENC28J60初始化263
13.2.7使用ENC28J60收发数据268
13.2.8ENC28J60驱动代码总结272
13.3uIP协议栈简介274
13.3.1uIP特性274
13.3.2uIP应用接口275
13.3.3uIP的初始化及配置函数277
13.3.4uIP的主程序循环277
13.4uIP移植分析279
13.4.1下载uIP1.0版源码文件279
13.4.2理解两个中间层文件与应用层和协议层之间的关系280
13.4.3添加uIP协议栈后的工程文件组285
第14章综合示例:基于uIP的Telnet服务286
14.1实验现象预览286
14.2Telnet远程登录协议287
14.2.1Telnet概述287
14.2.2Telnet协议主要技术288
14.2.3Telnet命令288
14.3Telnetd服务框架及实现290
14.3.1本实验Telnetd服务框架290
14.3.2Telnetd服务框架的实现291
14.4上层应用与uIP协议的接口:telnetd_appcall()304
14.5建立工程,编译和运行309
14.5.1创建和配置工程309
14.5.2编译执行311
第15章SDIO总线协议与SD卡操作312
15.1SD卡简介312
15.1.1SD卡家族312
15.1.2SD卡引脚功能定义313
15.1.3SD卡内部组成314
15.1.4SD卡容量规格315
15.1.5SDIO接口规范和总线应用拓扑315
15.2SD协议316
15.2.1工作模式与状态316
15.2.2命令和响应格式316
15.2.3卡识别模式317
15.2.4数据传输模式320
15.3STM32SDIO控制器322
15.3.1控制器总体结构描述322
15.3.2SDIO适配器模块323
15.3.3SDIOAHB接口325
15.4工程入口及配置326
15.4.1实验硬件资源326
15.4.2工程入口文件main.c327
15.5SDIO初始化328
15.5.1SD卡上电初始化函数SD_PowerON()330
15.5.2SD卡规格信息获取函数SD_InitializeCards()336
15.6SDIO卡测试代码分析339
15.6.1块擦除340
15.6.2多块写342
15.6.3多块读345
15.7建立工程,编译和运行348
15.7.1建立以下工程文件夹348
15.7.2创建文件组和导入源文件348
15.7.3编译执行349
第16章移植文件系统FatFs350
16.1实验现象预览:基于Shell的文件系统命令350
16.2FatFs文件系统351
16.2.1FatFs特点351
16.2.2FatFs在设备系统中的层次与接口351
16.3移植FatFs文件系统352
16.3.1FatFs源代码结构352
16.3.2基于FatFs应用的常用数据类型说明353
16.3.3FatFs的移植355
16.4FatFs文件系统应用示例分析357
16.4.1工程源代码逻辑357
16.4.2工程源代码分析358
16.5建立工程,编译和运行363
16.5.1创建和配置工程363
16.5.2编译执行364
第17章无线接入:Wi-Fi模块ESP8266应用365
17.1无线技术标准:IEEE802.11365
17.1.1IEEE802.11简介365
17.1.2无线局域网的组网拓扑366
17.1.3无线接入过程的三个阶段367
17.2ESP-WROOM-02模组368
17.2.1ESP-WROOM-02性能参数368
17.2.2ESP-WROOM-02与主机系统的电路连接369
17.3ESP-WROOM-02指令集370
17.3.1ESP8266AT常用指令370
17.3.2使用ESP-WROOM-02进行真实通信373
17.4封装ESP-WROOM-02的配置函数375
17.4.1ESP-WROOM-02的初始化函数375
17.4.2ESP-WROOM-02的配置函数377
17.4.3优化USART接收缓存的数据结构379
17.4.4ESP-WROOM-02的Shell操作命令381
17.5建立工程,编译和运行384
17.5.1工程程序文件384
17.5.2创建和配置工程384
17.5.3编译执行385
第18章移植μC/OS-III操作系统387
18.1μC/OS-III基础387
18.1.1μC/OS-III简介387
18.1.2μC/OS-III内核组成架构388
18.2μC/OS-III任务基础390
18.2.1任务状态390
18.2.2任务控制块和就绪任务表391
18.2.3创建任务391
18.2.4任务同步与通信393
18.3μC/OS-III的信号量393
18.3.1信号量分类及其应用393
18.3.2信号量工作方式394
18.3.3信号量应用操作步骤396
18.4μC/OS-III的消息队列396
18.4.1消息队列工作模型397
18.4.2消息队列应用操作步骤397
18.5μC/OS-III的事件标志组398
18.5.1事件标志组工作模型398
18.5.2事件标志组应用操作步骤399
18.6信号量、消息队列和事件标志组综合示例399
18.6.1综合示例任务关系图400
18.6.2任务代码头文件task.h400
18.6.3任务代码C文件task.c402
18.6.4中断异常处理文件stm32f10x_it.c409
18.7μC/OS-III移植410
18.7.1μC/OS-III源码组织架构410
18.7.2简化μC/OS-III源码组织架构411
18.7.3建立基于μC/OS-III的工程412
18.7.4μC/OS-III综合示例运行效果414
第19章基于μC/OS-III的信息系统415
19.1系统功能描述415
19.1.1系统任务划分415
19.1.2系统实际运行效果415
19.2系统任务设计分析417
19.2.1Shell任务417
19.2.2LED灯闪烁任务420
19.2.3事件监测任务420
19.2.4系统统计任务422
19.2.5无线通信处理任务425
19.3工程源代码(文件)整合428
19.3.1主文件main.c428
19.3.2任务头文件task.h428
19.3.3includes.h文件429
19.3.4任务实现文件task.c430
19.4建立工程,编译和运行430
19.4.1建立工程源代码结构430
19.4.2建立文件组,导入源文件430
19.4.3编译执行431
参考文献432
内容推荐
本书主要基于STM32F103ZET6处理器,根据当前基于MCU的嵌入式技术实际应用需求,合理选择了多种常用重要的外设接口,如USART、SPI、I2C、FSCM、SDIO总线、以太网等,结合丰富的实例及其程序代码,由浅入深、系统全面地介绍嵌入式系统的底层工作原理。在此过程中,通过穿插多
随便看

 

霍普软件下载网电子书栏目提供海量电子书在线免费阅读及下载。

 

Copyright © 2002-2024 101bt.net All Rights Reserved
更新时间:2025/1/19 14:28:46