整理MTK dsi.PLL_CLOCK配置

DSI采用的是双边采样,则clk等于数据速率的一半,也就是说一个clk周期内传送2位,所以你计算出来的值还要除以2
根据mtk faq的计算公式,是这样的:

1、DSI vdo mode下的数据速率data_rate的大致计算公式为:
Data rate= (Height+VSA+VBP+VFP)*(Width+HSA+HBP+HFP)* total_bit_per_pixel*frame_per_second/total_lane_num

2、DSI cmd mode下的数据速率data_rate的大致计算公式为:
Data rate= width*height*1.2* total_bit_per_pixel*frame_per_second/total_lane_num

每线 clk =  Data rate/2;

Data Rate,即Data Lane上数据传输速率,在VDO MODE中计算公式如下:

Data Rate = ((height + vsa + vbp + vfp) * (width + hsa + hbp + hfp) *
	bits_per_pixel * frames_per_second) / data_lanes

例如:
Data Rate = ((960 + 4 + 16 + 16) * (540 + 4 + 40 + 40) * 24 * 60) / 2 = 418798080
即Data Rate约为420MHz

而dsi在clock的上升沿和下降沿都会采集数据,所以在计算clock时应为Data Rate的一半,对应前面的420MHz,那么clock应设置为210MHz(注意在计算clock时,clock * 2应比Data Rate稍大)。

那么在mtk平台上应该如何设置clock的频率呢?有两种方式,一是通过配置3个参数得到(6582 kk平台),二是直接设置clock频率(推荐第二种)。
第一种方式,通过分频倍频计算:
params->dsi.pll_div1 = 1;	/* 配置0,1,2,3时对应的div1_real为1,2,4,4 */
params->dsi.pll_div2 = 1;	/* 配置0,1,2,3时对应的div2_real为1,2,4,4 */
params->dsi.fbk_div = 30;	/* 范围是0~63 */
那么输出频率计算公式如下:
(26MHz * (fbk_div + 1) * 2) / (div1_real * div2_real) = (26 * 31 * 2) / (2 * 2) = 403。
那么这种方式实际上计算出来是的Data Rate,即mtk手册上所说的BRPL(Bits Rate Per Lane)。

第二种方式:
params->dsi.PLL_CLOCK = 210MHz;

从代码看来,实际上他们最后都是通过设置DSI_PLL_CON0和DSI_PLL_CON2寄存器来实现的。

参考文档:MT6582_LCM_Porting_Guide_DSI_V1.0.pptx.pdf
	MTK_on_line_FAQ_SW_ALPS_20141031.pdf
  • 3
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码片段中的语句表示了一些关于显示设备的参数设置。以下是对每个参数的解释: - `params->dsi.vertical_sync_active=4`:垂直同步激活期,表示在每个屏幕帧的垂直同步信号激活期间的行数。在此行数内,显示设备将进行垂直同步操作。 - `params->dsi.vertical_backporch=12`:垂直后肩,表示垂直同步信号结束后到下一帧图像数据开始之间的行数。在此行数内,显示设备将进行垂直后肩操作。 - `params->dsi.vertical_frontporch=30`:垂直前肩,表示上一帧图像数据结束到垂直同步信号开始之间的行数。在此行数内,显示设备将进行垂直前肩操作。 - `params->dsi.horizontal_sync_active=20`:水平同步激活期,表示在每个屏幕帧的水平同步信号激活期间的像素数。在此像素数内,显示设备将进行水平同步操作。 - `params->dsi.horizontal_backporch=20`:水平后肩,表示水平同步信号结束后到下一帧图像数据开始之间的像素数。在此像素数内,显示设备将进行水平后肩操作。 - `params->dsi.horizontal_frontporch=40`:水平前肩,表示上一帧图像数据结束到水平同步信号开始之间的像素数。在此像素数内,显示设备将进行水平前肩操作。 - `params->dsi.PLL_CLOCK=421`:像素时钟频率,表示每秒传输的像素数。该参数用于控制显示设备的刷新率和分辨率。 这些参数用于调整显示设备的同步和间隔,以确保图像正确地显示在屏幕上。具体数值的设置可能会根据具体的显示设备和需求而有所不同。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值