OpenEdv-开源电子网

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

开启ADC到存储的DMA后,printf会卡住,不能正常输出

[复制链接]

1

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
86
金钱
86
注册时间
2021-7-7
在线时间
14 小时
发表于 2022-7-1 17:28:47 | 显示全部楼层 |阅读模式
5金钱
开启DMA后,主函数里的printf函数就会卡住,会一直卡在DMA的中断里,sram应该是没有溢出的。

代码大概是这个样子
void         bsp_Init(void)
{
          MX_DMA_Init();
          MX_ADC_Init();
          MX_TIM14_Init();
          Init_Uart();
          Init_Led();
          Init_Key();
          bsp_InitTimer();

//          bsp_DelayMS(10000);                                                                        //等待高压模块初始化
          LedOn(CTR);                                                                                        //打开高压模块
          HAL_ADCEx_Calibration_Start(&hadc);                                        //校准adc
//          HAL_ADC_Start_DMA(&hadc, ADC_Value, ADC_LENGTH);                //开始ADC转换
}


int fputc(int ch, FILE *f)
{
#if 1        /* 将需要printf的字符通过串口中断FIFO发送出去,printf函数会立即返回 */
        comSendChar(COM1, ch);

        return ch;
#else        /* 采用阻塞方式发送每个字符,等待数据发送完毕 */
        /* 写一个字节到USART1 */
        USART1->DR = ch;

        /* 等待发送结束 */
        while((USART1->SR & USART_SR_TC) == 0)
        {}

        return ch;
#endif
}


然后主函数里的printf就会一直卡在下面这个中断里
void DMA1_Channel1_IRQHandler(void)
{
  HAL_DMA_IRQHandler(&hdma_adc);
}

DUJTMOUOHVEETWQ5XM3NKHO.png

最佳答案

查看完整内容[请看2#楼]

因为DMA每次完成后就会去中断服务函数DMA1_Channel1_IRQHandler( ),ADC采样点数过少,就会一直不停地在运行中断服务函数,导致主函数int main()中的代码无法得到执行。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2019-5-27
在线时间
15 小时
发表于 2022-7-1 17:28:48 | 显示全部楼层
因为DMA每次完成后就会去中断服务函数DMA1_Channel1_IRQHandler( ),ADC采样点数过少,就会一直不停地在运行中断服务函数,导致主函数int main()中的代码无法得到执行。
回复

使用道具 举报

1

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
86
金钱
86
注册时间
2021-7-7
在线时间
14 小时
 楼主| 发表于 2022-7-1 18:05:20 | 显示全部楼层
我好像找个问题了,开启DMA转换那里,最后一个参数数据个数,大于等于7就行,小于就会出这样的问题
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2022-7-5 01:43:16 | 显示全部楼层
wyf18388335146 发表于 2022-7-1 18:05
我好像找个问题了,开启DMA转换那里,最后一个参数数据个数,大于等于7就行,小于就会出这样的问题

解决了?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

1

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
86
金钱
86
注册时间
2021-7-7
在线时间
14 小时
 楼主| 发表于 2022-8-12 15:21:09 | 显示全部楼层

对,解决了,缓存的数组小于7就会出问题
回复

使用道具 举报

12

主题

160

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2747
金钱
2747
注册时间
2017-12-16
在线时间
199 小时
发表于 2022-8-13 14:08:47 | 显示全部楼层
wyf18388335146 发表于 2022-8-12 15:21
对,解决了,缓存的数组小于7就会出问题

为什么呢?
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-26 07:02

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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