SPI中的极性CPOL和相位CPHA

SPI中的极性CPOL和相位CPHA

详解SPI中的极性CPOL和相位CPHA

SPI由于接口相对简单(只需要4根线),用途算是比较广泛,主要应用在 EEPROM,FLASH,
实时时钟,AD转换器,还有数字信号处理器和数字信号解码器之间。
 
即一个SPI的Master通过SPI与一个从设备,即上述的那些Flash,ADC等,进行通讯。
 
而主从设备之间通过SPI进行通讯,首先要保证两者之间时钟SCLK要一致,互相要商量好了,要匹配,
否则,就没法正常通讯了,即保证时序上的一致才可正常讯。
 
而这里的SPI中的时钟和相位,指的就是SCLk时钟的特性,
即保证主从设备两者的时钟的特性一致了,以保证两者可以正常实现SPI通讯。
 
SPI的极性Polarity和相位Phase,最常见的写法是CPOL和CPHA,不过也有一些其他写法,简单总结如下:

(1) CKPOL (Clock Polarity) = CPOL = POL = Polarity = (时钟)极性

(2) CKPHA (Clock Phase)   = CPHA = PHA = Phase = (时钟)相位

(3) SCK=SCLK=SPI的时钟

(4) Edge=边沿,即时钟电平变化的时刻,即上升沿(rising edge)或者下降沿(falling edge)

对于一个时钟周期内,有两个edge,分别称为:

(1)Leading edge=前一个边沿=第一个边沿,对于开始电压是1,
那么就是1变成0的时候,对于开始电压是0,那么就是0变成1的时候;

(2)Trailing edge=后一个边沿=第二个边沿,对于开始电压是1,
那么就是0变成1的时候(即在第一次1变成0之后,才可能有后面的0变成1),
对于开始电压是0,那么就是1变成0的时候;

本博文采用如下用法:

  1. 极性=CPOL
  2. 相位=CPHA
  3. SCLK=时钟
  4. 第一个边沿和第二个边沿
CPOL和CPHA,分别都可以是0或时1,对应的四种组合就是:
 

SPI中的极性CPOL和相位CPHA
 
SPI中的极性CPOL和相位CPHA
下面详细介绍。

CPOL极性

先说什么是SCLK时钟的空闲时刻,其就是当SCLK在发送8个bit比特数据之前和之后的状态,

于此对应的,SCLK在发送数据的时候,就是正常的工作的时候,有效active的时刻了。
其英文精简解释为:Clock Polarity = IDLE state of SCK。

SPI的CPOL,表示当SCLK空闲idle的时候,其电平的值是低电平0还是高电平1:

CPOL=0,时钟空闲idle时候的电平是低电平,所以当SCLK有效的时候,就是高电平,就是所谓的active-high;

CPOL=1,时钟空闲idle时候的电平是高电平,所以当SCLK有效的时候,就是低电平,就是所谓的active-low;
SPI中的极性CPOL和相位CPHA
 
从上图中可以看出,(CPOL=0)的SCK 波形,它有(传输)8 个脉冲,而在脉冲传输前和完成后都保持在【低电平状态】。
此时的状态就是时钟的空闲状态或无效状态,因为此时没有脉冲,也就不会有数据传输。
同理得出,(CPOL=)1 的图,时钟的空闲状态或无效状态时SCK 是保持【高电平的】。

CPHA相位

首先说明一点,capture strobe = latch = read = sample,都是表示数据采样,数据有效的时刻。

相位,对应着数据采样是在第几个边沿(edge),是第一个边沿还是第二个边沿,
0对应着第一个边沿,1对应着第二个边沿。对于:
 
CPHA=0,表示第一个边沿:

对于CPOL=0,idle时候的是低电平,第一个边沿就是从低变到高,所以是上升沿;

对于CPOL=1,idle时候的是高电平,第一个边沿就是从高变到低,所以是下降沿;

CPHA=1,表示第二个边沿:

对于CPOL=0,idle时候的是低电平,第二个边沿就是从高变到低,所以是下降沿;

对于CPOL=1,idle时候的是高电平,第一个边沿就是从低变到高,所以是上升沿;
 
SPI中的极性CPOL和相位CPHA
 
 
我们看上面的图,发现数据 SI 是对应 SCK 的第一个时钟沿,
再仔细看,数据是在SCK的第一个时钟边沿保持稳定【数据被采样捕获】,
在下一个边沿改变【SCK 的下降沿数据改变】因此我们得出结论:
 
该系列FLASH 是【数据在第一个时钟沿被采样捕获】
或【数据在SPCK 起始边沿捕获,在SPCK 下一个边沿改变】

如何判断CPOL和CPHA

如果起始的SCLK的电平是0,那么CPOL=0,如果是1,那么CPOL=1,
然后看数据采样时刻,即时序图数据线上的数据那个矩形区域的中间所对应的位置,
对应到上面SCLK时钟的位置,对应着是第一个边沿或是第二个边沿,即CPHA是0或1。
(对应的是上升沿还是还是下降沿,要根据对应的CPOL的值,才能确定)。
 

(1)如何判断CPOL:SCLK的空闲时候的电压,是0还是1,决定了CPOL是0还是1;

(2)如何判断CPHA:而数据采样时刻对应着的SCLK的电平,是第一个边沿还是第二个边沿,对应着CPHA为0还是1。

 
SPI中的极性CPOL和相位CPHA
 

最后来看一下S3C2440的SPI的CPOL和CPHA,结合前面讲的理论知识,下面的图就很好理解啦!
 

SPI中的极性CPOL和相位CPHA
 
SPI中的极性CPOL和相位CPHA

此处,再多解释一下可能会遇到的CKPCKE,其是MicrochipPIC系列芯片中的说法。

1CKPClock Polarity Select,就是极性=CPOL

CKP,虽然名字和CPOL不一样,但是都是指时钟相位的选择,定义也一样:

CKP: Clock Polarity Select bit

1 = Idle state for clock (CK) is a high level

0 = Idle state for clock (CK) is a low level

所以不多解释。

2CKEClock Edge Select,就是相位=CPHA

CKE: SPI Clock Edge Select bit

1 = Transmit occurs on transition from active to Idle clock state

0 = Transmit occurs on transition from Idle to active clock state

意思是

1 =(数据)传输发生在时钟从有效状态转到空闲状态的那一时刻

0 =(数据)传输发生在时钟从空闲状态转到有效状态的那一时刻

其中,数据传输的时刻,即图中标出的“数据transmit传输的时刻”,很明显,

该时刻是一个时钟和下一个时钟之间交界的地方,对应的不论是上升沿还是下降沿,

都与我们前面提到的CPHA=数据采样的时刻,的边沿方向所相反。

所以,此处的CKE,正好与CPHA相反。

所以,CKPCKE所对应的取值的含义为:

When CKP = 0: CKE=1 => Data transmitted on rising edge of SCK, CKE=0 => Data transmitted on falling edge of SCK

When CKP = 1: CKE=1 => Data transmitted on falling edge of SCK, CKE=0 => Data transmitted on rising edge of SCK

 SPI中的极性CPOL和相位CPHA

SPI中的极性CPOL和相位CPHA

SPI中的极性CPOL和相位CPHA

 

 

STM32F4 SPI Data clock timing diagram

Clock phase and clock polarity

Four possible timing relationships may be chosen by software, using the CPOL and CPHA bits in the SPI_CR1 register.

The CPOL (clock polarity) bit controls the steady state value of the clock when no data is being transferred.

This bit affects both master and slave modes.

If CPOL is reset, the SCK pin has a low-level idle state.
If CPOL is set, the SCK pin has a high-level idle state.

If the CPHA (clock phase) bit is set, the second edge on the SCK pin  is the MSBit capture strobe. 
(falling edge if the CPOL bit is reset, rising edge if the CPOL bit is set)
Data are latched on the occurrence of the second clock transition.

If the CPHA bit is reset, the first edge on the SCK pin is the MSBit capture strobe. 
(falling edge if CPOL bit is set, rising edge if CPOL bit is reset) 
Data are latched on the occurrence of the first clock transition.

The combination of the CPOL (clock polarity) and CPHA (clock phase) bits selects the data capture clock edge.

SPI中的极性CPOL和相位CPHA

Figure 248, shows an SPI transfer with the four combinations of the CPHA and CPOL bits.

The diagram may be interpreted as a master or slave timing diagram
where the SCK pin, the MISO pin, the MOSI pin are directly connected
between the master and the slave device.

Note:

Prior to changing the CPOL/CPHA bits the SPI must be disabled by resetting the SPE bit.

Master and slave must be programmed with the same timing mode.
The idle state of SCK must correspond to the polarity selected in the SPI_CR1 register
(by pulling up SCK if CPOL=1 or pulling down SCK if CPOL=0).

The Data Frame Format (8- or 16-bit) is selected through the DFF bit in SPI_CR1 register, 
and determines the data length during transmission/reception.

 

SPI Transfer Modes

 

SPI interface allows to transmit and receive data simultaneously on two lines (MOSI and MISO).

Clock polarity (CPOL) and clock phase (CPHA) are the main parameters

that define a clock format to be used by the SPI bus.

 

 

Depending on CPOL parameter, SPI clock may be inverted or non-inverted.

 

CPHA parameter is used to shift the sampling phase.

If CPHA=0 the data are sampled on the leading (first) clock edge.

If CPHA=1 the data are sampled on the trailing (second) clock edge,

regardless of whether that clock edge is rising or falling.

 

CPOL=0, CPHA=0

The data must be available before the first clock signal rising.

The clock idle state is zero.

The data on MISO and MOSI lines must be stable while the clock is high and can be changed when the clock is low.

The data is captured on the clock’s low-to-high transition and propagated on high-to-low clock transition.

SPI中的极性CPOL和相位CPHA

CPOL=0, CPHA=1

The first clock signal rising can be used to prepare the data.

The clock idle state is zero.

The data on MISO and MOSI lines must be stable while the clock is low and can be changed when the clock is high.

The data is captured on the clock’s high-to-low transition and propagated on low-to-high clock transition.SPI中的极性CPOL和相位CPHA

CPOL=1, CPHA=0

The data must be available before the first clock signal falling.

The clock idle state is one.

The data on MISO and MOSI lines must be stable while the clock is low and can be changed when the clock is high.

The data is captured on the clock’s high-to-low transition and propagated on low-to-high clock transition.SPI中的极性CPOL和相位CPHA

CPOL=1, CPHA=1

The first clock signal falling can be used to prepare the data.

The clock idle state is one.

The data on MISO and MOSI lines must be stable while the clock is high and can be changed when the clock is low.

The data is captured on the clock’s low-to-high transition and propagated on high-to-low clock transition.SPI中的极性CPOL和相位CPHA

SPI Modes and Timing.

Introduction

In a lot of cases, when using SPI, we do need to use “SPI_Init_Advanced”.

It has a number of parameters. Here the parameters regarding the SPI “mode” are described. The “mode” consists of

  • The SPI clock (SCK) polarity (parameter clock_idle)
  • The PIC SPI data out transmit edge (parameter edge)

in

procedure SPIx_Init_Advanced(..., data_sample, clock_idle, edge: word);

The “data_sample” parameter does not belong to the actual “SPI mode”, it is an extra feature of the MCU, see here.

The SPI “Modes”

SPI knows 4 “standard” modes, reflecting the SCK’s polarity (CPOL) and the SCK’s phase (CPHA).

The definition is:

SPI Mode CPOL CPHA
0 (or 0,0) 0 0
1 (or 0,1) 0 1
2 (or 1,0) 1 0
3 (or 1,1) 1 1

The meaning is:

CPOL:

  • 0 = Clock Idle low level
  • 1 = Clock Idle high level

CPHA:

  • 0 = SDO transmit edge (*) active to idle
  • 1 = SDO transmit edge idle to active

(*): the transmit edge is the clock edge at which the SDO level changes 

In a timing diagram this looks like(only one clock pulse shown here):

SPI中的极性CPOL和相位CPHA

The Transmit edge is the clock edge at which the SPI output data changes,
the Sampling edge is the clock edge at which the sampling of the SPI input data takes place.
The sampling edge is normally the opposite one of the transmit edge, but see also here. 

SPI and PIC/ dsPIC

The PIC MCU supports a 4 SPI modes, but the MCU registers involved are named differently and behave differently.
The 2 MCU registers are CKP (Clock Polarity) and CKE (Clock edge).

The relation between those 2 registers and the SPI modes is:

SPI Mode CKP CKE
0 (or 0,0) 0 1
1 (or 0,1) 0 0
2 (or 1,0) 1 1
3 (or 1,1) 1 0

As you can see, CKP behaves the same as CPOL, CKE is the inverse of CPHA.

This means that a simple “SPI_Set_mode” looks like this:

procedure Set_SPI_mode(CPOL_, CPHA_: byte);
// The 2 paremeters are:
// CPOL: SPI clock polarity: 0 = Clock Idle LOW;               1 = Clock Idle HIGH
// CPHA: SPI clock Phase:    0 = Transmit edge active to idle; 1 = Transmit edge Idle to active
begin
  CKP_bit := CPOL_;
  CKE_bit := (CPHA_ xor 1) and 1; // invert bit zero
end;

Above routine can e.g. used after a usage of an mE SPIx_Init… routine to (re)set the SPI mode.

The mE SPI library usage

In the mE SPI library the “SPI mode” is set by 2 parameters of the “SPIx_Init_Advanced” function.

The the parameters for PIC are : “clock_idle” and “transmit_edge”
The the parameters for dsPIC are: “clock_idle” and “edge”

Important: in both cases the last parameter (“transmit edge” or “edge” parameter) is

 NOT the transmit edge, but the other one, called the “Sampling edge“,

see here. As you can see the name of the PIC parameter is wrong (it says “transmit_edge”).

Furthermore the constant values used to give the parameters their values are:

For PIC:
CPK: _SPI_CLK_IDLE_LOW and _SPI_CLK_IDLE_HIGH
CPE: _SPI_LOW_2_HIGH, _SPI_HIGH_2_LOW (**)

For dsPIC:
CPK: _SPI_CLK_IDLE_LOW and _SPI_CLK_IDLE_HIGH
CPE: _SPI_ACTIVE_2_IDLE, _SPI_IDLE_2_ACTIVE (**)

(**) Again: the “edge” is the “Sampling Edge”, not the “Transmit Edge”, see here. 

Deriving the parameters from the device’s “SPI mode”

The easiest way is using the “SPI mode” if known, the hardest is deriving the parameters from the device’s timing diagram.

The table below gives the relationship between an SPI device’s “SPI mode” and the parameter values to use with “SPIx_Init_Advanced”:

SPI MODE clock idle parameter Edge parameter = the “Sampling” edge
0,0 _SPI_CLK_IDLE_LOW _SPI_LOW_2_HIGH (pic) : _SPI_IDLE_2_ACTIVE (dsPIC)
0,1 _SPI_CLK_IDLE_LOW _SPI_HIGH_2_LOW (pic)  : _SPI_ACTIVE_TO_IDLE (dsPIC)
1,0 _SPI_CLK_IDLE_HIGH _SPI_HIGH_2_LOW (pic) : _SPI_IDLE_TO_ACTIVE (dsPIC)
1,1 _SPI_CLK_IDLE_HIGH _SPI_LOW_2_HIGH (pic) : _SPI_ACTIVE_TO_IDLE (dsPIC)

Important:

In mikroPascal the parameter “edge” represents the clock edge where in input data is sampled,

not the “transmit edge” (the clock edge at which the SDO data is changed). 

The parameter “data sample” is not included in the “SPI mode”,

but usually “_SPI_DATA_SAMPLE_MIDDLE” will do fine, see however also here.

Defining parameters from the device’s timing diagram

This manner has to be applied if the “SPI mode” of the device at hand is not (explicitely) defined.

To find out the necessary values of the parameters we have to look to the device’s SPI timing diagram we want to handle:

SPI中的极性CPOL和相位CPHA

Keep in mind that in the “device” diagram the “device” timing is shown.

For the PIC timing input and output should be interchanged (which was already done in the above diagram,

it shows the timing from the PIC’s perspective). 

1. The “clock_idle” parameter

See 1 in the diagram. The level wanted is the SCK level at the moment notCS changes. In the diagram this level is zero, so: theclock idle is low.
This means also that (again in our case) the clock active level is high. 

2. The “edge” parameter

See 2 in the diagram. The edge wanted is the one in the middle between 2 PIC output (PIC SO) datachanges (two “transmit” edges, represented by “x” in the timing diagram). 
In our case we see that it is the edge from low to high, or from idle to active

The “data_sample” parameter

The data_sample parameter is not defined in the SPI mode, it is an extra feature of the MCU.
Normally the “Sampling edge” (see here) is the opposite one of the “transmit edge”.

This is achieved by setting the “data_sample” parameter to the value “_SPI_DATA_SAMPLE_MIDDLE”. 

The sampling moment can however be shifted to the same moment as the transmit edge

by setting the “data_sample” parameter to the value “_SPI_DATA_SAMPLE_END” value, see here). 

How to define which one to use:

See 3 in the above diagram.
First define the “data output time”, represented by an x in the timing diagram.

It is the time from one PIC output data (PIC SO) change to the next.
Now compare the device data out (SO = PIC SI) with the “data output time”.

The data_sample value we have is the best moment in the “data output time”

the PIC should take a sample of its input data (the device output data).

In our case, the middle of the “data output time” seems to be the most appropriate (at the end would be not bad either). 

Info

a. Timing diagram (derived and modified from Mchp datasheet)

This is the (master) timing diagram with the terms explained:

SPI中的极性CPOL和相位CPHA

 

 SPI中的极性CPOL和相位CPHA

 

 

 

 
 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109363.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 什么是AV接口_A∨插口的作用

    什么是AV接口_A∨插口的作用Audio&Video音频&视频:音频(Audio)这个专业术语,人类能够听到的所有声音都称之为音频,它可能包括噪音、声音被录制下来以后,无论是说话声、歌声、乐器都可以通过数字音乐软件处理。视频(Video)泛指将一系列静态影像以电信号方式加以捕捉,纪录,处理,储存,传送,与重现的各种技术。连续的图像变化每秒超过24帧(frame)画面以上时,根据视觉暂留原理,人眼无法辨别单幅的静态画面;看上去是平滑连续的视觉效果,这样连续的画面叫做视频。由于AV算是出现比较早的一种接口,它由黄.

    2022年9月22日
    4
  • 用bc做国密sm2加解密、SM3withSM2签名验签等

    用bc做国密sm2加解密、SM3withSM2签名验签等importorg.bouncycastle.asn1.ASN1EncodableVector;importorg.bouncycastle.asn1.ASN1Integer;importorg.bouncycastle.asn1.ASN1Sequence;importorg.bouncycastle.asn1.DERSequence;importorg.bouncycast…

    2025年12月10日
    3
  • Git使用流程_git提交流程

    Git使用流程_git提交流程以coding为例,演示如何使用git首先理解下整个流程,如图一,将本地代码上传到远程仓库1.(电脑里得先下载git)登录coding,新建一个仓库,点击代码浏览可以看到2.在本地新建一个文件夹,作为项目根目录,再此启动GitBash,进入目录,并输入gitinit初始化一个本地git仓库3.将本地仓库和我们在coding上创建的远程仓库对接起来,输入gitre…

    2022年9月23日
    4
  • 显示屏如何检测坏点(手机屏幕坏点检测图片)

    文章来源:http://bbs.50bang.com/read.php?tid=23543通过debug检测屏幕颜色显示坏点、低格硬盘等等技巧通过如下方法,可以方便地在手头么有工具特情况下检测LCD显示器的坏点  购买LCD显示器最忌有亮点或暗点,我们可以借助相关的检测软件来辅助查看,但在配电脑时,老板常常不让我们装软件,其实利用Debug中的F命令就可以看得清清楚楚!  为了检测LCD屏…

    2022年4月17日
    240
  • vbs整人代码蓝屏_vbs整人代码「建议收藏」

    vbs整人代码蓝屏_vbs整人代码「建议收藏」展开全部大量的楼上已经说了。这个e68a84e8a2ad62616964757a686964616f31333433633336是本人原创,亲测有用。毒性嘛,就是会烧CPU,然后在这个vbs旁边创建一大堆垃圾文件(请准备好30G空间)【具体在代码中】仅供恶搞娱乐和研究,没有攻击任何人,组织的意图。setqstart=wscript.CreateObject(“wscript.shell”)s…

    2022年5月5日
    101
  • 抖音表白代码「建议收藏」

    最近抖音上火了一个由小伙伴自己制作的一个表白代码,很多小伙伴都在问这个表白代码是怎么写的?小编今天就为大家带来了抖音表白代码汇总!抖音表白代码示例1:msgbox(“做我女朋友好吗?”)msgbox(“房产证写你名字…保大…我妈会游泳…”)示例2:msgbox(“做我女朋友好吗?”)msgbox(“房产证写你名字…保大…我妈会游泳…”)x=msgbox(“做我女朋友…

    2022年4月13日
    437

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号