首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

stm8s10X的SPI硬件通讯配置

stm8s10X的SPI硬件通讯配置

SPI主模式
前期:
1.打开外设时钟前期(打开外设时钟设时钟均处于开的状态。用户可通过清除CLK_PCKENR1或CLK_PCKENR2中PCKEN位来关闭相应的外设时钟。但是在关闭外设的时钟前,用户必须设置相应的位禁用该外设。为了使能一个外设,用户必须先设置寄存器CLK_PCKENR中对应的PCKEN位,然后设置外设控制寄存器中的外设使能位。) SPI对应的标号时PCKEN11
2.Alternate function output: SPI outputs must be set-up as push-pull.
3.复用功能的输出:复用输出功能为外设输出到外部或者I/O引脚提供一个方便的操作方法。当复用功能使能时,复用功能模块接管了输出锁存寄存器(Px_ODR)并强制Px_ODR相应的位为1。复用输出功能可以是上拉或者开漏输出,取决于外设本身和控制寄存器1(Px_CR1),输出摆率取决于控制寄存器2 (Px_CR2)的值。
例如:
考虑到要达到最佳性能,SPI输出引脚必须设置为上拉,快速摆率。
配置步骤
1. 通过SPI_CR1寄存器的BR[2:0]位定义串行时钟波特率
2. 选择CPOL和CPHA位,定义数据传输和串行时钟间的相位关系(改变CPOL/CPHA位之前,必须清除SPE位将SPI禁止)
3. 配置SPI_CR1寄存器的LSBFIRST位定义帧格式。

4. 硬件模式下,应把NSS脚连接到高电平;软件模式下,SPI_CR2寄存器的SSM和SSI位为‘1’
5. 必须设置MSTR和SPE位
/********开时钟************************************/
CLK->PCKENR1 = CLK->PCKENR1|0x10;
/********将所有与spi相关寄存器置0**************/
void SPI_DeInit(void)
{
SPI->CR1 = SPI_CR1_RESET_VALUE;
SPI->CR2 = SPI_CR2_RESET_VALUE;
SPI->ICR = SPI_ICR_RESET_VALUE;
SPI->SR = SPI_SR_RESET_VALUE;
SPI->CRCPR = SPI_CRCPR_RESET_VALUE;
}
/********spi配置函数***************************/
void SPI_Init(SPI_FirstBit_TypeDef FirstBit, SPI_BaudRatePrescaler_TypeDef BaudRatePrescaler, SPI_Mode_TypeDef Mode, SPI_ClockPolarity_TypeDef ClockPolarity, SPI_ClockPhase_TypeDef ClockPhase, SPI_DataDirection_TypeDef Data_Direction, SPI_NSS_TypeDef Slave_Management, uint8_t CRCPolynomial)
/********使能spi*******************************/
void SPI_Cmd(FunctionalState NewState)
就此spi就配置好了
继承事业,薪火相传
返回列表