
STM32F405RGT6 ADC2+TIM4触发+DMA(DMA2_Stream2_CH1)+DMA中断会死机(取消中断后完全正常)
stm32支持canfd和dma结合使用吗
NUCLEO-F401RE板卡,连接USB,在KEIL下可以找到ST-LINK仿真器,也可以下载代码。在电脑上看不到NODE_F401RE的磁盘,有知道是什么原因?
程序进入HardFault_Handler求解
STM32CUBEIDE
This example describes how to configure the FMC controller to access the SDRAM memory in low power mode
STM32407 使用串口闲时中断+DMA方式接收最大接收字节是多少
USB_CDC_HOST 标准库里边USBH_DeAllocate_AllChannel()函数的疑问?
STM32部署机器学习算法硬件至少要使用哪个系列的芯片?
重新配置SCB->VTOR = 0x08010000后,再次复位,程序异常,发现不进tick中断,IIC读数卡死在准备查询循环中。
编译APP时注意设置该地址,否则编译后的地址没有偏移是无法正确运行的。
这一点可以参考官方的例程。
地址没有问题,只要隐去usb外设的初始化,就可以正常跳转到app。没什么太好的办法,现在的做法是bootloader更新完app以后,软复位,再次执行一遍bootloader,读取到更新标志位不需要更新,就不执行后面的代码,直接跳转到app,这样是可以的。不过没搞清楚为何bootloader里初始化usb外设以后,在跳转app失败这个问题,以后遇到怕是要出大问题
这个问题挺严重的,不知道其他人有没有遇到过。我在bootloader里隐去对usb外设的初始化就可以正常跳转到app。没什么太好的办法,现在的做法是bootloader更新完app以后,软复位,再次执行一遍bootloader,读取到更新标志位不需要更新,就不执行后面的代码,直接跳转到app,这样是可以的。不过没搞清楚为何bootloader里初始化usb外设以后,在跳转app失败这个问题,以后遇到怕是要出大问题
网上有人在跳转到app以前调用了这2个函数
__HAL_RCC_PWR_CLK_DISABLE(); HAL_RCC_DeInit();,进去看了下里面的内容,貌似就是把时钟又配置了一遍。试了下,有了这2句话,就可以正常跳转到app了,搞不懂。希望有猛男来指点下,这个有点狠,把整个工程的时钟都在配置了一遍,如果有其他外设在运行不知道会不会有影响,如果有单独的针对usb外设的操作,不影响其他外设,就完美了
跳转前让BOOT区开启过的外设中断使能都禁用掉,包括systick的。
也不要霸王硬上弓似地简单做总中断的关闭。保证开始跳转后BOOT区不会
产生任何有效中断请求。
至于你提到的关闭外设时钟并非必须的。对于开启过的外设中断,我们往往
可以对相应外设进行复位操作令其中断使能位清零,尤其当我们针对某个外设开启的
中断较多时,这也是比较快捷而有效的方式。
比方我们对USB外设做下复位。写法可能跟芯片系列有关系,望具体调整参考使用。
__HAL_RCC_USB_FORCE_RESET() ;
__HAL_RCC_USB_RELEASE_RESET() ;
至于你提到的其它方式,有些方式的确有点猛,呵呵!当然能达到目的也行。
不过,当我们搞清根本原因后,在组织代码时就可以灵活处理。
不是这个问题,中断在跳转前我都会屏蔽的。以后还是慎用usb外设,这次还能用其他办法绕过,下次就不好说了