当前位置:首页 > 单片机 > 单片机
[导读]spi速率计算公式为:PCLK / (CPSDVSR *[SCR+1])公式出处:lpc1114用户手册SSP章节CR0寄存器的bit15:bit8定义的解释里面PCLK是当前SSP的时钟,CPSDVSR是寄存器CPSR值,SCR是CR0寄存器bit15:bit8的值。所以spi的速率受

spi速率计算公式为:PCLK / (CPSDVSR *[SCR+1])

公式出处:lpc1114用户手册SSP章节CR0寄存器的bit15:bit8定义的解释里面

PCLK是当前SSP的时钟,CPSDVSR是寄存器CPSR值,SCR是CR0寄存器bit15:bit8的值。

所以spi的速率受到了3个寄存器值的影响,这3个寄存器分别是:

1. LPC_SYSCON->SSP1CLKDIV或者 LPC_SYSCON->SSP0CLKDIV(这是SSP的分频寄存器)

2. LPC_SSP1->CR0(这是SSP控制寄存器0,其中bit15:bit8决定速率)

3. LPC_SSP1->CPSR(这是SSP时钟预分频寄存器)

得到这3个寄存器的值,就可以计算出当前的spi速率值,例如下面的SPI1初始化函数:

voidSPI1_Init(void){uint8_ti,Clear=Clear;//Clear=Clear:用这种语句形式解决编译产生的Waring:neverused!LPC_SYSCON->PRESETCTRL|=(0x1<<2);//禁止LPC_SSP1复位LPC_SYSCON->SYSAHBCLKCTRL|=(0x1<<18);//允许LPC_SSP1时钟bit18LPC_SYSCON->SSP1CLKDIV=10;//10分频:50/10=5MhzLPC_SYSCON->SYSAHBCLKCTRL|=(1<<16);//使能IOCON时钟(bit16)LPC_IOCON->PIO2_1&=~0x07;LPC_IOCON->PIO2_1|=0x02;//把PIO2_1选择为LPC_SSPCLKLPC_IOCON->PIO2_2&=~0x07;LPC_IOCON->PIO2_2|=0x02;//把PIO2_2选择为LPC_SSPMISOLPC_IOCON->PIO2_3&=~0x07;LPC_IOCON->PIO2_3|=0x02;//把PIO2_3选择为LPC_SSPMOSILPC_SYSCON->SYSAHBCLKCTRL&=~(1<<16);//禁能IOCON时钟(bit16)//8位数据传输,SPI模式,CPOL=1,CPHA=1,空闲时CLK为1,SCR=4LPC_SSP1->CR0=0x04C7;//预分频值(注意:这里必须为偶数2~254)LPC_SSP1->CPSR=10;LPC_SSP1->CR1&=~(1<<0);//LBM=0:正常模式LPC_SSP1->CR1&=~(1<<2);//MS=0:主机模式LPC_SSP1->CR1|=(1<<1);//SSE=1:使能SPI1//清空RxFIFO,LPC1114收发均有8帧FIFO,每帧可放置4~16位数据for(i=0;i<8;i++){Clear=LPC_SSP1->DR;//读数据寄存器DR将清空RxFIFO}}

上面例子中,主频50MHz,LPC_SYSCON->SSP1CLKDIV值为10,即PCLK=5MHz;LPC_SSP1->CR0=0x04c7,即bit15:bit8为4,即SCR=4;LPC_SSP1->CPSR=10;带入公式计算得出,现在的SPI速率应该是100KHz.

上图中,示波器,横向每格表示5微秒,图中一个周期就是10微秒,即100KHz,实测与理论完全一致。


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

SPI 是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。是Motorola(摩托罗拉)首先在其MC68HCXX系列处理器上定义的。SPI是一种单主机、高速的,全双工,同步...

关键字: spi spi通信原理

为什么要加锁在SMP系统中,如果仅仅是需要串行地增加一个变量的值,那么使用原子操作的函数(API)就可以了。但现实中更多的场景并不会那么简单,比如需要将一个结构体A中的数据提取出来,然后格式化、解析,再添加到另一个结构体...

关键字: spi ic ck

为什么要加锁在SMP系统中,如果仅仅是需要串行地增加一个变量的值,那么使用原子操作的函数(API)就可以了。但现实中更多的场景并不会那么简单,比如需要将一个结构体A中的数据提取出来,然后格式化、解析,再添加到另一个结构体...

关键字: spi ic ck

SPI接口通信原理

关键字: spi 通讯

Linux 点击上方蓝字 记得关注我们哦! 内核里已经提供spi接口小屏的设备驱动,在内核的配置选项: make menuconfig ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf...

关键字: spi 内核

  SPI即串行外围设备接口,是一种高速的,全双工,同步的通信总线,由于其在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,出于这种简单易用的特性,很多AD转

关键字: spi 隔离芯片

你知道首款2Gb大容量高性能SPI NOR Flash产品吗?业界领先的半导体器件供应商兆易创新GigaDevice(股票代码 603986)今日宣布,隆重推出国内首款容量高达2Gb、高性能SPI NOR Flash——...

关键字: 2gb nor spi 兆易创新 flash产品

摘 要: Xilinx 7系列FPGA是Xilinx公司最新推出的一个芯片系列,Kintex7是该系列芯片中的一种,拥有大量的可编程资源。即便如此,在一些多模式的大型复杂的系统设计中,芯片的资源

关键字: Flash FPGA spi

引言 近年来,城市污水处理产业进入快速发展期。污水排放企业将污水集中排放到污水处理厂进行集中污水处理,排污企业根据排污量缴费。而传统的污水排放量主要是由人工对排污企业的现场流量计进行抄收

关键字: spi 数据 监控
关闭
关闭