Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
DMA+ADC
TIM
Hardfault
在stm32中移植了ADC+DMA+TIM周期采集电池电压,第二次调用会出现IBUSERR的段错误
发布于 2023-08-24 16:17:28 浏览:630
订阅该版
![微信截图_20230824161611.png](https://oss-club.rt-thread.org/uploads/20230824/855c6a9f687789b712dadde9702ecc85.png) 使用命令行反复调用电压采集没有问题,在两次调用中间使用mqtt传输了一次数据后再采集电压就会出现段错误。
查看更多
1
个回答
默认排序
按发布时间排序
OGBoy
2023-08-24
这家伙很懒,什么也没写!
```c #include
#include
#include
#include "rtdbg.h" #include "adc_sample.h" #include "main.h" /* 设置数据缓存大小,当SAADC采样完此大小数据时产生一次采样完成事件,采样过程中不需要CPU参与(所有通道均采集完成) */ #define SAMPLE_IN_BUFFER (ADC_CHANNEL_NUMS * 1) //数据缓存大小 static int16_t adc_buffer[SAMPLE_IN_BUFFER]; //数据缓存地址 static adc_sample_t adc_sample = {RT_NULL}; static saadc_cplt_cb_t saadc_callback_list[ADC_CHANNEL_NUMS] = {NULL}; static bool m_status = false; static bool m_int_status = false; DMA_HandleTypeDef hdma_adc3; #if 1 TIM_HandleTypeDef htim3; ADC_HandleTypeDef hadc3; /****************** weak callback ******************/ void DMA2_Stream0_IRQHandler(void) { if(m_int_status == true) return; HAL_ADC_Stop_DMA(&hadc3); for(int i = 0; i < ADC_CHANNEL_NUMS; i++) { if(saadc_callback_list[i] != NULL) { float sample_value = adc_buffer[i] * 3.3 / 4096; saadc_callback_list[i](sample_value); //LOG_D("p_buffer[%d] :%f", i, sample_value); } } HAL_DMA_IRQHandler(&hdma_adc3); HAL_ADC_Start_DMA(&hadc3, (uint32_t*)adc_buffer, sizeof(adc_buffer)); m_int_status = false; } void TIM3_IRQHandler(void) { HAL_TIM_IRQHandler(&htim3); } /* 定时器3初始化 */ static uint8_t MX_TIM3_Init(void) { uint8_t err_ret = RT_ERROR; TIM_ClockConfigTypeDef sClockSourceConfig = {0}; TIM_MasterConfigTypeDef sMasterConfig = {0}; htim3.Instance = TIM3; htim3.Init.Prescaler = 8400; htim3.Init.CounterMode = TIM_COUNTERMODE_UP; htim3.Init.Period = 10 * SAMPLE_TIME_INTERVAL; //设置采样周期 htim3.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; htim3.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE; do{ if (HAL_TIM_Base_Init(&htim3) != HAL_OK) break; sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL; if (HAL_TIM_ConfigClockSource(&htim3, &sClockSourceConfig) != HAL_OK) break; sMasterConfig.MasterOutputTrigger = TIM_TRGO_UPDATE; sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE; if (HAL_TIMEx_MasterConfigSynchronization(&htim3, &sMasterConfig) != HAL_OK) break; err_ret = RT_EOK; LOG_D("MX_TIM3_Init success!"); }while(0); return err_ret; } /** * Enable DMA controller clock */ static void MX_DMA_Init(void) { /* DMA controller clock enable */ __HAL_RCC_DMA2_CLK_ENABLE(); /* DMA interrupt init */ /* DMA2_Stream0_IRQn interrupt configuration */ HAL_NVIC_SetPriority(DMA2_Stream0_IRQn, 0, 0); HAL_NVIC_EnableIRQ(DMA2_Stream0_IRQn); LOG_D("MX_DMA_Init success!"); } static void MX_DMA_DeInit(void) { /* DMA controller clock enable */ __HAL_RCC_DMA2_CLK_DISABLE(); /* DMA interrupt init */ /* DMA2_Stream0_IRQn interrupt configuration */ HAL_NVIC_DisableIRQ(DMA2_Stream0_IRQn); LOG_D("MX_DMA_DeInit success!"); } /** * @brief ADC3 Initialization Function * @param None * @retval None */ static uint8_t MX_ADC3_Init(void) { uint8_t err_ret = RT_ERROR; ADC_ChannelConfTypeDef sConfig = {0}; /** Configure the global features of the ADC (Clock, Resolution, Data Alignment and number of conversion) */ hadc3.Instance = ADC3; hadc3.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV4; hadc3.Init.Resolution = ADC_RESOLUTION_12B; hadc3.Init.ScanConvMode = ENABLE; hadc3.Init.ContinuousConvMode = DISABLE; hadc3.Init.DiscontinuousConvMode = DISABLE; hadc3.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_RISING; hadc3.Init.ExternalTrigConv = ADC_EXTERNALTRIGCONV_T3_TRGO; hadc3.Init.DataAlign = ADC_DATAALIGN_RIGHT; hadc3.Init.NbrOfConversion = ADC_CHANNEL_NUMS; hadc3.Init.DMAContinuousRequests = ENABLE; hadc3.Init.EOCSelection = ADC_EOC_SINGLE_CONV; do { if (HAL_ADC_Init(&hadc3) != HAL_OK) break; /** Configure for the selected ADC regular channel its corresponding rank in the sequencer and its sample time.*/ sConfig.Channel = ADC_CHANNEL_3; sConfig.Rank = 1; sConfig.SamplingTime = ADC_SAMPLETIME_3CYCLES; if (HAL_ADC_ConfigChannel(&hadc3, &sConfig) != HAL_OK) break; /** Configure for the selected ADC regular channel its corresponding rank in the sequencer and its sample time. */ sConfig.Channel = ADC_CHANNEL_6; sConfig.Rank = 2; if (HAL_ADC_ConfigChannel(&hadc3, &sConfig) != HAL_OK) break; err_ret = RT_EOK; LOG_D("MX_ADC3_Init success!"); }while(0); return err_ret; } static void saadc_sample_start(void) { do{ if (HAL_ADC_Start_DMA(&hadc3, (uint32_t*)adc_buffer, sizeof(adc_buffer)) != HAL_OK) { LOG_D("HAL_ADC_Start_DMA error!"); break; } if (HAL_TIM_Base_Start_IT(&htim3) != HAL_OK) { LOG_D("HAL_TIM_Base_Start_IT error!"); break; } m_int_status = false; }while(0); } static void saadc_init(void) { MX_TIM3_Init(); MX_DMA_Init(); MX_ADC3_Init(); } static void saadc_unint(void) { HAL_TIM_Base_Stop_IT(&htim3); //关闭采集定时器 HAL_ADC_Stop_DMA(&hadc3); //关闭ADC DMA采集 /* 初始化定时器为默认配置 */ HAL_TIM_Base_DeInit(&htim3); /* 初始化DMA为默认配置 */ MX_DMA_DeInit(); /* 初始化SAADC为默认配置 */ HAL_ADC_DeInit(&hadc3); } #endif static void saadc_sample(uint8_t channel, saadc_cplt_cb_t callback) { int i = 1; i = i; //assert(channel < ADC_CHANNEL_NUMS); saadc_callback_list[channel] = callback; if(m_status == true) return; saadc_init(); saadc_sample_start(); m_status = true; LOG_D("saadc_sample is ernter!"); } static void saadc_sample_cplt(uint8_t channel) { assert(channel < ADC_CHANNEL_NUMS); saadc_callback_list[channel] = NULL; int idx = 0; for(; idx < ADC_CHANNEL_NUMS; idx++) if(saadc_callback_list[idx] != NULL) break; if(m_status == false || idx < ADC_CHANNEL_NUMS) return; saadc_unint(); m_status = false; LOG_D("saadc_sample_cplt is ernter!"); } static int adc_sample_init(void) { assert(ADC_CHANNEL_NUMS < 8); adc_sample.sample = saadc_sample; adc_sample.sample_cplt = saadc_sample_cplt; return 0; } INIT_PREV_EXPORT(adc_sample_init); adc_sample_t* adc_sample_get(void) { return &adc_sample; } ```
撰写答案
登录
注册新账号
关注者
0
被浏览
630
关于作者
OGBoy
这家伙很懒,什么也没写!
提问
3
回答
2
被采纳
0
关注TA
发私信
相关问题
1
RTT1.0,STM32调试时会跑到HardFault【已解决】,出现新问题
2
新手请教关于hardfault怎么查
3
github最新版本库中stm32f0X分支,运行切换任务时候出现hardfault[已解决]
4
实现iap功能,bootloader使用了rtt操作系统,在跳转到app代码的时候提示出现hardfault的问题
5
ymodem在on_begin内发送can无法断开连接,而且RTT会报hardfault
6
挂载UFFS文件系统执行到退出_BuildTreeStepOne函数时hardfault异常
7
STM32F1+RTT串口接收中断进入hardfault
8
STM32F746NG随机进入hardfault(已解决)
9
[已解决]自已建了个STM32F103的MDK工程,初始化时总是进入HardFault,求教!
10
将 Cortex M3 的 hardfault 处理与 M4、M7、M0 保持一致?
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
【24嵌入式设计大赛】基于RT-Thread星火一号的智慧家居系统
2
RT-Thread EtherKit开源以太网硬件正式发布
3
如何在master上的BSP中添加配置yml文件
4
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
5
RT-Thread 发布 EtherKit开源以太网硬件!
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
MicroPython
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
16
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
13
个答案
1
次被采纳
本月文章贡献
程序员阿伟
9
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
5
次点赞
RTT_逍遥
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部