ch32v307 SPI mode1(SPI_CPHA =1)测试发现异常

使用SPI mode1, 实测发现 mosi 数据线,每个字的第一个bit长度1.5clk,最后一个bit 0.5clk,造成接收端不稳定。

配置如下:

void SPI_FullDuplex_Init(void)

{

GPIO_InitTypeDef GPIO_InitStructure={0};

SPI_InitTypeDef SPI_InitStructure={0};


RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOA | RCC_APB2Periph_SPI1, ENABLE );


#if 1//(SPI_MODE == HOST_MODE)

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

GPIO_Init( GPIOA, &GPIO_InitStructure );


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;

GPIO_Init( GPIOA, &GPIO_InitStructure );


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

GPIO_Init( GPIOA, &GPIO_InitStructure );



SPI_InitStructure.SPI_Mode = SPI_Mode_Master;

#endif


SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;




SPI_InitStructure.SPI_Da

icon_jpg.gifch307spi_1st_bit_1p5_clk.jpg

icon_jpg.gifstm32_good_spi_mode1.jpg

icon_jpg.gifch307_last_half_clk.png

taSize = SPI_DataSize_16b;

SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low;

SPI_InitStructure.SPI_CPHA = SPI_CPHA_2Edge;//MODE 1

SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;

SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_32;

SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;

SPI_InitStructure.SPI_CRCPolynomial = 7;

SPI_Init( SPI1, &SPI_InitStructure );


#if 1 //(SPI_MODE == HOST_MODE)

SPI_I2S_DMACmd( SPI1, SPI_I2S_DMAReq_Tx, ENABLE );

SPI_I2S_DMACmd( SPI1, SPI_I2S_DMAReq_Rx, ENABLE );


#endif


SPI_Cmd( SPI1, ENABLE );

}


您好,该现象正常不会影响到从机数据的接收,在EVT中有SPI主从收发的例程,你可以测试一下。若考虑到稳定性因素,可以选择使用其他模式,如模式0。后续若有问题,可以邮箱(lzs@wch.cn)和我沟通。


实测后边沿不稳定。看了一下时序图,使用mode2配置可以和mode1的外设正常通讯了。


您好,从机设备用的是哪款芯片或设备,可以和我说一下,我们这边可以测试一下。后续沟通可通过邮箱(lzs@wch.cn)沟通。


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