HAL STM32H750驱动W25Qxx移植
HAL STM32H750驱动W25Qxx移植
- 基于安富莱BSP驱动移植,将W25Q64挂载到STM32H750的SPI2上,板子采用自制的。
- BSP驱动包资料:
https://pan.baidu.com/s/1Lum1i0K157Dv3z9annKiYw
提取码:0eqi
测试了查询方式、中断方式、以及DMA方式,在测试DMA方式时遇到了一些问题。就是不能开启高速缓存Cache,一旦开启高速缓存,可以识别到外设W25QXX,型号和容量,但是一次性读取数据不全。不开启高速缓存条件下,DMA读取没有问题。
- 🧨在不熟悉高速缓存区的使用情况下,并且在使用DMA情况下,不要随意开启下面几行代码:
//使能CPU的L1-Cache
void Cache_Enable(void)
{
SCB_EnableICache();//使能I-Cache
SCB_EnableDCache();//使能D-Cache
SCB->CACR|=1<<2; //强制D-Cache透写
}
- 如果需要启用高速缓存模式,可以在DMA读取和写入数据前后禁用和开启高速缓存模式。例如:
SCB_DisableICache(); //禁用CACHE缓存
SCB_DisableDCache();
sfReadTest(); //读取数据
SCB_EnableDCache(); //使能DCACHE
SCB_EnableICache();
- 个人使用SPI2连接的W25Q64,接线方式:
- 测试效果:
- 原bsp驱动,针对DMA方式,可能地方需要注意修改:
* DMA模式使用的SRAM4 */
#elif defined (USE_SPI_DMA)
#if defined (__GNUC__) /* KEIL******AC5:__CC_ARM*/
__attribute__((section (".RAM_D3"))) uint8_t g_spiTxBuf[SPI_BUFFER_SIZE];
__attribute__((section (".RAM_D3"))) uint8_t g_spiRxBuf[SPI_BUFFER_SIZE];
#elif defined (__ICCARM__) /* IAR ********/
#pragma location = ".RAM_D3"
uint8_t g_spiTxBuf[SPI_BUFFER_SIZE];
#pragma location = ".RAM_D3"
uint8_t g_spiRxBuf[SPI_BUFFER_SIZE];
#endif
/* 定义在CCM RAM里面的变量 */
//__attribute__((section (".CCM_RAM"))) uint8_t g_spiTxBuf[SPI_BUFFER_SIZE];
//__attribute__((section (".CCM_RAM"))) uint8_t g_spiRxBuf[SPI_BUFFER_SIZE];
#endif
- 在DMA方式下,将需要传输的数组变量指定到AHB SRAM(D3 域)进行存放,加快访问速度。
STM32H750 SPI 接口的区别和时钟源(SPI1 到 SPI6)
- SPI1 到 SPI6 的区别
-
- SPI1,SPI2 和 SPI3 支持 4 到 32bit 数据传输,SPI4,SPI5 和 SPI6 是 4 到 16bit 数据传输。
-
- SPI1,SPI2 和 SPI3 的 FIFO 大小是 16x8bit,而 SPI4,SPI5 和 SPI6 的 FIFO 大小是 8x8bit。
- SPI1,SPI2 和 SPI3 的 FIFO 大小是 16x8bit,而 SPI4,SPI5 和 SPI6 的 FIFO 大小是 8x8bit。
- SPI1 到 SPI6 的所在的总线(对应 SPI 框图的 SPI_CLK 时钟域)
SPI1,SPI4 和 SPI5 在 APB2 总线,SPI2,SPI3 在 APB1 总线,SPI6 在 APB4 总线。注意,SPI 的最高时钟不是由这些总线决定的。 - SPI1 到 SPI6 的支持的最高时钟(对应 SPI 框图的 SPI_KER_CK)
STM32H7 主频在 400MHz 下,SPI1,SPI2 和 SPI3 的最高时钟是 200MHz,而 SPI4,5,6 是 100MHz, 以 SPI1 为例,可以选择的时钟源如下:
- 这里特别注意一点,SPI 工作时最少选择二分频,也就是说 SPI1,2,3 实际通信时钟是 100MHz,而 SPI4,5,6是 50MHz。
移植方法
- 通过STM32CubeMX创建自己的工程,选择对应的SPI组。
- 如果SPI使用DMA或中断方式,,那么取消勾选生成中断函数:
- 移植驱动程序,拷贝下面三个对应的源文件和头文件到自己工程中即可:
- 接下来就是,根据个人硬件配置进行调整修改即可。
文章评论