CSI及CPHY的学习知识点

news/2025/2/14 3:23:34/

0.CSI早期只有DPHY可用

        CSI-2 v1.3及之后版本提供了更高的接口带宽和更好的通道布局灵活性。从CSI-2 V1.3开始引入了C-PHY 1.0(C-PHY 1.0是MIPI联盟于2014年9月发布的新物理接口),能够兼容之前的D-PHY v1.2版本。

        在CSI-2 V1.2及以前都只能用DPHY传输csi数据。

1.CPHY不需要line coding

8b/10b这些线路编码是不需要的,CPHY的三线编码本身就解决了连续0/1的情况。

2.CPHY的三线编码使用线态跳变传递信息的

        有六个线态(wire state),每一个当前线态都可以跳变到另外5个线态。每一次跳变对应3bit symbol【跳变有5种可能,用3bit表示,所以3bit数有不用的】,每7个symbol对应16bit原始数据。可以理解为7个symbol需要3线共传输21bit,共传输16bit原始数据。16/21=76%.比DPHY的50%效率要高【两个差分bit传1bit原始数据】。

        线态之间有5种变化,所以最多能传输log2(5)=2.3219bit数据,连续7个跳变最多能传输log2(5)×7=16.2533bit数据,所以选择用7个symbol表示16bit数据

3.CPHY也正是通过线态的电压改变完成了时钟恢复

        无论何时,线上传输的相邻线态【wire state】都是不同的,而正是线态的变化对应为编码数据,同时由不停的变化可以方便的恢复时钟

        当前线态由当前symbol和上一个线态共同决定。

4.CPHY基本上完全重用DPHY的低功耗模式

        异步escape传输和LP mode和DPHY一样,Escape和control mode信号和DPHY PPI一致,除了没有clklane的ulps相关信号

5.无需clklane,所以正反向传输可以达到相同的速率,DPHY反向速率是正向最大1/4

6.HS mode两边都端接,LP是单端且无端接

7.LP或ESC是三线是什么状态

        虽然有三根线,但是为了保证和DPHY一致,只有4个状态是有效的。

8.和DPHY相同的HS/LP/LPCD

9.PPI接口大部分和DPHY的PPI复用,会有一些特殊

  • cphy ppi的DataHs可以支持16bit也可以支持32bit,对应wordClkHs【DPHY是ByteClkHs】symbolClkHs的1/7和1/14. 
  • CPHY比DPHY多了2bit的T/RxWordValidHS[1:0],0bit表示DataHs[15:0]有效,1bit表示DataHS[31:16]有效。
  • CPHY可以选择只支持16bit Data或32bitdata,也可以同时支持16/32bit可配----TxDataWidthHs
  • 多了发送同步及同步类型选择TxSendSyncHs[1:0], TxSyncTypeHS0[2:0]和TxSyncTypeHS1[2:0]-------Rx增加对应的信号
  • Rx多了一个RxInvalidCodeHS[1:0]:用来表示收到的连续7个symbol不是有效symbol。在syncWord和ALP时无效
  • 多了ALP code发送和ALP类型选择以及ALP Nibble data三组信号TxSendALPHS[1:0], TxALPCodeHS0/1[3:0]和TxALPNibble0/1[3:0]------Rx增加对应的信号
  • SyncWord和ALP是32bit还是16bit和DataHS的规格一致
  • Escape信号和DPHY一致
  • control mode比DPHY少了clklane的ulps信号,多了一个ALPWakeState[2:0]:ALP-暂停唤醒线态,配置ALP-暂停唤醒状态时线态值。默认为+x。

10.HS的同步及同步类型

如果是32bit的dataHS,为什么会有TxSendSyncHs[1:0]两bit ?

原因在于16bit的syncword有可能在dataHS的低16bit,也有可能在高16bit。对应需要两个TxSyncTypeHS0/1[2:0]

syncWord都是16bit,会不会出现连续发送的情况?这时候2bit的SendSyncHs都会有效?

TxSyncTypeHS 如下图有5种类型的syncword。

TxSendSyncHS[1:0]:两种情况下发送syncWord:

  • 用发送的syncWord来分开packet header的副本
  • 在HS data发送之前即SOT阶段发送syncWord

对应Rx也有两种情况:

  • 在RxActiveHS上升沿拉高一个RxWordClkHS
  • 在收到冗余packet headers之前拉高

11.ALP和FBTA,CPHY 1.2/DPHY 3.0特性

        CPHY v1.2有ALP,但DPHY v1.2是没有的。在CPHY v2.0还增加了在HS mode下快速进行bus trun-around的流程,FBTA。 DPHY V3.0上开始支持ALP和FBA。

11.1 ALP

11.1.1 什么是ALP? 和LP有何区别?为什么要增加ALP? 答案如下:

        ALP:alternative low power 【备用低功耗】.ALP是HSmode下的一种低功耗,可以使Lane和PHY不用进入LP mode,而降低功耗。这么做的好处是能够快速的进行ALP和HS data bursts传输的切换。

        正常情况下HS的data burst传输之间是要回到LP111 stop state这种standby状态。一个Burst传输完成要走EOT,拉起LP-111 stop state的,然后进入control mode。而ALP mode就不要走EOT,也不用拉高LP-111,而是另外一个流程快速进入ALP-PAUSE状态。

        ALP-PAUSE又分为ALP-PAUSE  STOP和ALP-PAUSE ULPS,这两个状态和LP mode 的stop state和ulps是类似的。

11.1.2 ALP code

上表给出了PPI ALP code及对应的seven-Symbol序列【需要注意的是和HS data不同,这里不是16mapping到seven-Symbol,而是4bit mapping】。同时给出了和LP及Escape mode相应的序列

11.1.3 在HS传输ALP的示例及状态转换

一次完整的HS到ALP在到HS的过程如下:

  • HS data传输----->Post1------>ALP command---->Post2----- >ALP-Pause mode----->ALP-Pause Wake----->Preamble------>sync------>HS data
  • 这个过程可以类比 HS data传输---->LP command---->Escape---->LP command ----->HS data传输的过程

一次完整的ALP到ALP command再到ALP的过程如下:

  • ALP-Pause Wake----->Preamble------>ALP command---->Post2----- >ALP-Pause mode----->ALP-Pause Wake
  • 这个过程可类比Escape----->LP command----->Escape----->LP command

从上面过程来看有几个结论:

  1. ALP-Pause Wake之后都紧跟着Preamble
  2. 进入ALP-Pause之前都要发送Post2
  3. 从ALP-Pause退出 先进入Wake状态,在该状态停留一段时间【上图Wake的线态是+x,实际可以配置为6个线态的任意一个
  4. 从ALP-pause到HS data传输要重新sync
  5. HS data到ALP command中间要有Post1【下图也有HS直接进入ALP command的,此时因该是HS data没有发送完毕

11.1.4 ALP相关的TX和RX端信号:

        TxSendALPHS[1:0] :在HS mode,该信号拉起时,开始传输ALP code。此时会忽略DataHs上的数据,而选择TxALPCodeHS0/1[3:0]上的4bit的ALP code。

        TxALPCodeHS0/1[3:0]:4bit ALP code。【ALPCode不为4'b1010时,直接发送ALPCode的seven-symbol;ALPCode=4'b1010时,发送的是由TxALPNibble0/1[3:0]确定的S_104444S_0

        TxALPNibble0/1[3:0]:在HS发送,TxSendALPHS有效且TxALPCodeHS0/1[3:0]=4'b1010的时候用来选择Nibble code的seven-symbol的第1和第7个symbol【即11.1.2节 ALP code中 LPDT Nibble code的s0和s1】。其中S0和S1的编码如下【TxALPNibble0/1[3:0]就是下表的Data列,取值0-0xF】:       

        之所以有0/1的选择是为了和dataHS是一拍16bit还是一拍32bit保持一致。比如说当前是32bit的dataHS,当前的TxWordValidHS[1:0]=2'b01, TxSendALPHS[1:0]=2'b10,则此时:

  • DataHS[15:0]需要被TX正确发送
  • DataHs[31:16]不会被发送,而是选择TxALPCodeHS1[3:0]或LPDT Nibbie code来发送。

对应的Rx端信号为:

RxALPValidHS[1:0]:表示Rx收到了7-symbol的ALP code。一般在以下三种情况下拉高:

  • 在normal HS preamble后面【由11.1.3节ALP的示例图可见,preamble后面不一定全是ALP command】
  • 在Hs burst的POST1之后【由11.1.3节ALP的示例图可见】
  • 在calibration preamble后面【11.1.3节ALP的示例并没有列出这种情况】

11.1.5 什么时候发起ALP?

TODO,这个应该在protocol里面描述?

11.2 FBTA

TODO,没有细看,需要在CPHY的v2.0版本查看。    

12.和DPHY一样PPI TX的data支持反压,PPI RX不支持反压

13.HS command包括发送Sync Word和ALP Code 和 Post pattern?

        什么是HS command?干什么的?

        在发送HS command的时候,DataHS上就传输SyncWord或ALP code? HS command可以打断正常图像数据的传输?

14.所有lane最低支持前向HS和escape

15.HS传输16bit整数倍数据,LP传输8bit整数倍数据【确切说是LPDT】

16.从16bit到7symbol的mapper和demapper以及symbol到wire state的编解码

        都可以在C-PHY specification_v1.2.pdf的第六章global operation上找到,这里不在展开

17.LP也只有4个状态

        和DPHY的LP一样都只有4个状态LP-000,LP-001,LP-100,LP-111,DPHY是LP00/01/10/11.如果当期是HS传输,对于LP-RX来说会把250±250/2mv的HS信号都识别为LP-000【DPHY也是类似】。

18.Post1/2,sync word, preamble,同步

        Post1:是packet Data的结尾标识,是长度可配的7-symbol,7-symbol是连续的7个"4".该post1不作为sync使用。另一个用途是为了在packet data传输完毕,继续传递时钟信息一段时间,用于Rx PHY和protocol处理完packet。

        Post2:进入ALP-Pause前标识码,前面只能是ALP的stop code和ULPS code。是一个7-symbol的"4"

        sync Word:用作同步和分割冗余PH。用作同步时跟在Preamble后面。是一个7-symbol为"3-4-4-4-4-4-3"。

        【High-Speed data transmission occurs in bursts. To aid receiver synchronization, data bursts shall be extended on the transmitter side with a Preamble and Post sequence.】

        上面一段CPHY spec原文虽然说前导码和Post seq用于sync,实际只有专用sync word用于同步

        Preamble:前导码分别为两种,一种是带中间可编程序列的;另外一种是不带中间可编程序列。如下:

       带中间可编程序列持续时间为t3-PREBEGIN+t3-PROGSEQ+t3-PREEND,其中中间可编程序列持续时间为t3-PROGSEQ,序列可配置。PREBEGIN和PREEND期间发的都是7-symbol "3"

        不带中间可编程序列续时间为t3-PREBEGIN+t3-PREEND,PREBEGIN和PREEND期间发的都是7-symbol "3"

500.CSI实际传输是以packet为单位

        虽然CPHY单lane传输的最小单位是16bit,但是实际协议层是以packet为单位传输数据的。在协议层看到的是一次传输一个或多个Packets。对于每条lane 一次HS Transmission【或者说一次Burst传输】是以SOT开始,EOT结束。多条lane数据量可以不相等,也可以不同时开始【通常情况下同时开始,不同时结束】。

        CPHY HS传输视频数据时,如果protocol把一个packet分配到多lane同时传输时,每条lane都都会传输一份该packet的header。

        DPHY HS传输视频数据时,如果protocol把一个packet分配到多lane同时传输时,不需要每条lane都传输一份PH和PF,只需要将packet按顺序在lane上传输即可。

501.CSI-CPHY下的长包结构

有三点需要注意:

  1. Header是传输该packet的所有lane都要发送
  2. 每个header都是由两个3x16bit的相同header组成,这叫做copy of a packet header或者redundant header
  3. 两个相同的3x16bit的header在发送之间要插入syncWord,用于分割原PH和redundant PH。

对于第一点有个问题: 如果视频payload只有16bit,但是一共有4个lane在传输,此时该payload组成的packet是会分配到单lane还是4lane上传输?

所以需要确定protocl在分配数据的原则是什么

502.什么是redundant Packet headers(Copy of a packet header)

        首先需要说明的CSI v1.2及以下都是对应的PHY只有DPHY,没有CPHY。redundant PH只在CPHY的packet中才有。

503.SOT和redundant Packet headers之前都会发syncWord

在SOT流程中会发送SOT

在redundant Packet headers之前也会发送syncWord----这个syncWord由phy的controller插入第一个3x16bit的packet Header和第二个3x16bit的packet header【即redundant packet Header和第一份完全一致】之间。该syncWord仅仅是用来分割两份PH的。

        注意无论DSI还是CSI的packet中都没有包含为同步而添加的syncWord。Transmission的同步都有靠SOT的syncWord

504.CPHY protocol多lane传输,分配和合并

TODO


http://www.ppmy.cn/news/1124629.html

相关文章

QT信号槽实现原理

定义Q_OBJECT宏 在宏中声明了几个重要的成员变量及成员函数,包括声明了一个只读的静态成员变量static MetaObject,以及3个public的成员函数 static const QMetaObject staticMetaObject; virtual const QMetaObject *metaObject() const; virtual void …

springboot+canal+mysql+redis缓存双写一致性

canal官网地址:https://github.com/alibaba/canal/wiki/QuickStart 基本上按照官网的步骤来就行 准备 首先服务器上要安装好jdk,因为canal运行需要jdk,同时把canal对应的端口在服务中开放,否则连接不上 对于自建 MySQL , 需要先开启 Binl…

【Vue.js】使用Element搭建首页导航左侧菜单

目录 Mock.js 是什么 有什么好处 安装mockjs ​编辑 引入mockjs mockjs使用 login-mock Bus事物总线 首页导航栏与左侧菜单搭建 结合总线完成组件通讯 Mock.js 是什么 Mock.js是一个用于生成随机数据的模拟数据生成器。它可以帮助开发人员模拟接口请求,生…

Socket编程基础(1)

目录 预备知识 socket通信的本质 认识TCP协议和UDP协议 网络字节序 socket编程流程 socket编程时常见的函数 服务端绑定 整数IP和字符串IP 客户端套接字的创建和绑定 预备知识 理解源IP和目的IP 源IP指的是发送数据包的主机的IP地址,目的IP指的是接收数据包…

求职应聘找工作的同学,在线测评怎么过?

信息时代,越来越多的公司在招聘时引入了人才测评机制。企业和单位希望通过人才测评在广大的应聘者中,找到符合自己要求的人才。虽然很多应聘者能力和简历都比较出众,但却在最开始的人才测评中吃了亏。有的公司很看重人才测评结果。测评就相当…

Android中级——PackageManagerService和Intent

PackageManagerService和Intent PackageManagerServiceIntent PackageManagerService PMS扫描已安装的apk,解析其AndroidManifest.xml获取App相关信息,如下是其构造函数的相关片段 ...... if (partition.getPrivAppFolder() ! null) { //扫描系统应用…

k8s-2 集群升级

首先导入镜像到本地 然后上传镜像到仓库 在所有集群节点 部署cri-docker k8s从1.24版本开始移除了dockershim,所以需要安装cri-docker插件才能使用docker 配置cri-docker 升级master 节点 升级kubeadm 执行升级计划 修改节点套接字 腾空节点 升级kubelet 配置k…

‘Xcode Unable to execute command: Segmentation fault: 11‘

概述, Xcode Unable to execute command: Segmentation fault: 11 解决方案, 添加: Build Setting -> Other Linker Flags -> -ld64 延伸, -ld64是什么, 在 Xcode 的 Build Setting 中,Other Linker Flags(其他链接器标志)用于向链…