问题描述:
芯片: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也是一样的,有错位的情况。