嵌入式开发之mipi协议基础学习

嵌入式开发之mipi协议基础学习MIPI——Mobileindustryprocessinterface多家移动开发或者应用商共同筹划接口标准联盟节约成本,加快产品开发速度内容丰富,显示、照相机、电源管理、射频、存储接口等等CIS(cmosimagesensor)中仅用到了mipi协议中的csi-2(cameraserialinterface二代,标识生成要求)和D-phy

大家好,又见面了,我是你们的朋友全栈君。

MIPI ——Mobile industry process interface

多家移动开发或者应用商共同筹划

接口标准联盟

节约成本,加快产品开发速度

内容丰富,显示、照相机、电源管理、射频、存储接口等等

CIS(cmos image sensor)中仅用到了mipi协议中的csi-2(camera serial interface二代,标识生成要求)和D-phy(物理层,输出通道要求)

Camera端做transmitter,平台端做receiver

简而言之 mipi的作用就是:

1.数据并行转换成串行;

2.功能复用,节约传输线;

3.相对提高传输品质和速度;

4.增加传输距离;

5.适用新的平台需求;

嵌入式开发之mipi协议基础学习

为什么mipi那么NB,下面对比一下就照了。

嵌入式开发之mipi协议基础学习

并口需要

Vsync:帧同步信号

Hsync:行同步信号

和8条数据线,但这10根线,mipi只需要5根。所以,我行,我来!

嵌入式开发之mipi协议基础学习

Clock和 data中体现差分即低位先出,故如此表示,差分信号P高N低表1,P低N高表0.

现在对mipi大概有点小小的概念了。再给你看看她的照片,保证你喜欢。MIPI 输出长什么样?

当当当当~~

嵌入式开发之mipi协议基础学习

帧头标识、帧尾标识(分别由vsync上升下降沿生成)

行头标识、行尾标识(分别由hsync上升下降沿生成)

有效数据长包。包含行标识,所以可以省略line_sync短包

相对于并口传输,即是将vsync、hsync与数据共通道复用传输。

总之一句话,能用软件解决的一定不要动硬件,能动手的一定不要动嘴。人生哲理。

什么?不要看PS过的照片!好吧,下面发个素颜照。

嵌入式开发之mipi协议基础学习

是不是美如画。

而mipi的信号符合其通信协议,

规定其起始电压在1.1~1.3V,等等,如下图(我比较懒,不服来辩)。这是其电气要求。

嵌入式开发之mipi协议基础学习

然后软件方面,如下图:

嵌入式开发之mipi协议基础学习

字节(byte)为基本传输单元,每个byte中有8位(bit)

Sync dyte:用来同步数据开始,告知接下来为有效数据

DATA TYPE:该包传输的是什么格式的数据YUV422(1E)/RAW8(2A)/RAW10(2B)

WC(16bits)= PAYLOAD中的byte数量(即输出窗口的1行中有多少个字节,也即列数。注意raw10为列数的1.25倍,raw12为列数的1.5倍)

ECC:校验datatype和wc是否出错

Payload=image data

CSC:PAYLOAD数据传输校验

*由于插入了许多数据标识,所以会影响hb或者vb的最小值

MIPI DPHY 终端概念

嵌入式开发之mipi协议基础学习

mipi的信号线是一对差分线,理论上可以高电平传一个数据,低电平也传一个,速度又快,功耗又小。

很多时候,平台端的mipi时序和Sensor端如果不匹配,就会出问题。硬件问题的话,就亮信号!

嵌入式开发之mipi协议基础学习

Term未连接情况信号时这样滴。正常的是这样滴:

嵌入式开发之mipi协议基础学习

Sensor输出在设计时已经考虑,应用时主要是FPC或者PCB走线影响

通常要求:

差分对内两线等长,尽量少折线,方向一致;

差分对间地线走地,减小串扰;

线上过孔最少;

至少一侧有铺地;

线长最长不超过20cm;

尽量远离天线;

目的:

阻抗匹配、阻抗连续,减少信号损失,获得较高的信号完整性;

减少信号间耦合,保证信号完整性;

减少与其他射频信号的相互作用,保证各信号的质量;

Settle count

主要是hs_prepare+hs_zero时间与其匹配;

通常设定T_settle count为T_(hs_prepare+hs_zero)/2;

是平台设定参数,通常不改默认值,与pclk频率有关;

不匹配会引起的问题:

卡顿;

不出图;

不规则滚屏、拍照分屏

调节方法:

增大或者减小T_hs_prepare、hs_zero,参数最小值为1,有时需要调的很不可思议才可行,这是需要配成manual模式。

嵌入式开发之mipi协议基础学习

DDR采样,即在时钟的上升和下降沿均采集数据,保证高速传输又可以有效降低时钟频率,要求时钟和数据相位为正交关系。

实际中因为负载差异,会限制时钟的建立速度,同时数据的不规律输出(不是确定的输出序列),所以对setup或者hold时间要求不同。可能造成误码,引起麻点,严重时会丢行。

数据传输速率,单位为bps(bit per second)

mipi_data=pclk_tot*10(raw10)

=pclk_tot*8 (raw8)

pclk_tot=数字输出并行时钟pclk * 数字通道数M

mipi N通道,每通道数据率=mipi_data/N

Mipi时钟速度=每通道数据率/2= mipi_data/4

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

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

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


相关推荐

  • 主流流媒体服务器介绍

    主流流媒体服务器介绍1)FMS(Flashmediaserver)简介 FMS是一个完全基于软件环境的多媒体实时通讯环境,代表了当前实时通讯领域内的发展的方向,并且,其自身也融合了大量的新特色,用于创建下一代通讯应用程序  简而言之,Adobe的FMS是一个多媒体应用平台,在这个平台上,可以实现多媒体流的点播、直播、交互等多种应用,由于Adobe公司在网络多媒体应用上的雄厚实力,以及AdobeFla

    2022年5月6日
    46
  • hackbar工具安装使用教程

    hackbar工具安装使用教程HackBar工具介绍HackBar是一个浏览器上的一个插件,包含一些黑客常用的工具,比如SQLinjection,XSS,加密等!免费版下载百度网盘:https://pan.baidu.com/s/1WBT6iqx9ZRSbCRbGWUfvvA提取码:1234免费版安装:按F12打开hackbar界面…

    2022年6月14日
    153
  • C#点餐系统_点餐系统数据库设计

    C#点餐系统_点餐系统数据库设计一.编程思想1.首先考虑需要什么样的界面;2.界面中需要用到的控件,以及控件的简单设置;3.在不需要按钮控件的情况下,点击会生成按钮的实现;4.通过点击后生成的菜品统计以及价格的自动计算;二.编程核心1.获取控件中的内容;2.添加按钮点击事件;3.对控件中的内容封装传递后并在下一步取出;4.label控件和button控件的生成;5.主要用到了foreach进行遍历;三.实现……

    2025年10月1日
    5
  • python flask教程_python框架有哪些

    python flask教程_python框架有哪些大家好,这算是我使用CSDN以来第一次正二八经的想自己写一篇博客。如果有写的不好的地方还请大家见谅!使用pipenv的方便之处就是可以单独的为每一个python 项目建立对应的虚拟环境,而且该过程简单方便。下面我会用简短的步骤来描述这个过程:1. 首先使用pip进行安装pipenv。 用管理员身份打开命令行(cmd),然后输入pipinstallpipenv 回车,结果如下图所…

    2022年8月28日
    9
  • 学生个人网页设计作品_简单的静态网页代码

    学生个人网页设计作品_简单的静态网页代码学生个人静态网页设计作品之我的家乡设计思路知识运用内容介绍页面代码展示作品展示设计思路页面使用居中效果,留下留白简洁简便,使浏览者在浏览的过程中有一种舒适感,在视觉方面有着清晰安静的画面,吸引浏览者对下面内容的浏览。作品采用的背景是白色,在视觉方面上有着明亮的空间,主体内容宽度为1080px,较大的宽度让浏览者能够清晰的浏览。知识运用在操作方面上运用了html5和css3,采用了div+css结构、表单、超链接、浮动、绝对定位、相对定位、字体样式、引用视频等基础知识内容介绍《我的家

    2025年9月14日
    9
  • android之SeekBar和RatingBar

    今天在看一个音乐播放器的源代码时候用到了SeekBar,就翻出来mars老师的视频复习了一下,然后综合使用了一下.首先先看下运行效果:下来我们看看布局文件的设计:main.xml: 1 2

    2022年3月9日
    41

发表回复

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

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