关于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也是一样的,有错位的情况。


1666007709237737.jpg

1666007709113190.jpg

1666007709157081.jpg

1666007709164613.jpg

1666007709804012.jpg

1666007709156517.jpg


您好,附件例程为CH32V103 SPI主从通信例程,SPI初始化配置和你需求配置是一致的,你可以参考从机例程配置下。需要注意,初始化时候最好将对应结构体清0,然后清除一下对应的状态标志位,如下图。此外,主从注意共地。后续若有问题,可通过邮箱(lzs@wch.cn)和我继续进行沟通。

icon_rar.gifCH32V103 SPI 主从.zip

image.png


只有登录才能回复,可以选择微信账号登录