专栏中心

EEPW首页 > 专栏 > 技术分享 | i.MX8M Mini适配MIPI转eDP芯片

技术分享 | i.MX8M Mini适配MIPI转eDP芯片

发布人:武汉万象奥科 时间:2024-05-08 来源:工程师 发布文章
1.方案概述

此方案使用HD-8MMN-CORE的核心板搭配TI公司的芯片SN65DSI86转换芯片实现。

SN65DSI86作为一款MIPI DSI转eDP的芯片,支持双通道DSI输入,最大四通道显示输出,最大支持4K@60fps输出,WUXGA 1080P。本方案中将采用单通道DSI输入,双通道DP输出到1080p的屏幕。

HD8MMN-CORE系列工业级核心板基于NXP(Freescale) i.MX8MM系列Cortex-A53高性能处理器设计,支持硬件加密,支持摄像头接口、USB3.0接口、HDMI/MIPI、PCIe、千兆以太网接口、多路串口等,适用于快速开发一系列最具创新性的应用,如多媒体应用、人机界面、工业4.0、车载终端以及边缘计算设备等。


2.硬件原理图

注:硬件修改REFCLK上需要贴上27M的晶振,TEST2引脚需要通过4.7K电阻上拉到1.8V.

3软件实现3.1软件介绍

内核版本:Linux5.10;

SN65DSI86驱动:drivers/gpu/drm/bridge/ti-sn65dsi86.c

Panel驱动:drivers/gpu/drm/panel/panel-simple.c


3.2

CONFIG_DRM_TI_SN65DSI86=yCONFIG_DRM_PANEL_SIMPLE=y


1)
/ {        osc_27m: clock-osc-27m {                compatible = "fixed-clock";                #clock-cells = <0>;                clock-frequency = <27000000>;                clock-output-names = "osc_27m";        };
       lcd_backlight: lcd_backlight {                compatible = "pwm-backlight";                pwms = <&pwm1 0 100000>;                status = "okay";
               brightness-levels = < 0  1  2  3  4  5  6  7  8  9                                     10 11 12 13 14 15 16 17 18 19                                     20 21 22 23 24 25 26 27 28 29                                     30 31 32 33 34 35 36 37 38 39                                     40 41 42 43 44 45 46 47 48 49                                     50 51 52 53 54 55 56 57 58 59                                     60 61 62 63 64 65 66 67 68 69                                     70 71 72 73 74 75 76 77 78 79                                     80 81 82 83 84 85 86 87 88 89                                     90 91 92 93 94 95 96 97 98 99                                    100>;                enable-gpios = <&gpio1 1 GPIO_ACTIVE_HIGH>;                default-brightness-level = <80>;        };        panel {                compatible = "test,test-edp-1080p";        //                backlight = <&lcd_backlight>;                no-hpd;
               port {                        panel1_in: endpoint {                                remote-endpoint = <&sn65_out>;                        };                };        };};&pwm1 {        pinctrl-names = "default";        pinctrl-0 = <&pinctrl_pwm1>;        status = "okay";};
&i2c4 {        clock-frequency = <400000>;        pinctrl-names = "default";        pinctrl-0 = <&pinctrl_i2c4>;        status = "okay";        sn65dsi86@2d {               .                clock-names = "refclk";          //          //SN65DSI8612 MHz, 19.2 MHz, 26 MHz, 27 MHz or 38.4 MHz.                clocks = <&osc_27m>;
                                     port@1 {                                reg = <1>;                                sn65_out: endpoint {                                        //data-lanes = <0 1 2 3>;                  //eDP2                                        data-lanes = <0 1>;


2)

drivers/gpu/drm/panel/panel-simple.c


tatic const struct display_timing test_edp_1080p_timing = {        .pixelclock = { 153000000, 153000000, 153000000 },        .hactive = { 1920, 1920, 1920 },        .hfront_porch = { 100, 100, 100 },        …..        .bus_format = MEDIA_BUS_FMT_RGB666_1X18,        .connector_type = DRM_MODE_CONNECTOR_eDP,    };static const struct of_device_id platform_of_match[] = {        {                .compatible = "test,test-edp-1080p",                .data = &test_edp_1080p,        },


sn65dsi86drivers/gpu/drm/bridge/ti-sn65dsi86.cDSIpanelcouldnotfindanypanelnode1SN65DSI86Panelpanel

static int ti_sn_bridge_attach(struct drm_bridge *bridge,enum drm_bridge_attach_flags flags){...          //dsi->mode_flags = MIPI_DSI_MODE_VIDEO;        dsi->mode_flags = MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_SYNC_PULSE |                          MIPI_DSI_MODE_EOT_PACKET | MIPI_DSI_MODE_VIDEO_HSE;


3)Linktrainingfailed,linkisoffSN65DSI86ASSReDPASSReDPTEST21.8VASSRDP


#define SN_ENH_FRAME_REG                        0x5A#define  ASSR_CONTROL                           BIT(0)...
static int ti_sn_link_training(struct ti_sn_bridge *pdata, int dp_rate_idx,const char **last_err_str)    {        unsigned int val;int ret;int i;
/* set dp clk frequency value */        regmap_update_bits(pdata->regmap, SN_DATARATE_CONFIG_REG,                           DP_DATARATE_MASK, DP_DATARATE(dp_rate_idx));
       regmap_write(pdata->regmap, 0xff, 0x07);        regmap_write(pdata->regmap, 0x16, 0x01);        regmap_write(pdata->regmap, 0xff, 0x00);/* For DisplayPort, use the standard DP scrambler seed. */        regmap_update_bits(pdata->regmap, SN_ENH_FRAME_REG,ASSR_CONTROL, 0);/* enable DP PLL */        regmap_write(pdata->regmap, SN_PLL_ENABLE_REG, 1);...


eDP


[ 2.299284] ti_sn65dsi86 3-002d: [drm:ti_sn_bridge_enable] ERROR Can't read lane count (-6); assuming 4           [ 2.765851] ti_sn65dsi86 3-002d: [drm:ti_sn_bridge_enable] ERROR Can't read eDP rev (-6), assuming 1.1




专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们

关键词: NXP i.MX8M Mini Display Linux ARM MIPI转eDP显示 SN65DSI86

相关推荐

聚积科技首度参与SID Display Week展现多元背光卓越成功案例与创新解决方案

边缘 AI 加速的 Arm Cortex‑M0+ MCU 如何为电子产品注入更强智能

​Arm 宣布推出 Performix,为开发者带来 AI 时代必备的可扩展性能

2026-05-07

走进智能工厂 为何智能诊断是持续运行的关键

WinCE+ARM开发及关键技术 下

视频 2009-10-22

ARM Axion 处理器加持谷歌第八代 TPU,云端全面转向智能体 AI 架构

ARM嵌入式系统开发:软件设计与优化

Arm财报过山车:营收创纪录,股价跌7%

ARM开发详解

最新ARM技术和嵌入式技术发展动态 下

视频 2009-10-22

汽车暖通空调(HVAC)控制参考设计

WinCE+ARM开发及关键技术 上

视频 2009-10-22

Arm遭遇监管危机:FTC针对其技术授权启动反垄断调查

2026-05-18

arm学习资料

资源下载 2007-12-03

ARM嵌入式软件编程经验谈

Arm CEO:AI智能体将推动CPU核心数升至 512

网络与存储 2026-05-11

ARM嵌入式系统开发

Arm宣布推出Performix,为开发者带来 AI 时代必备的可扩展性能

最新ARM技术和嵌入式技术发展动态 中

视频 2009-10-22

ARM 展示小型低功耗上网本样品

视频 2009-03-16
更多 培训课堂
更多 焦点
更多 视频

技术专区