STM32F4入手调试USART,ADC-DMA

发布者:电子创意达人最新更新时间:2016-10-08 来源: eefocus关键字:STM32F4  USART  ADC-DMA 手机看文章 扫描二维码
随时随地手机看文章
在F4-Discovery上调试串口,板上无串口接口芯片,需外接电平转换芯片和串口接口,通过插针引线连接两块电路板,板上3.3V供电180mA不足以支持MAX3232工作,故用usb提供的+5V来为其供电。STM32F405xx/STM32F407xx手册里里写道USART1的Pin map: Tx-PA9;RX-PA10。参考IAP的示例,昨天搞了一晚上无论如何都没有输出,很是奇怪。一直以为初始化不对。今天早晨发现手册Page56中Table7. Alternate function mapping中USART1_TX/USART1_RX映射到PB6/PB7。然后做了如下的初始化,串口的引脚跳到PB6、PB7,果然有输出。那么既然管脚map上首推的映射是PA9/PA10那么为什么没有输出呢,而且用示波器测试一直为高电平?原来Discovery的试验板将PA9连接到usb的vbus供电上了。

如下STM32F4xxxx的USART初始化。

void    USART1_AF_Config(void)

{

  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE);

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);

  /* Connect PXx to USARTx_Tx*/

  GPIO_PinAFConfig(GPIOB, GPIO_PinSource6, GPIO_AF_USART1);

  /* Connect PXx to USARTx_Rx*/

  GPIO_PinAFConfig(GPIOB, GPIO_PinSource7, GPIO_AF_USART1);

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6;//TX

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;

  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;

  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;

  GPIO_Init(GPIOB, &GPIO_InitStructure);

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;//RX

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;

  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

  GPIO_Init(GPIOB, &GPIO_InitStructure);

    /* USARTx configured as follow:

        - BaudRate = 115200 baud

        - Word Length = 8 Bits

        - One Stop Bit

        - No parity

        - Hardware flow control disabled (RTS and CTS signals)

        - Receive and transmit enabled  */

  USART_InitStructure.USART_BaudRate = 115200;

  USART_InitStructure.USART_WordLength = USART_WordLength_8b;

  USART_InitStructure.USART_StopBits = USART_StopBits_1;

  USART_InitStructure.USART_Parity = USART_Parity_No;

  USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;

  USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;

  USART_Init(USART1, &USART_InitStructure);

  USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;

  USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;

  USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;

  USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;

  USART_Init(USART1, &USART_InitStructure);

  USART_ClockInit(USART1, &USART_ClockInitStructure);

  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);

  NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;

  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;

  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;

  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;

  NVIC_Init(&NVIC_InitStructure);

  USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);

  /* Enable USART */

  USART_Cmd(USART1, ENABLE);

  BSP_USART1_Init();

}

 

使用带参数的USART Printf:

#define     BSP_USART1_TX_FIFO_SIZE             1024

#define     BSP_USART1_RX_FIFO_SIZE             128

void BSP_USART1_Init(void)

{

         kfifo_alloc(&usart1_tx_fifo, BSP_USART1_TX_FIFO_SIZE);

         kfifo_alloc(&usart1_rx_fifo, BSP_USART1_RX_FIFO_SIZE);

 

unsigned int BSP_USART1_Write(char* data, unsigned int len)

{

         USART_ITConfig(USART1, USART_IT_TXE, DISABLE);

         len = kfifo_in(&usart1_tx_fifo, (unsigned char*)data, len);

         USART_ITConfig(USART1, USART_IT_TXE, ENABLE);

         return len;

}

 

unsigned int BSP_USART1_Read(char* data, unsigned int len)

{

         len = kfifo_out(&usart1_rx_fifo, (unsigned char*)data, len);

         return len;

}

 

unsigned int BSP_USART1_Printf(char* fmt, ...)

{

         va_list args;

         unsigned int len;

         char *buf = malloc(512);

         va_start(args, fmt);

         vsprintf(buf, fmt, args);

         va_end(args);

         len = BSP_USART1_Write(buf, strlen(buf));

         free(buf);

         return len;

}

 

Stm32f4xx_it.c中isr添加:

#include

#include

#include

 

extern  struct kfifo usart1_tx_fifo;

extern  struct kfifo usart1_rx_fifo;

void  USART1_IRQHandler(void)

{

         uint8_t chr;

         if(USART_GetITStatus(USART1, USART_IT_RXNE))

         {

                   chr = USART_ReceiveData(USART1);

                   kfifo_in(&usart1_rx_fifo, &chr, 1);

         }

         if(USART_GetITStatus(USART1, USART_IT_TXE))

         {

                   USART_ClearITPendingBit(USART1, USART_IT_TXE);

                   if(kfifo_out(&usart1_tx_fifo, &chr, 1))

                            USART_SendData(USART1, chr);

                   else

                            USART_ITConfig(USART1, USART_IT_TXE, DISABLE);

         }

}

主函数调用,在ADC3_DMA示例上进行USART1的添加和使用,需要注意的是用fifo时发送和接收占用了1K多的内存还有USART1_Printf也使用了0.5K的内存,所以需要将heap的容量增大,改到0x800就够。

int main(void)

{  USART1_AF_Config();

  ADC3_CH12_DMA_Config();

  /* Start ADC3 Software Conversion */

  ADC_SoftwareStartConv(ADC3);

  while (1)

  {

  /* convert the ADC value (from 0 to 0xFFF) to a voltage value (from 0V to 3.3V)*/

    ADC3ConvertedVoltage = ADC3ConvertedValue *3300/0xFFF;

    BSP_USART1_Printf("ADCdata: %d\r\n",ADC3ConvertedVoltage);

    Delay(0x3FFFFF);

    BSP_USART1_Printf("%s\r\n",dispstr);

  }

}

STM32F4的DMA channel map也由原来F1的2维DMAx_Channely变成3维DMA_Channelx_DMAy_Streamz,增加了许多。

ADC的DMA全在DMA2上,通道0、1、2上。

  /* DMA2 Stream0 channel0 configuration **************************************/

  DMA_InitStructure.DMA_Channel = DMA_Channel_2;
  DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)ADC3_DR_ADDRESS;
  DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)&ADC3ConvertedValue;
  DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralToMemory;
  DMA_InitStructure.DMA_BufferSize = 1;
  DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
  DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Disable;
  DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
  DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
  DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;
  DMA_InitStructure.DMA_Priority = DMA_Priority_High;
  DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;
  DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_HalfFull;
  DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
  DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;
  DMA_Init(DMA2_Stream0, &DMA_InitStructure);
  DMA_Cmd(DMA2_Stream0, ENABLE);
STM32F4入手调试USART - [T.BN]9527 - 我想我可以
 
STM32F4入手调试USART - [T.BN]9527 - 我想我可以
关键字:STM32F4  USART  ADC-DMA 引用地址:STM32F4入手调试USART,ADC-DMA

上一篇:STM32 GPIO设置
下一篇:at91sam9261-ubifs成功移植

推荐阅读最新更新时间:2024-03-16 15:14

STM32F4学习笔记2——时钟与复位系统
STM32F4采用了三种不同的时钟用来驱动系统时钟(SYSCLK) ·HSI振荡器时钟(内部时钟) ·HSE振荡器时钟(外部时钟) ·PLL时钟(锁相环时钟) 这些设备有以下两种二级时钟源 ·32kHz低速内部RC,可用于驱动独立看门狗和通过程序选择驱动RTC。RTC用于从停机/待机模式下自动唤醒系统。 ·32.768kHz低速外部晶振也可以用来通过程序选择驱动RTC(RTCCLK)。 AHB总线最高支持168MHz的时钟,通过AHB总线分频APB2最高支持84MHz,APB1最高支持42MHz。 所有外设驱动全部来至于SYSCLK除了下面几个: ·USB OTG FS时钟48MHz,随机信
[单片机]
STM32F407玩控制—不完全微分PID控制
常规pid算法有缺陷,主要有:1是当偏差发生突变时,微分作用仅在一个周期内起作用,这个也不合理,2是当输入PV值有噪声时,调节器输出波动大,这在前面的图中可以看到,这对机械执行机构不理,使执行机构容易坏,执行机构故障多,自然生产也就不稳定,所以工程上通常用不完全微分PID调节器,文献中有两种类型的不完全微分PID算法,一种是在常规PID算法后串一个一阶延滞环节(比如参见金以慧《过程控制》,即 Gc(s)=Kc*(1+1/(Ti*s)+Td*s)/(Tf*s+1),这种不完全微分PID算法,与前面讲的常规pid算法加过程值(PV)滤波有点相近,仅在设定(SP)有变化的情况下,调节器输出不同,其余情况下是一样的;另一种是在微分环节上串
[单片机]
用<font color='red'>STM32F4</font>07玩控制—不完全微分PID控制
STM32:DMA实例之串口(USART)通信
硬件平台:stm32f10xZET6 开发环境:keil MDK uVision v4.10 开发语言:C、ST_lib_3.5固件库 /* 代码演示 main.c */ #include stm32f10x.h #include bsp_usart1.h #include bsp_led.h extern uint8_t SendBuff ; static void Delay(__IO u32 nCount); /** * @brief 主函数 */ int main(void) { /* USART1 config 115200 8-N-1 */ USART1_Config(); USART1_
[单片机]
STM32F4寄存器编写跑马灯例程
最近由于在学习STM32看到别人用寄存器编程控制跑马灯,于是自己也想试一试。可是试了好久终究弄不出来。回头看了下库函数的调用关系才搞明白。首先通过查看GPIOA的设置函数发现设置如下: void GPIO_Init(GPIO_TypeDef* GPIOx, GPIO_InitTypeDef* GPIO_InitStruct) { uint32_t pinpos = 0x00, pos = 0x00 , currentpin = 0x00; /* Check the parameters */ assert_param(IS_GPIO_ALL_PERIPH(GPIOx)); assert_param(IS_GPIO_
[单片机]
关于STM32F4xx的GPIO
STM32F4xx的GPIO可以分为GPIOA到GPIOK个端口,每个端口有16个IO口。 对每个GPIO端口,STM32F4xx安排了4个32位配置寄存器(GPIOx_MODER、GPIOx_OTYPER、GPIOx_OSPEEDR、GPIOx_PUPDR)用于对端口内的每个IO口进行配置,安排2个32位数据寄存器(GPIOx_IDR、GPIOx_ODR)用于每个端口的数据输入输出存储,此外,还安排了1个32位置位/复位寄存器(GPIOx_BSRR),1个32位锁定寄存器(GPIOx_LCKR)和2个32位复用功能选择寄存器(GPIOx_AFRH、GPIOx_AFRL)。 对每一个IO口而言,用户可以根据需要将其配置为通
[单片机]
基于STM32F407的七要素气象站(气象传感器)CR-WS数据处理实现
一、七要素气象站介绍 1.七要素气象站介绍 开发板还是采用STM32F407 485连线: 如果买了变送器就按照下图连线: 没有买变送器的话,直接从气象站上拉线,红正黑负,黄485-A,绿485-B。 如果开发板只有232接口,可以买个485转232转换头。还有一个点,它这个供电需要外接9V以上的直流电,光是两个电池是不行的,会出现数据响应错误。 2.通信协议 通信协议 地址 操作 说明 备注 0x0000 保留 0x0001 只读 空气温度,16进制,分辨率0.1℃ +40的数据 0x0002 只读 空气湿度,16进制,分辨率0.1%RH
[单片机]
基于<font color='red'>STM32F4</font>07的七要素气象站(气象传感器)CR-WS数据处理实现
STM32F4 开发笔记3: 定时器2-5的使用方法
STM32F4有多种定时器,其中TIM2-TIM5称为通用定时器,具有相似的软件设置及使用方法。在这里还需要注意的是TIM3和TIM4为16位定时器,TIM2和TIM5为32位定时器。 使用TIM2-5可以遵循以下步骤: 1、打开config.h文件,对如下图所示的宏进行设置,设置为0表示不启动相应的定时器,设置为1表示当前定时器定时1ms,设置为2表示当前定时器定时10ms,设置为3表示当前定时器定时100ms,设置为4表示当前定时器为1s。 上图所示的设置结果为,启动定时器2设置为1ms定时,启动定时器5设置为1s定时,定时器3和定时器4没有启动。 2、打开main.c文件,在相应的中断函数中填入逻辑代
[单片机]
<font color='red'>STM32F4</font> 开发笔记3: 定时器2-5的使用方法
STM32F407-SPI通信接口
1.SPI概念 SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,主要应用在 EEPROM,FLASH,实时时钟,AD转换器,还有数字信号处理器和数字信号解码器之间。 SPI接口一般使用4条线通信: MISO 主设备数据输入,从设备数据输出。 MOSI 主设备数据输出,从设备数据输入。 SCLK时钟信号,由主设备产生。 CS从设备片选信号,由主设备控制。 主机和从机都有一个串行移位寄存器,主机通过向它的SPI串行寄存器写入一个字节来发起一次传输。 串行移位寄存器通过MOSI信号线将字节传送给从机,从机也将自己的串行移位寄存器中的内
[单片机]
<font color='red'>STM32F4</font>07-SPI通信接口
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved