1 技术分享 | i.MX8M Mini适配MIPI转eDP芯片-德赢Vwin官网 网
0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

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

武汉万象奥科 2024-05-08 13:52 次阅读


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=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"; //默认名字 //SN65DSI86仅支持12 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>; //根据eDP屏的通道数设置,这里为2通道 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, },

修改sn65dsi86驱动以适应我们的板卡,修改drivers/gpu/drm/bridge/ti-sn65dsi86.c,修改DSI正确的模式,防止找不到注册的panel出现报错“couldnotfindanypanelnode”,开机过程中打印1次是正常的,SN65DSI86的驱动找不到Panel会被多次调用,直到找到panel为止。

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,linkisoff”的报错,是因为SN65DSI86默认只支持ASSR模式的eDP屏幕,对于不支持ASSR模式的eDP屏,硬件上则需要将TEST2引脚拉高到1.8V,且修改相关寄存器将芯片从ASSR模式变为支持标准的DP模式,修改如下:

#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

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表德赢Vwin官网 网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • ARM
    ARM
    +关注

    关注

    134

    文章

    9083

    浏览量

    367364
  • Linux
    +关注

    关注

    87

    文章

    11291

    浏览量

    209305
  • MIPI
    +关注

    关注

    11

    文章

    310

    浏览量

    48612
收藏 人收藏

    评论

    相关推荐

    i.MX8M Mini适配MIPIeDP芯片技术案例分享

    此方案使用HD-8MMN-CORE的核心板搭配TI公司的芯片SN65DSI86芯片实现。
    的头像 发表于 05-08 14:14 1233次阅读
    <b class='flag-5'>i.MX8M</b> <b class='flag-5'>Mini</b><b class='flag-5'>适配</b><b class='flag-5'>MIPI</b><b class='flag-5'>转</b><b class='flag-5'>eDP</b><b class='flag-5'>芯片</b><b class='flag-5'>技术</b>案例分享

    米尔推出基于NXP i.MX8M系列芯片的MYD-JX8MX系列开发板

    随着嵌入式及物联网技术的飞速发展,高性能计算的嵌入式板卡已经成为智能产品的基础硬件平台。为响应行业应用和满足客户需求,米尔电子推出基于NXP公司i.MX8M系列芯片的开发平台MYD-JX8MX
    发表于 06-12 11:13 1448次阅读

    迅为i.MX8M Mini开发板-多核异构CPU低功耗

    、RS485等一应俱全。i.MX8M Mini是没有CAN 控制器的,我们通过CAN控制芯片引出了一路CAN接口;网口是自适应的网口,可以自适应成10M 、100
    发表于 06-29 10:29

    i.MX8M Minii.MX8M Nano设计兼容性指导手册

    i.MX 8M Minii.MX 8M Nano设计兼容性指南
    发表于 12-13 06:36

    i.MX8M plus - MIPI CSI 2支持带有虚拟通道ID的数据包?

    我的客户计划使用两个 MT9M114(来自 On-Semi)CMOS 传感器并将两个 MIPI-CSI2 端口合并为一个端口(使用 Lattice FPGA 设备)。我的问题是,i.MX8M Plus
    发表于 03-17 06:41

    请问i.MX8M Plus的MIPI-CSI2接口是否支持非连续时钟?

    你好社区, 请问i.MX8M Plus的MIPI-CSI2接口是否支持非连续时钟?我可以在哪个文件中找到它的信息?
    发表于 03-21 07:07

    最多有多少摄像头可以与i.MX8M plus的2x MIPI-CSI配合使用?

    Plus 的 2x MIPI-CSI 接口。如果 i.mx8M plus 不适合 SVM 应用,还有哪些 NXP AP 芯片组是 SVM 的良好解决方案?
    发表于 03-21 06:20

    i.MX8M Mini PCIe端点测试失败的原因?

    硬件:i.MX8M Mini 客户板软件:L5.4.47_2.2.0客户将他们的板作为标准 PCIe 卡接口连接 x86 PC Linux 5.4.68 并遵循 PCI 测试用户指南测试 i.MX8M
    发表于 03-23 06:30

    i.MX8M Mini支持的最大分辨率是多少?

    各位,我计划使用 4 通道 mipi 将 48MP 相机与 i.MX8M Mini 套件集成。请帮助我了解 imx8m-mini 是否可以从传感器获取 8000x6000 分辨率的
    发表于 04-04 08:55

    i.MX8M Mini LPDDR4-3000迹线长度/延迟匹配怎么处理?

    我目前正在使用 LPDDR4-3000 作为内存设计带有 i.MX8M Mini 的定制 PCB。在将 LPDDR4-3000 路由到 i.MX8M Mini 时,我有多个问题。我知道
    发表于 04-20 07:44

    i.MX8M系列总计算能力如何?

    我们正在评估 i.mx8m 系列(i.mx8mi.mx8m plus 等)的总计算能力,包括 cpu 和 npu。
    发表于 04-24 07:39

    i.MX8M Mini不支持VPU H1编码器图像缩小?

    在使用 H1 将视频编码为 H.264 之前,我尝试在 i.MX8M Mini 上使用图像缩小器。 但是函数EWLReadAsicConfig () 返回cfg_info
    发表于 05-04 09:02

    如何为i.MX8M Plus构建SCFW?

    我们正在推出一款基于 i.MX8M Plus 的新板。我找到了技术说明 AN13275.pdf,其中包含有关编译所有软件的说明。 我目前被困在 SCFW 上。我已经下载了 SCFW 移植工具包,其中
    发表于 05-17 12:58

    米尔科技恩智浦i.MX8Mi.MX8M Mini的区别

    很多客户看到米尔电子MYC-C8MMX核心板及开发板、MYC-JX8MX核心板及开发板后都对恩智浦i.MX8Mi.MX8M Mini产生一
    的头像 发表于 11-25 09:03 6748次阅读
    米尔科技恩智浦<b class='flag-5'>i.MX8M</b>与<b class='flag-5'>i.MX8M</b> <b class='flag-5'>Mini</b>的区别

    【数字交通新力量】基于i.MX8M Plus核心板的RSU应用案例-飞凌嵌入式

    基于i.MX8M Plus核心板的RSU应用案例
    的头像 发表于 03-13 14:09 775次阅读
    【数字交通新力量】基于<b class='flag-5'>i.MX8M</b> Plus核心板的RSU应用案例-飞凌嵌入式