CSI及CPHY的学习知识点

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。

        在一次burst传输中第一个syncWord必须是"3444443",后续的syncWord可以任意配置上表中的5个值。所以一次Burst传输中可以发送不同类型的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是类似的。

        ALP-PAUSE时,线态为VA=VB=VC 且 V_{OD\_AB}=V_{OD\_BC}=V_{OD\_CA}

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.Reserved

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-x"。TX发送时,最后一个symbol是确定的【最先发送】,但RX检测到5个连续的"4-4-4-4-4"后面接着一个"3"时就可以完成同步,而不关心最开始接收的"x"

        x可以时0,1,2,3,4这5种取值,对应5种SyncType,可参考第10条"HS的同步及同步类型"的描述

        【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"

19.bit order 字符顺序

        在描述7-symbol和其他序列时都是按照MSB在左边但LSB先发送,MSB后发送。

7-symbol:[s6s5s4s3s2s1s0],其中s0先被Tx发送,先被Rx接收。

上面的规则是通用规则,CPHY/DPHY都是遵守该规则。

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.mzph.cn/news/88138.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

echarts添加点击事件

实现效果:点击图表,弹出该数据下对应得详情 官方文档: 封装的图表组件中: 点击获取点击得对象,进而将需要的参数传给父组件,在父组件中再去请求接口获取更多信息 this.chart.on(click, (params)> {th…

HTML5福利篇--使用Canvas画图

目录 一.Canvas元素 1.Canvas元素定义 2.使用JavaScript获取页面中的Canvas对象 二.绘制图形 1.绘制直线 2.绘制矩形 (1)rect() (2)strokeRect() (3)fillRect()和clearRect()函数 3.绘制圆弧 4.…

C语言的stdio.h的介绍

C语言的stdio.h的介绍 C语言的stdio.h的介绍 C语言的stdio.h的介绍C语言stdio.h的介绍 C语言stdio.h的介绍 这个含义是导入标准输入输出库 包含头文件.h&#xff0c;std标准库&#xff0c;io是input output输入输出库 <>代表系统库&#xff0c;自定义的话用""…

Stm32_点灯

利用HAL库基本语法实现C8T6点灯操作 引脚配置 PB3、4 、5 //设置为output PB6、7 设置Input且为上拉初始化代码&#xff1a; 由于3、4、5引脚默认输出为0灯泡默认点亮所以要将他们初始化为1 void Inint(){//初始化灯泡函数熄灭HAL_GPIO_WritePin(GPIOB, GPIO_PIN_3, GPIO_PI…

C#源码 LIS实验室(检验科)信息系统源码 SaaS模式的Client/Server架构

LIS实验室&#xff08;检验科&#xff09;信息系统&#xff0c;一体化设计&#xff0c;与其他系统无缝连接&#xff0c;全程化条码管理。集申请、采样、核收、计费、检验、审核、发布、质控、查询、耗材控制等检验科工作为一体的网络管理系统。 技术细节&#xff1a; 体系结构…

【效率提升】maven 转 gradle 实战 | 京东云技术团队

一、灵魂三问 1、gradle 是什么&#xff1f; 一个打包工具&#xff0c; 是一个开源构建自动化工具&#xff0c;足够灵活&#xff0c;可以构建几乎任何类型的软件&#xff0c;高性能、可扩展、能洞察等。其中洞察&#xff0c;可以用于分析构建过程中数据&#xff0c;提供分析参…

Vue 使用vue-pdf 显示pdf文件 切换页面 缩放 全屏 自动播放等

<template><div id"container"><!-- 上一页、下一页--><div class"right-btn"><div click"toFullOrExit" class"turn-btn"><span>{{ isFull 1 ? "取消全屏" : "全屏" }}&l…

IDS与防火墙的区别

1. 什么是IDS&#xff1f; IDS是入侵检测系统&#xff08;Intrusion Detection System&#xff09;的缩写。它是一种计算机安全工具&#xff0c;用于监视计算机网络或系统中的活动&#xff0c;以便检测潜在的恶意行为或入侵尝试。IDS的主要目标是识别可能威胁网络安全的活动&a…

Serverless 数仓技术与挑战(内含 PPT 下载)

近期&#xff0c;Databend Labs 联合创始人张雁飞发表了题为「Serverless 数仓技术与挑战」的主题分享。以下为本次分享的精彩内容&#xff1a; 主题&#xff1a; 「Serverless 数仓技术与挑战」 演讲嘉宾&#xff1a; 张雁飞 嘉宾介绍&#xff1a; Databend Labs 联合创始人…

智能井盖:提升城市井盖安全管理效率

窨井盖作为城市基础设施的重要组成部分&#xff0c;其安全管理与城市的有序运行和群众的生产生活安全息息相关&#xff0c;体现城市管理和社会治理水平。当前&#xff0c;一些城市已经将智能化的窨井盖升级改造作为新城建的重要内容&#xff0c;推动窨井盖等“城市部件”配套建…

微信公众号开发(BUG集)

1.微信公众平台接口错误:不合法的自定义菜单使用用户 地址&#xff1a;解决地址 2.微信公众平台接口错误:invalid ip 180.101.72.196 ipv6 ::ffff:180.101.72.196, not in whitelist rid: 6511420b-60c59249-01084d02 白名单离开放服务器IP

Mybatis学习笔记9 动态SQL

Mybatis学习笔记8 查询返回专题_biubiubiu0706的博客-CSDN博客 动态SQL的业务场景&#xff1a; 例如 批量删除 get请求 uri?id18&id19&id20 或者post id18&id19&id20 String[] idsrequest.getParameterValues("id") 那么这句SQL是需要动态的 还…

【初阶数据结构】——堆的引入

目录 前言 一、二叉树的顺序结构及实现 1.1二叉树的顺序结构 1.2堆的结构 二、堆的实现 2.1堆向上调整算法&#xff08;堆的插入&#xff09; 2.2堆向下调整算法&#xff08;堆的删除&#xff09; 2.3建堆的时间复杂度 2.4堆的创建 2.5堆的初始化和空间的销毁 2.6堆…

二值贝叶斯滤波计算4d毫米波聚类目标动静属性

机器人学中有些问题是二值问题&#xff0c;对于这种二值问题的概率评估问题可以用二值贝叶斯滤波器binary Bayes filter来解决的。比如机器人前方有一个门&#xff0c;机器人想判断这个门是开是关。这个二值状态是固定的&#xff0c;并不会随着测量数据变量的改变而改变。就像门…

Python 序列排序

嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 &#x1f447; &#x1f447; &#x1f447; 更多精彩机密、教程&#xff0c;尽在下方&#xff0c;赶紧点击了解吧~ python源码、视频教程、插件安装教程、资料我都准备好了&#xff0c;直接在文末名片自取就可 python中&…

【QandA C++】内存泄漏、进程地址空间、堆和栈、内存对齐、大小端和判断、虚拟内存等重点知识汇总

目录 内存泄漏 内存模型 、进程地址空间 堆和栈的区别 内存对齐 大端小端及判断 虚拟内存有什么作用 内存泄漏 概念: 是指因为疏忽或错误造成程序未能释放已经不再使用的内存的情况, 内存泄漏并不是指内存在物理上的消失, 而是应用程序分配了某段内存后, 因为设计错误…

Docker 安装Redis(集群)

3主3从redis集群配置 1、新建6个docker容器 redis 实例 docker run -d --name redis-node-1 --net host --privilegedtrue -v /data/redis/share/redis-node-1:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6381 docker run -d --name redis-node-2 --ne…

2023 “华为杯” 中国研究生数学建模竞赛(E题)深度剖析|数学建模完整代码+建模过程全解全析

​ 问题一 血肿扩张风险相关因素探索建模 思路&#xff1a; 根据题目要求,首先需要判断每个患者是否发生了血肿扩张事件。根据定义,如果后续检查的血肿体积比首次检查增加≥6 mL或≥33%,则判断为发生了血肿扩张。 具体判断步骤: (1) 从表1中提取每个患者的入院首次影像检查…

python基础语法

目录 常量和表达式 变量和类型 1.整数int 2.小数float 3.字符串string 4.布尔类型bool 5.动态类型 注释 输入输出 输出 输入 运算符 算术运算符 关系运算符 逻辑运算符 赋值运算符 python和C、Java语法区别 创建一个python项目 常量和表达式 在python中&…

String的增删查【C++】

String的增删查【C】 前言string的增删查改构造与析构构造string(const char* str "")赋值构造string(const string& s1) 赋值重载析构函数增reservepush_backappendinsert 删erase 查迭代器流插入流提取流插入流提取 前言 从这里开始可以算是进入了STL的学习中…