SPI1->CR1|=0<<3;//Fsck=Fpclk/2=36Mhz }else if(SpeedSet==SPI_SPEED_8)//°Ë·ÖƵ { SPI1->CR1|=2<<3;//Fsck=Fpclk/8=9Mhz }else if(SpeedSet==SPI_SPEED_16)//Ê®Áù·ÖƵ { SPI1->CR1|=3<<3;//Fsck=Fpclk/16=4.5Mhz }else //256·ÖƵ ...
void SPI1_Init(void) { RCC->APB2ENR |= 1<<12;//使能SPI1 时钟 RCC->APB2ENR |= 1<<2; //配置服用功能输出 GPIOA->CRL&=0X000FFFFF; GPIOA->CRL|=0XBBB00000;//PA5.6.7 复用,推挽输出 50M时钟 (不能配置成开漏,否则输出为锯齿波) GPIOA->ODR|=0X7<<5; SPI1->CR1|=0<<11;//8b...
SPI1->CR1|=1<<8; ③设置SPI为主机并设置数据帧格式 Eg:SPI1->CR1|=1<<2; //SPI主机 SPI1->CR1|=0<<11;//8bit数据格式 ④设置时钟极性和相位极性 Eg:SPI1->CR1|=1<<1; //空闲模式下SCK为1 CPOL=1 SPI1->CR1|=1<<0; //数据采样从第二个时间边沿开始,CPHA=1 ⑤传输速率和LSBFIRST帧...
a&=b; 等同于 a=a&b;即SPI1->CR1寄存器的值与0XFFC7做位与运算,结果存入SPI1->CR1寄存器。
每个数据帧的长度均为 8 位或 16 位,具体取决于使用 SPI_CR1 寄存器中的 DFF 位。所选的数据帧格式适用于发送和/或接收。 其实就是我们上面也简单的概括了一下。 状态标志 这个我们可以在使用的时候通过查询寄存器得知。 SPI中断 这个就是中断了,我们也是可以在程序中使用的。
SPI 控制寄存器 1(SPICR1): SPIE=1:使能 SPI 中断 ;SPIE=0:关闭 SPI 中断 ; SPE=1:SPI 模块使能;SPE=0:停止 SPI 模块,SPI 端口为普通 IO 口 MSTR=1:SPI 工作在主机模式;MSTR=0:SPI 工作在从机模式 CPOL=1:时钟在空闲时候为高电平;CPOL=0:时钟在空闲时候为低电平. CPHA=1:在偶数个时钟边沿开始...
//Fsck=Fcpu/256将SPI1->CR1的中间3位设置为1.至于什么意思去查下SPI1->CR1的每个位的功能.
SPI1->CR1|=SPI_BaudRatePrescaler; //设置SPI1速度 SPI_Cmd(SPI1,ENABLE); //使能SPI1 } //SPI1 读写一个字节 //TxData:要写入的字节 //返回值:读取到的字节 这里是两种方法,也可以说是一种方法 我喜欢上面这个。 u8 SPI1_ReadWriteByte(u8 TxData) ...
通过设置SPI_CR1寄存器的SSM位来使能这种模式 这种模式下NSS引脚可以另作他用。内部的NSS电平可以通过SPI_CR1寄存器进行驱动 硬件NSS 若NSS输出被使能,此时STM32工作为主SPI,并且NSS输出已经通过SPI_CR2寄存器的SSOE位使能,此时NSS引脚被拉低,所有NSS引脚与这个主SPI的NSS引脚相连并配置为硬件NSS的SPI设备,将自动变成...
其中数据帧长度可以通过“控制寄存器 CR1”的“DFF 位”配置成 8 位及 16 位模式;配置“LSBFIRST位”可选择 MSB 先行还是 LSB 先行。 1.2.2.4. 整体控制逻辑 整体控制逻辑负责协调整个 SPI 外设,控制逻辑的工作模式根据我们配置的“控制寄存器(CR1/CR2)”的参数而改变,基本的控制参数包括前面提到的 SPI 模式、...