WCH沁恒单片机
直播中

王静

7年用户 1531经验值
私信 关注
[问答]

CH32V103C8使用SPI-slave模式在时序上有问题怎么解决?

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







更多回帖

发帖
×
20
完善资料,
赚取积分