MIPI DSI协议解析

2023-11-05 20:20
文章标签 协议 解析 mipi dsi

本文主要是介绍MIPI DSI协议解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

要学习MIPI协议,不学习DSI协议是不能深刻理解的!

今天我们一起来学习一下MIPI DSI协议;

1:Overview

DSI 全称Display Serial Interface,是由MIPI联盟定义的处理器与外设之间的移动设备接口规范,该规范建立在现有的标准的基础上,并采用了MIPI联盟DBI,DPI,DCS标准中定义的像素格式和命令集,DSI是主要用于显示传输的接口。

一般而言,完整的的DSI传输如下图所示,从上到下依次为(本文主要关注第二层与第三层)

1:Application:描述了数据流中包含的数据的更高层的编码和解释,根据显示子系统架构,他可能由具有规定格式的像素组成,或者由显示模块的命令组成,可以参考DSC/DPI/DBI spec;

2:Low Level Protocal:该协议规定了通过接口的位和字节的顺序和值,它定义如何将字节组织成定义的组,即数据包,该协议以数据包为最小集合,并为每隔数据包定义了所需要的包头,以及如何生成和解释包头信息,后续发送端将包头和错误检查信息附加到正在传输的数据中;

3:Lane Managment:通道管理,DSI可进行通道扩展以提高性能,根据应用的带宽要求,Data Lane的数量可以是1,2,3,4;

4:PHY Layer:物理层

 操作模式:

DPHY有三种操作模式: Escape mode, High-Speed(Burst) mode,及 Control mode。
• MIPI的HS模式(0.2V),传送图像数据,速度为80Mbps ~ 1000Mbps;
• MIPI的LP模式(1.2V),可以用于传送控制命令,最高速度为10Mbps;
• MIPI规定,任一个MIPI设备必须具有Escape Mode,此为LP模式(低功耗模式)中的一种,此模式下可低速传输图像或其他数据。
2.1 从控制模式的停止状态开始的可能事件有:
• Escape mode request (LP-11→LP-10→LP-00→LP-01→LP-00)
• High-Speed mode request (LP-11→LP-01→LP-00)
• Turnaround request (LP-11→LP-10→LP-00→LP-10→LP-00)
2.2 Escape mode是数据Lane在LP状态下的一种特殊操作
• 在这种模式下,可以进入一些额外的功能:LPDT, ULPS, Trigger
• 数据Lane进入Escape mode模式通过LP-11→LP-10→LP-00→LP-01→LP-00
• 一旦进入Escape mode模式,发送端必须发送1个8-bit的命令来响应请求的动作,0x87(LPDT),0x78(ULPS), 0x45(Trigger)。
• Escape mode 使用Spaced-One-Hot Encoding
2.3 超低功耗状态(ULPS, Ultra-Low Power State)
•这个状态下,lines处于空状态 (LP-00)
• 时钟Lane的超低功耗状态
•时钟Lane通过LP-11→LP-10→LP-00进入ULPS状态
•通过LP-10 → TWAKEUP →LP-11退出这种状态,最小TWAKEUP时间为1ms
2.4 高速数据传输 (High-Speed(Burst) mode)
•发送高速串行数据的行为称为高速数据传输或触发(burst)
•全部Lanes门同步开始,结束的时间可能不同。
•时钟应该处于高速模式
2. 5 各模操作式下的传输过程

•进入Escape模式的过程 :LP-11→LP-10→LP-00→LP-01→LP-00→Entry Code → LPD (10MHz)
•退出Escape模式的过程:LP-10→LP-11•进入高速模式的过程:LP-11→LP-01→LP-00→SoT(00011101) → HSD (80Mbps ~ 1Gbps)
•退出高速模式的过程:EoT→LP-11•控制模式 - BTA 传输过程:LP-11→LP-10→LP-00→LP-10→LP-00
•控制模式 - BTA 接收过程:LP-00→LP-10→LP-11
PS:(1)BTA(Bus turn around):总线控制权可在主机端与从机端之间交换,发送端发送放弃总线请求,接收端接收请求之后
控制总线发起应答,总的过程为BTA(bus turn around)操作。(2)Escape mode 和 High-Speed(Burst) 
mode之间的状态转换,必须经过stop state状态,不可直接转换。(3)每个字节都是低位先传,多字节元素(16位计数值、 16位CRC)也是低字节低位先传。

2:DSI Mode

DSI 定义了两种基本操作模式,Video模式Command模式,使用那种模式取决于外设的架构,功能与应用的目标。

2.1 Video模式

Video模式是指从主机处理器到外围设备的传输采用实时像素流形式的操作,一般而言,显示模块依靠主机处理器以足够的带宽提供图像数据,以避免显示图像中的闪烁或其他可见伪影,而一些视频模式架构可能包括一个简单的时序控制器部分帧缓冲区,用于在待机或者低功耗下保持部分屏幕或较低分辨率的图像,这允许关闭接口以降低功耗,当然为了降低复杂性和成本,仅在Video模式下运行的系统是单向的Data Lane。

# 视频信息只能使用高速模式传输


2.2 Command 模式

Command模式是指其中事务主要采取将命令数据发送到外设(例如显示模块)的形式的操作,显示控制器需要有本地寄存器帧缓冲器,处理器通过向显示控制器发送命令参数数据来间接控制其显示行为,同时还可以读取显示模块状态信息帧存储器的内容,故command模式操作需要一个双向的Data Lane。

# 某些显示器仅能在LP模式下初始化

3:DSI Physical Layer

本节简要概述DSI中使用的物理层,有关详细信息可以参考D-PHY——MIPI 系列之 D-PHY_爱洋葱的博客-CSDN博客

DSI使用一个或者多个串行数据信号和一个串行时钟在主机处理器和外围设备之间传输信息,通过总线发送高速串行数据的动作称为HS传输或者Burst,在高速传输之间,差分数据信号或者通道进入低功耗状态(LPS),且接口在不主动发送或者接收高速数据时也应该处于低功耗状态LPS。

下图为HS模式下的数据传输:

协议规定了一个字节即最小数据单元,一次传输包含N个字节。

3.1:数据流控 

由前面的结构可知,底层为协议层将数据发给PHY层,但是协议层和PHY层之间没有握手,一旦传输开始,协议层就可以限制进出PHY层的数据传输,而数据包一共完整无间断的发送和接收,则需要链路两端的协议层和数据缓冲应始终具有等于或者大于PHY层电路的带宽,一个实际的结果是系统实现者应该确保接收器的带宽能力等于或者大于发射器的带宽能力。

3.2 双向性 

DSI实现的物理层由一到四个数据通道和一个时钟通道组成,其中:

Command Mode:data lane0应该是双向的;额外的Data lane应是单向的。

Video Mode:Data Lane0可以是双向的或单向的;额外的Data Lane应是单向的。

Note:Clock lane应该由Master驱动,而不能由外设驱动;

            LP传输应仅使用Data Lane0;

PHY和协议层之间的接口有几个控制总线方向的信号,当master需要外设的响应时使用,例如返回READ数据或状态信息,它有如下流程

1:Master在传输的最后一个数据包期间向其PHY断言TurnRequest

2:PHY层拿到TurnRequest后在Eot序列之后发送BTA(bus turn around)命令;

3:当外设接收到BTA命令时,其PHY层将TurnRequest置为协议层的输入;

4:外设拿到TurnRequest通知其接收协议层准备向master发送响应;

5:外设发送响应后,外设同样使用TurnRequest将总线控制权交换给Master;

BTA机制时需要在LP下实现的 

下图为测试过程中抓的一个BTA波形:

3.3 Video Mode Interface 

在 Video 模式下运行的 DSI TX 的最低 PHY 要求是:

• Data Lane Module:CIL-MUNN(HS-TX、LP-TX)
• Clock Lane Module:CIL-MCNN(HS-TX、LP-TX)

在 Video 模式下运行的 DSI RX 的最低 PHY 要求是:
• Data Lane Module: CIL-SUNN (HS-RX, LP-RX)
• Clock Lane Module: CIL-SCNN (HS-RX, LP-RX)

3.4 Command Mode Interface

在 Command 模式下运行的 DSI TX 的最低 PHY 要求是:

• Data Lane Module: CIL-MUYY (HS-TX, LP-TX, LP-RX, and LP-CD)
•Clock Lane Module: CIL-MCNN (HS-TX, LP-TX)
在 Command 模式下运行的 DSI RX 的最低PHY要求是:
• Data Lane Module: CIL-SUYY (HS-RX, LP-RX, LP-TX, and LP-CD)
•Clock Lane Module: CIL-SCNN (HS-RX, LP-RX)

3.5 Clock

DSI时钟是从Master到Slave的信号,它可能具有多种功能:

1:Bit Clock:在整个链路上,DSI时钟用作源同步时钟,用于捕获接收器PHY中的串行数据位;

2:Byte Clock:分频后,DSI时钟用于在协议层和应用层之间的概念接口生成Lane Byte Clock

3:Esc Clock:分频后,DSI时钟用于LP模式;

4:Application Clock:DSI位时钟的分频版本可用于其他时钟功能;

所有DSI TX/RX都

这篇关于MIPI DSI协议解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/352247

相关文章

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

数据库使用之union、union all、各种join的用法区别解析

《数据库使用之union、unionall、各种join的用法区别解析》:本文主要介绍SQL中的Union和UnionAll的区别,包括去重与否以及使用时的注意事项,还详细解释了Join关键字,... 目录一、Union 和Union All1、区别:2、注意点:3、具体举例二、Join关键字的区别&php

Spring IOC控制反转的实现解析

《SpringIOC控制反转的实现解析》:本文主要介绍SpringIOC控制反转的实现,IOC是Spring的核心思想之一,它通过将对象的创建、依赖注入和生命周期管理交给容器来实现解耦,使开发者... 目录1. IOC的基本概念1.1 什么是IOC1.2 IOC与DI的关系2. IOC的设计目标3. IOC

java中的HashSet与 == 和 equals的区别示例解析

《java中的HashSet与==和equals的区别示例解析》HashSet是Java中基于哈希表实现的集合类,特点包括:元素唯一、无序和可包含null,本文给大家介绍java中的HashSe... 目录什么是HashSetHashSet 的主要特点是HashSet 的常用方法hasSet存储为啥是无序的

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用