OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4545|回复: 4

DMA串口数据发送问题(查了一天了也没看出那里有毛病)

[复制链接]

16

主题

31

帖子

0

精华

初级会员

Rank: 2

积分
115
金钱
115
注册时间
2012-10-29
在线时间
0 小时
发表于 2013-6-1 16:06:48 | 显示全部楼层 |阅读模式

求牛人指点:

程序预实现按下key0(PA13)将50个数,采用DMA方式通过USART1发送给pc,可是按下后发现不能进行DMA发送         

#include"stm32f10x_lib.h"
#include"stdio.h"
char SENTBUFF[50]={
                                   46,47,48,44,45,46,47,48,44,45,46,47,48,44,45,46,47,48,44,45,46,47,48,44,45,
                                  46,47,48,44,45,46,47,48,44,45,46,47,48,44,45,46,47,48,44,45,46,47,48,44,45
                              };

void RCC_Configuration(void);
void GPIO_Configuration(void);
void USART_Configuration(void);
void DMA_Configuration(void);
int main(void)
{   
  RCC_Configuration();
  GPIO_Configuration();
  USART_Configuration();
  DMA_Configuration();
  printf("\r\n start.... \r\n "); //初始化完成

 

  while(GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_13)); //按下key0进行DMA发送开始

  printf("\r\n start DMA.. \r\n "); 
  USART_DMACmd(USART1,USART_DMAReq_Tx,ENABLE);  //usart1打开DMA
  DMA_Cmd(DMA1_Channel5,ENABLE);      //使能DMA1Channel5


  while(DMA_GetFlagStatus(DMA1_FLAG_TC5) == RESET); //等待DMA发送完成
    //DMA_Cmd(DMA1_Channel5,DISABLE);
  printf("\r\n start DMA SUCCESS \r\n ");
  while(1);
 
}

void RCC_Configuration(void)
{
 /* 定义枚举类型变量 HSEStartUpStatus */
 ErrorStatus HSEStartUpStatus;

   /* 复位系统时钟设置*/
   RCC_DeInit();

   /* 开启HSE*/
   RCC_HSEConfig(RCC_HSE_ON);

   /* 等待HSE起振并稳定*/
   HSEStartUpStatus = RCC_WaitForHSEStartUp();
 
 /* 判断HSE起是否振成功,是则进入if()内部 */
   if(HSEStartUpStatus == SUCCESS)
   {
     /* 选择HCLK(AHB)时钟源为SYSCLK 1分频 */
     RCC_HCLKConfig(RCC_SYSCLK_Div1);
 
     /* 选择PCLK2时钟源为 HCLK(AHB) 1分频 */
     RCC_PCLK2Config(RCC_HCLK_Div1);

     /* 选择PCLK1时钟源为 HCLK(AHB) 2分频 */
     RCC_PCLK1Config(RCC_HCLK_Div2);

     /* 设置FLASH延时周期数为2 */
     FLASH_SetLatency(FLASH_Latency_2);
     /* 使能FLASH预取缓存 */
     FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);

     /* 选择锁相环(PLL)时钟源为HSE 1分频,倍频数为9,则PLL输出频率为 8MHz * 9 = 72MHz */
     RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);

     /* 使能PLL */
     RCC_PLLCmd(ENABLE);

     /* 等待PLL输出稳定 */
     while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);

     /* 选择SYSCLK时钟源为PLL */
     RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);

     /* 等待PLL成为SYSCLK时钟源 */
     while(RCC_GetSYSCLKSource() != 0x08);
   }
  
   /* 打开APB2总线上的GPIOA,USART1时钟*/
   RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_USART1|RCC_APB2Periph_AFIO, ENABLE);
 //打开AHB-DMA时钟
 RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1,ENABLE);
}
 void GPIO_Configuration()
 {
   GPIO_InitTypeDef GPIOA_Struct;
  //key0——PA13 
  GPIOA_Struct.GPIO_Pin=GPIO_Pin_13;
  GPIOA_Struct.GPIO_Speed=GPIO_Speed_50MHz;
  GPIOA_Struct.GPIO_Mode=GPIO_Mode_Out_PP; 
  GPIO_Init(GPIOA,&GPIOA_Struct); 
  /////////////////////////
  //TX--PA9
  GPIOA_Struct.GPIO_Pin=GPIO_Pin_9;
  GPIOA_Struct.GPIO_Speed=GPIO_Speed_50MHz;
  GPIOA_Struct.GPIO_Mode=GPIO_Mode_AF_PP; 
  GPIO_Init(GPIOA,&GPIOA_Struct);
  //RX--PA10
  GPIOA_Struct.GPIO_Pin=GPIO_Pin_10; 
  GPIOA_Struct.GPIO_Mode=GPIO_Mode_IN_FLOATING; 
  GPIO_Init(GPIOA,&GPIOA_Struct);
 
 }
   void USART_Configuration(void)
   {
    
   USART_InitTypeDef USART_InitStruct;  
   USART_InitStruct.USART_BaudRate=115200; //波特率
   USART_InitStruct.USART_WordLength=USART_WordLength_8b;//字长
   USART_InitStruct.USART_StopBits=USART_StopBits_1;
   USART_InitStruct.USART_Parity=USART_Parity_No; //奇偶
      USART_InitStruct.USART_Mode=USART_Mode_Rx|USART_Mode_Tx;//发送接受使能
      USART_InitStruct.USART_HardwareFlowControl=USART_HardwareFlowControl_None;//数据流控制
   USART_Init(USART1, &USART_InitStruct);  
   USART_Cmd(USART1,ENABLE);//使能USART1
    
   }


  void DMA_Configuration(void)
  {
 DMA_InitTypeDef DMA_InitStructure;
 DMA_DeInit(DMA1_Channel5);
 DMA_InitStructure.DMA_PeripheralBaseAddr=(u32)&USART1->DR;// 0x40013804
 DMA_InitStructure.DMA_MemoryBaseAddr=(u32)SENTBUFF;
 DMA_InitStructure.DMA_DIR=DMA_DIR_PeripheralDST;
 DMA_InitStructure.DMA_BufferSize=50;   //发送50个字节
 DMA_InitStructure.DMA_PeripheralInc=DMA_PeripheralInc_Disable;
 DMA_InitStructure.DMA_MemoryInc=DMA_MemoryInc_Enable;
 DMA_InitStructure.DMA_PeripheralDataSize=DMA_PeripheralDataSize_Byte;
 DMA_InitStructure.DMA_MemoryDataSize=DMA_MemoryDataSize_Byte;
 DMA_InitStructure.DMA_Mode=DMA_Mode_Normal;
 DMA_InitStructure.DMA_Priority=DMA_Priority_High;
 DMA_InitStructure.DMA_M2M=DMA_M2M_Disable;
 DMA_Init(DMA1_Channel5, &DMA_InitStructure);  
  }

int fputc(int ch, FILE *f)
{
 USART_SendData(USART1, (u8) ch);
 while(USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
 return ch;
}

实验6 DMA.zip

743.33 KB, 下载次数: 239

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2013-6-2 01:05:23 | 显示全部楼层
我们不是有现成的例程么?参考下吧.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 0 反对 1

使用道具 举报

9

主题

86

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
211
金钱
211
注册时间
2017-6-16
在线时间
46 小时
发表于 2018-6-7 10:16:20 | 显示全部楼层
while(GPIO_ReadInputDataBit(GPIOA,GPIO_Pin_13)); //按下key0进行DMA发送开始
  printf("\r\n start DMA.. \r\n ");
  USART_DMACmd(USART1,USART_DMAReq_Tx,ENABLE);  //usart1打开DMA
  DMA_Cmd(DMA1_Channel5,ENABLE);      //使能DMA1Channel5

  while(DMA_GetFlagStatus(DMA1_FLAG_TC5) == RESET); //等待DMA发送完成
    //DMA_Cmd(DMA1_Channel5,DISABLE);
  printf("\r\n start DMA SUCCESS \r\n ");


上面这些都要放到while(1)函数里把
回复 支持 反对

使用道具 举报

7

主题

188

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
385
金钱
385
注册时间
2018-7-19
在线时间
126 小时
发表于 2018-7-26 14:24:11 | 显示全部楼层
程序大致没什么问题,仿真看一下呢
回复 支持 反对

使用道具 举报

0

主题

2

帖子

0

精华

新手入门

积分
16
金钱
16
注册时间
2020-7-1
在线时间
4 小时
发表于 2020-7-30 11:37:53 | 显示全部楼层
发送通道不应该是l4 吗??? 你写的为啥是l5
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-8 04:35

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表