完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
问题描述:
芯片:CH32V103C8. 使用了SPI-1的端口的SLAVE模式,另外有个DSP芯片做MASTER模式。 开机后,CH32V103配置完成后,对DSP进行复位,DSP然后通过SPI端口开始尝试读取FLASH数据,然后并运行启动。 读取数据的代码 03 00 00 00 00 00,03 00 00 02 00 00, 03 00 00 04 00 00. DSP开始一共要读大约20个地址。 其中03是低速读取的命令,后面红色的3个字节是地址,然后连续读取2个字节。 由于DSP一直引导不了, 然后就用逻辑分析仪跟踪了一下数据内容。发现MISO脚输出的数据在时序上有问题。 CH32V103,工作的SPI-SLAVE配置如下: 硬件用SPI-1对应的PA4-PA7共4个端口。 SPI工作模式, SLAVE, 8 BIT, MSB, CPOL=0, CPHA=0, SPI-CS脚SOFT控制。 SPI初始化代码如下: void SPI_Configuration(void) { SPI_InitTypeDef SPI_InitStructure; GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE); // SPI1_NSS GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; GPIO_Init(GPIOA, &GPIO_InitStructure); // SPI1 pins: MISO GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_Init(GPIOA, &GPIO_InitStructure); // SPI1_SCK, SPI1_MOSI GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7 | GPIO_Pin_5; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOA, &GPIO_InitStructure); SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex; SPI_InitStructure.SPI_Mode = SPI_Mode_Slave; SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b; SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low; SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge; SPI_InitStructure.SPI_NSS = SPI_NSS_Soft; SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_2; SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB; SPI_InitStructure.SPI_CRCPolynomial = 7; SPI_Init(BOOT_SPI, &SPI_InitStructure); SPI_Cmd(BOOT_SPI, ENABLE); return; } 问题出现的BIT位置不固定。截了几个图,用虚白线表示出问题的BIT状态。 逻辑分析仪用的是USBee-AXPro,在最后一张图上,可以看到SPI-CLK频率大约是1.5MHz。 这其中,尝试了降低CH32V103的工作频率,从72M到36M。包括降低SPI的分频频率。 开始用HSI到HSE,都会出现。顺便说一下换CH32V307VCT6也是一样的,有错位的情况。 |
|
相关推荐
|
|
只有小组成员才能发言,加入小组>>
326 浏览 0 评论
CH582M HOST发送数到设备后,提交IN一直是2A是什么问题?
848 浏览 0 评论
1452 浏览 1 评论
CH579M+RT-Thread,RTC从Sleep模式唤醒失败是什么原因?
3413 浏览 2 评论
2820 浏览 1 评论
安卓手机支持外接otg扩展坞 然后使用ch340+ch9329控制电脑吗
1808浏览 1评论
1459浏览 1评论
343浏览 0评论
CH582M HOST发送数到设备后,提交IN一直是2A是什么问题?
860浏览 0评论
467浏览 0评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-1 19:21 , Processed in 0.632849 second(s), Total 69, Slave 52 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
3102