基于ARM的AD采集Word文件下载.docx
- 文档编号:18893753
- 上传时间:2023-01-02
- 格式:DOCX
- 页数:14
- 大小:255.78KB
基于ARM的AD采集Word文件下载.docx
《基于ARM的AD采集Word文件下载.docx》由会员分享,可在线阅读,更多相关《基于ARM的AD采集Word文件下载.docx(14页珍藏版)》请在冰豆网上搜索。
(1)掌握构建嵌入式系统软硬件平台的基本技能;
(2)具备基本嵌入式系统下C语言编程能力及操作系统基本调试的能力;
(3)了解应用嵌入式系统技术开发一套嵌入式系统设备的方法。
1.2实验设备及工具
硬件:
ARM嵌入式开发板、用于ARM的JTAG仿真器、四个电位器、盘线,插针等。
软件:
计算机操作系统WinXP、ARM集成开发环境、仿真器驱动程序、超级终端通讯程序。
1.3设计分析
1.3.1设计要求
(1)查阅相关文献资料,熟悉所选ARM芯片
(2)系统硬件设计,熟悉AD转换原理及过程ARM芯片的硬件接口实现
(3)能进行最少4路信号采集
1.3.2设计思路
本课题设计是根据我校老师自主研制的ARM实验板进行设计开发的。
用KeiluVision4软件对各个模块进行程序编写并进行调试,当程序调试无误后,将程序下载到ARM实验板上,经ARM芯片的AD转换器,经过模数转换器,将输入的模拟信号(电压)转换成数字信号,再通过串口助手显示出所采集到的数据
2系统组成和STM32控制器概述
2.1AD采集系统组成
如图1所示,系统功能的实现流程是:
电源开启后,系统功能初始化,开始采集外部由电位器分压得到的电压信号。
其电压信号经过预处理后通过设置的I/O口与芯片的A/D转换接口相连接。
经过A/D转换后,由芯片内部数据传输模块(DMA)把数据传给CPU进行相关的处理,得出结论,输出相应的控制信号。
控制芯片
图1系统框图
2.2STM32微控制器概述
2.2.1STM32微处理器概述
STM32系列32位闪存微控制器使用来自ARM公司具有突破性的Cortex-M3内核,该内核是专门设计与满足集高性能、低功耗、实时应用、具有竞争性价格于一体的嵌入式领域的要求。
Cortex-M3在系统结构上的增强,让STM32受益无穷;
Tumb-2指令集带来了更高的效率和更强的性能,既获得了传统32位代码的性能,又有16位的高代码密度;
通过紧藕合的嵌套矢量中断控制器,对中断事件的相应比以往更迅速,所有的这些又都融入了业界领先的功耗水平。
2.2.2Cortex-M3内核
Cortex-M3内核为ARMv7架构,是建立在一个高性能哈佛结构的三级流水线基础上的,可满足事件驱动的应用要求。
通过广泛采用时钟选通等技术,改进了每个时钟周期的性能,包括单周期的32x32乘法和硬件除法,获得了优异的能效比。
另外通过一个基于堆栈的异常模式的实现,显著地缩小了内核的物理尺寸。
Cortex-M3内核指令和数据各使用一条总线,如图2所示。
与Cortex-M3不同,ARM7系列处理器使用冯·
诺依曼(VonNeumann)架构,指令和数据共用信号总线以及存储器。
由于指令和数据可以从存储器中同时读取,所以Cortex-M3处理器对多个操作并行执行,加快了应用程序的执行速度。
内核流水线分3个阶段:
取指、译码和执行。
当遇到分支指令时,译码阶段也包含预测的指令取指,这提高了执行的速度。
处理器在译码阶段期间自行对分支目的地指令进行取指。
在稍后的执行过程中,处理完分支指令后便知道下一条要执行的指令。
如果分支不跳转,那么紧跟着的下一条指令随时可供使用。
如果分支跳转,那么在跳转的同时分支指令可供使用,空闲时间限制为一个周期。
图2Cortex-M3内核结构图
Cortex-M3内核包含一个适用于传统Thumb和新型Thumb-2指令的译码器、一个支持硬件乘法和硬件除法的先进ALU、控制逻辑和用于连接处理器其他部件的接口。
Cortex-M3处理器是一个32位处理器,带有32位宽的数据路径,寄存器库和存储器接口。
其中有13个通用寄存器,两个堆栈指针,一个链接寄存器,一程序计数器和一系列包含编程状态寄存器的特殊寄存器。
Cortex-M3处理器支持两种工作模式:
线程(Thread)和处理器(Handler);
两个等级的访问形式:
有特权或无特权。
在不牺牲应用程序安全的前提下实现了对复杂的开放式系统的执行。
无特权代码的执行限制或拒绝对某些资源的访问,如某个指令或指定的存储器位置。
Thread是常用的工作模式,它同时支持享有特权的代码以及没有特权的代码。
当异常发生时,进入Handler模式,在该模式中所有代码都享有特权。
此外,所有操作均根据以下两种工作状态进行分类,Thumb代表常规执行操作,Debug代表调试操作。
借助bit-banding技术,Cortex-M3处理器可以在简单系统中直接对数据的单个位进行访问。
存储器映射包含两个位于SRAM的大小均为IMB的bit-band区域和映射到32MB别名区域的外设空间。
在别名区域中,某个地址上的加载/存储操作将直接转化为对被该地址别名的位的操作。
对别名区域中的某个地址进行写操作,如果使其最低有效位置位,那么bit一and位为1,如果使其最低有效位清零,那么bit-band位为零。
读别名后的地址将直接返回适当的bit-band位中的值。
除此之外,该操作为原子位操作,其他总线活动不能对其中断。
2.3内部直接存储寄存器(DMA)
直接存储器存取用来提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。
无须CPU任何干预,通过DMA数据可以快速地移动。
这就节省了CPU的资源来做其他操作。
DMA控制器有7个通道,每个通道专门用来管理来自于一个或多个外设对存储器访问的请求。
还有一个仲裁器来协调各个DMA请求的优先权。
它的主要特性如下:
(1)7个独立的可配置的通道(请求)
(2)每个通道都直接连接专用的硬件DMA请求,每个通道都同样支持软件触
发。
这些功能通过软件来配置。
(3)在七个请求间的优先权可以通过软件编程设置(共有四级:
很高、高、中等
和低),假如在相等优先权时由硬件决定(请求0优先于请求1,依此类推)。
(4)独立的源和目标数据区的传输宽度(字节、半字、全字),模拟打包和拆包
的过程。
(5)支持循环的缓冲器管理
(6)每个通道都有3个事件标志(DMA半传输,DMA传输完成和DMA传输出错),这3个事件标志逻辑或成为一个单独的中断请求。
(7)存储器和存储器间的传输
(8)外设和存储器,存储器和外设的传输
(9)闪存、SRAM、外设的SRAM、APB1和APB2外设均可作为访问的源和目标。
(10)可编程的数据传输数目:
最大为65536
如图3所示:
DMA控制器和Cortex-M3核共享系统数据总线执行直接存储器数据传输。
当CPU和DMA同时访问相同的目标(RAM或外设)时,DMA请求可能会停止CPU访问系统总线达若干个周期,总线仲裁器执行循环调度,以保证CPU至少可以得到一半的系统总线(RAM或外设)带宽。
在发生一个事件后,外设发送一个请求信号到DMA控制器。
DMA控制器根据通道的优先权处理请求。
当DMA控制器开始访问外设的时候,DMA控制器立即发送给外设一个应答信号。
当从DMA控制器得到应答信号时,外设立即释放它的请求。
一旦外设释放了这个请求,DMA控制器同时撤销应答信号。
如果发生更多的请求时,外设可以启动下次处理。
总之,每个DMA传送由3个操作组成:
(1)从外设数据寄存器或者从DMA_CMARx寄存器指定地址的存储器单元执行
加载操作。
(2)存数据到外设数据寄存器或者存数据到DMA_CMARx寄存器指定地址的存储器单元。
(3)执行一次DMA_CNDTRx寄存器的递减操作。
该寄存器包含未完成的操作数目。
图3DMA框图
仲裁器根据通道请求的优先级来启动外设/存储器的访问。
优先权管理分2个阶段:
(1)软件:
每个通道的优先权可以在DMA_CCRx寄存器中设置,有4个等级:
−最高优先级
−高优先级
−中等优先级
−低优先级
(2)硬件:
如果2个请求有相同的软件优先级,则拥有较低编号的通道比拥有
较高编号的通道有较高的优先权。
举个例子,通道2优先于通道4。
2.4模拟/数字转换控制器(ADC)
12位ADC是一种逐次逼近型模拟数字转换器。
它有18个通道,可测量16个外部和2个内部信号源。
各通道的A/D转换可以单次、连续、扫描或间断模式执行。
ADC的结果可以左对齐或右对齐方式存储在16位数据寄存器中。
它的主要特征如下:
(1)12-位分辨率
(2)转换结束,注入转换结束和发生模拟看门狗事件时产生中断
(3)单次和连续转换模式
(4)从通道0到通道n的自动扫描模式
(5)自校准
(6)带内嵌数据一致的数据对齐
(7)通道之间采样间隔可编程
(8)规则转换和注入转换均有外部触发选项
(9)间断模式
(10)双重模式(带2个ADC的器件)
(11)ADC转换时间:
−STM32F103xx增强型产品:
ADC时钟为56MHz时为1μs(ADC时钟为72MHz为1.17μs)
−STM32F101xx基本型产品:
ADC时钟为28MHz时为1μs(ADC时钟为36MHz为1.55μs)
(12)ADC供电要求:
2.4V到3.6V
(13)ADC输入范围:
Vref-≤Vin≤VREF+
(14)规则通道转换期间有DMA请求产生。
S12内置了2组10位/8位的A/D模块:
ATD0和ATD1,共有16个模拟量输入通道,属于逐次逼近型A/D转换器(这个转换过程与用天平称物的原理相似)。
图4A/D模块功能结构图
图4所示的是A/D模块的功能结构,这个功能模块被虚线划分成为图示所示的虚线所隔离的三个部分:
IP总线接口、转换模式控制/寄存器列表,自定义模拟量。
IP总线接口负责该模块与总线的连接,实现A/D模块和通用I/O的目的,还起到分频的作用;
转换模式控制寄存器列表中有控制该模块的所有的寄存器,执行左右对齐运行和连续扫描。
自定义模拟量负责实现模拟量到数字量的转换。
包括了执行一次简单转换所需的模拟量和数字量。
3硬件实现
本设计的基于ARM的多通道AD采集的系统采用“电源部分+ARM核心控制模块”实现所需功能。
其中电源电路由两部分组成:
ARM核心模块电源电路和有电位器提供的可变电源。
其中由ARM核心模块提供的电源电路仅实现对3.3V的电压进行采集,但是在实际的应用中,我们还需要对其他类型的电压进行采集。
怎样才能做到这些呢?
这里就要用到由电位器提供的电压,来实现对其他类型的电压的采集。
其电路原理图如下图所示:
图5AD采集原理图
如图5:
主要由四个电位器提供四路AD数据采集其中四个电位器均采用的是5K的这样如果想要改变某一路的电压只需要调节该路的电位器即可实现。
使用起来相当方便快捷。
4软件实现
本次设计主要采用的是使用DMA来进行ADC操作。
因为ADC规则通道转换的值储存在一个仅有的数据寄存器中,所以当转换多个规则通道时,一定要使用DMA传输,这可以避免了已经存在数据寄存器的数据丢失。
当规则通道的转换结束是产生DMA请求,并将转换的数据从数据存储器中传输到用户指定的目的地址。
利用DMA方式进行AD采集是需要用到的初始化程序包括两部分:
DMA初始化函数和ADC初始化函数。
本系统应用到的库函数资源有:
stm32f10x_adc.c(模拟/数字转换),stm32f10x_dma.c(直接内部数据传输),stm32f10x_exti.c(外部中断管理),stm32f10x_flash.c(芯片内部存储器flash操作函数),stm32f10x_gpio.c(I/O口设置),stm32f10x_lib.c(调试所有外设初始化的函数),stm32f10x_nvic.c(系统中断管理),stm32f10x_rcc.c(单片机时钟管理)。
通过这些资源的相互衔接组合来实现系统数据采集的功能。
下面为程序的流程图:
图6AD采集流程图
5总结
课程设计做到这里也差不多要结束了,这次课程设计总体来说还是有些难度的,课程设计的代码也是相当的长,设计中要实现的现象也有好几个,先前简单的做过一个也是关于ARM的课程设计,然而先前的课程设计是比较基础的要实现的现象也就一两个,单个来说课程设计还是很好做的,不过当这些现象多了的同时还要一起实现的话课程设计就有些难度了,有困难干等着也解决不了,所以在做本次的课程设计之前,我和几个做同样课程那个设计的同学就讨论了一下。
在第一天老师布置完任务之后回来后,我们几个同学就在网上找了相应的资料,再看了相关资料后终于有了明确的思考方向,再次去设计时就顺利多了,虽然在课程设计代码中还有些问题,不过在之后调试中都一一解决了。
最后课程设计也顺利完成了。
通过这次课程设计我懂得了许多,一个人的力量再大也有不够的时候,团结同学合力完成课程设计或是其他的事情往往能起到事半功倍的效果。
同时一个人的基础知识也是相当重要的,有了基础才能走得更远、飞得更高!
参考文献
[1]田泽.嵌入式系统开发与应用教程[M].北京:
北京航空航天大学出版社,2005.3
[2]吴明晖.基于ARM的嵌入式系统开发与应用[M].北京:
人民邮电出版社,2004.
[3]周立功,ARM嵌入式系统基础教程[M].北京:
北京航空航天大学出版社2008
[4]周立功,深入浅出ARM7-LPC213X/214X[M].北京:
北京航空航天大学出版社2006
[5]王田苗,嵌入式系统设计与实例开发[M].北京:
清华大学出版社,2003
附录
AD采集的主程序代码:
#include"
stm32f10x.h"
usart1.h"
tempad.h"
extern__IOuint16_tADC_ConvertedValue[5];
floatADC_ConvertedValueLocal;
voidDelay(__IOu32nCount)
{
for(;
nCount!
=0;
nCount--);
}
intmain(void)
USART1_Config();
Temp_ADC1_Init();
while
(1)
{
inti;
Delay(0xffffee);
printf("
\r\n这是四路AD采集\r\n"
);
for(i=1;
i<
5;
i++)
ADC_ConvertedValueLocal=((float)ADC_ConvertedValue[i])/4096*3.3;
\r\nThecurrentAD[%d]value=%fV\r\n"
i,ADC_ConvertedValueLocal);
}
AD采集配置程序代码:
#include"
#defineADC1_DR_Address((u32)0x4001244C)
__IOu16ADC_ConvertedValue[5];
//__IOu16ADC_ConvertedValueLocal;
staticvoidADC1_GPIO_Config(void)
GPIO_InitTypeDefGPIO_InitStructure;
/********EnableDMAclock*********/
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1,ENABLE);
/*******EnableADC1andGPIOCclock*******/
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1|RCC_APB2Periph_GPIOC|RCC_APB2Periph_GPIOA,ENABLE);
/*******ConfigurePA.01asanaloginput*******/
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AIN;
GPIO_Init(GPIOA,&
GPIO_InitStructure);
/*******ConfigurePA.02asanaloginput*******/
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_2;
/*******ConfigurePA.03asanaloginput*******/
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_3;
/*******ConfigurePA.04asanaloginput*******/
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_4;
staticvoidADC1_Mode_Config(void)
DMA_InitTypeDefDMA_InitStructure;
ADC_InitTypeDefADC_InitStructure;
/*******DMAchannel1configuration*******/
DMA_DeInit(DMA1_Channel1);
DMA_InitStructure.DMA_PeripheralBaseAddr=ADC1_DR_Address;
DMA_InitStructure.DMA_MemoryBaseAddr=(u32)&
ADC_ConvertedValue;
DMA_InitStructure.DMA_DIR=DMA_DIR_PeripheralSRC;
DMA_InitStructure.DMA_BufferSize=5;
DMA_InitStructure.DMA_PeripheralInc=DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc=DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize=DMA_PeripheralDataSize_HalfWord;
//数据宽度为16位
DMA_InitStructure.DMA_MemoryDataSize=DMA_MemoryDataSize_HalfWord;
DMA_InitStructure.DMA_Mode=DMA_Mode_Circular;
DMA_InitStructure.DMA_Priority=DMA_Priority_High;
DMA_InitStructure.DMA_M2M=DMA_M2M_Disable;
DMA_Init(DMA1_Channel1,&
DMA_InitStructure);
/*******EnableDMAchannel1*******/
DMA_Cmd(DMA1_Channel1,ENABLE);
/*******ADC1configuration*******/
ADC_InitStructure.ADC_Mode=ADC_Mode_Independent;
ADC_InitStructure.ADC_ScanConvMode=ENABLE;
ADC_InitStructure.ADC_ExternalTrigConv=ADC_ExternalTrigConv_None;
ADC_InitStructure.ADC_DataAlign=ADC_DataAlign_Right;
ADC_InitStructure.ADC_NbrOfChannel=5;
ADC_Init(ADC1,&
ADC_InitStructure);
RCC_ADCCLKConfig(RCC_PCLK2_Div8);
/*******ADC1regularchannel16configuration*******/ADC_RegularChannelConfig(ADC1,ADC_Channel_16,1,ADC_SampleTime_55Cycles5);
ADC_RegularChannelConfig(ADC1,ADC_Channel_1,2,ADC_SampleTime_55Cycles5);
ADC_RegularChannelConfig(ADC1,ADC_Channel_2,3,ADC_SampleTime_55Cycles5);
ADC_RegularChannelConfig(ADC1,ADC_Channel_3,4,ADC_SampleTime_55Cycles5);
ADC_RegularChannelConfig(ADC1,ADC_Channel_4,5,ADC_SampleTime_55Cycles5);
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 ARM AD 采集