C6678的SPI Flash启动失败

本文记录了在XX板上C6678 DSP通过SPI Flash启动遇到的问题及解决过程。在尝试SPI启动时,发现CPU进入启动分支后,信号在几十字节后消失。通过阅读Bootloader源码、分析启动流程,最终发现启动参数表的定义与文档不符,修正后成功启动。
摘要由CSDN通过智能技术生成

XX板上的6678使用I2C外接其他主机启动。但设计时保留了Nor Flash启动方式作为备份启动方式,因此需要调试SPI Flash启动。

6678支持多种启动方式,在《Bootloader for the C66x DSP User Guide(sprugy5b)》中都有描述。不同的启动方式由上电时启动模式引脚的状态配置,XX板上在研发阶段采用了拨码配置。

根据手册说明,需要先生成一个启动镜像烧入到Nor Flash中。SPI Flash模式下的启动镜像分两部分,一是启动参数表,二是启动表。启动表是从编译生成的.out文件经过TI提供的一些工具逐步转换格式生成的,启动参数表在每种启动模式下均不相同,可以手工逐字节填写。

首先做了一个简单的闪灯程序,用仿真器下载运行成功,然后用工具转化出启动表。最后需要手工加上启动参数表。
TI提供的示例中有I2C EEPROM的启动镜像,但是没有SPI镜像。两者的启动表格式相同,但启动参数表格式略有区别。参考手册并仿照I2C进行修改后生成镜像,烧进去后修改拨码,上电后发现灯不亮。

这时回到手册再仔细分析,花费两天时间也没有发现问题,网上也查找不到相应资料。后来把思路重新整理了一下,根据手册整理出CPU的启动流程图,然后准备一步步排查。

首先上电后采样引脚确定启动模式。用万用表测量拨码电平,没有发现问题。用示波器排查CPU时钟输出引脚,发现有输出信号,说明CPU在正常工作。
然后就要读Flash数据了,用示波器看Flash波形,有输出和输入信号,证实了CPU进入了SPI启动的分支。但持续约几十个字节后信号消失,而正常情况下应该有几百字节才对。这里明显有问题,但原因不明。
由于启动过程CPU都是在执行BootROM里的指令

### 回答1: STM32F407芯片具有DMA功能和SPI接口,可以实现DMA SPIFlash的读写。下面是一个简要的描述: 首先,需要确保STM32F407的SPI控制器正确配置。配置SPI控制器的模式(主模式/从模式)、数据位宽、时钟极性和相位等参数。确定好SPI的数据输入输出引脚。 接下来,配置DMA控制器,使其能够与SPI控制器进行数据传输。配置DMA的数据传输方向、传输大小、传输通道和传输模式等参数。 然后,将待传输的数据从Flash中读取出来并存储在单独的缓冲区中。可以使用读取函数来实现,例如: ```c uint8_t dataBuffer[256]; uint32_t address = 0x08000000; uint32_t size = 256; FLASH_Read(address, dataBuffer, size); //从Flash中读取数据到缓冲区 ``` 然后,将从Flash读取的数据传输到SPI接口,使用DMA来完成数据传输。可以使用发送函数来实现,例如: ```c SPI_DMA_SendData(dataBuffer, size); //使用DMA传输数据到SPI ``` 需要注意的是,在使用DMA进行SPI数据传输时,将数据写入SPI的数据寄存器后,DMA控制器会自动将数据从缓冲区传输到SPI接口,并在传输完成后产生中断信号,通知传输已完成。 如果需要进行Flash写操作,则需要将要写入的数据存储到缓冲区中,然后再使用DMA将数据传输到SPI接口,最后使用Flash编程函数将数据写入Flash中。 以上是一个简要的描述,实际的代码实现需要根据具体情况进行调整和优化。 ### 回答2: STM32F407实现DMA SPIFlash的读写可以通过以下步骤实现: 1. 配置SPI接口:首先需要配置SPI接口,包括主从模式、数据位长度、时钟极性和相位、CPOL、CPHA等参数。在SPI控制寄存器中配置这些参数。 2. 配置DMA通道:使用DMA来传输数据,可以提高读写效率。选择一个合适的DMA通道,并设置传输方向、数据宽度和缓冲区地址。 3. 配置Flash:根据Flash的芯片型号和规格,选择合适的操作命令和地址,将其配置到SPI发送缓冲区中。 4. 启动DMA传输:通过设置DMA控制寄存器,启动DMA传输,并等待传输完成的中断或状态标志。 5. 数据传输:在中断或状态标志表明DMA传输完成后,将接收到的数据从SPI接收缓冲区中读取出来,并将其写入Flash或从Flash中读取。 6. 完成操作:根据需求,可以通过判断Flash状态寄存器的标志位,来确认数据读写是否成功。如果成功,可以继续执行其他操作;如果失败,可以进行错误处理。 需要注意的是,Flash的读写操作必须按照其规格和要求进行,包括地址对齐、写保护状态等。另外,还需要根据具体的编程环境和开发板,在程序中选择合适的库函数和API来执行相应的配置和操作。 ### 回答3: STM32F407是一款高性能的单片机,通过DMA(Direct Memory Access)和SPI(Serial Peripheral Interface)可以实现对Flash的读写操作。 首先,我们需要配置SPI接口。在STM32F407中,SPI接口使用4条I/O线来进行通信,即SCK、MISO、MOSI和SS(片选信号)。我们需要将这些线连接到Flash芯片,并在单片机上进行相应的引脚配置。 然后,我们需要配置DMA控制器。DMA可以将数据在存储器和外设之间进行直接传输,提高数据传输效率。在STM32F407中,有多个DMA通道可供选择。我们选择一个合适的通道,并进行相应的配置,包括数据长度、传输方向等。 接下来,我们需要编写读写Flash的代码。读取Flash时,我们可以向Flash芯片发送读取命令,并通过SPI接收到的数据进行存储;写入Flash时,我们将要写入的数据送入DMA缓冲区,并通过SPI发送给Flash芯片。 在读写过程中,DMA控制器将负责将数据从存储器传输到SPI接口(写入Flash)或从SPI接口传输到存储器(读取Flash)。这样,我们可以将主处理器从数据传输中解放出来,提高系统的并发性。 最后,我们需要进行相应的测试和调试,确保读写操作的正确性。可通过读取Flash中的数据验证读取操作的准确性,并通过编写检验程序验证写入操作的准确性。 总之,通过配置SPI接口和DMA控制器,我们可以实现STM32F407对Flash的读写操作。这种方式能够提高数据传输效率,减轻主处理器的负担,从而提高系统的性能。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值