精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

技術(shù)分享 | i.MX8M Mini適配MIPI轉(zhuǎn)eDP芯片

武漢萬象奧科 ? 2024-05-08 13:52 ? 次閱讀


1.方案概述

此方案使用HD-8MMN-CORE的核心板搭配TI公司芯片SN65DSI86轉(zhuǎn)換芯片實(shí)現(xiàn)。

SN65DSI86作為一款MIPI DSI轉(zhuǎn)eDP的芯片,支持雙通道DSI輸入,最大四通道顯示輸出,最大支持4K@60fps輸出,WUXGA 1080P。本方案中將采用單通道DSI輸入,雙通道DP輸出到1080p的屏幕。

HD8MMN-CORE系列工業(yè)級(jí)核心板基于NXP(Freescale) i.MX8MM系列Cortex-A53高性能處理器設(shè)計(jì),支持硬件加密,支持?jǐn)z像頭接口、USB3.0接口、HDMI/MIPI、PCIe、千兆以太網(wǎng)接口、多路串口等,適用于快速開發(fā)一系列最具創(chuàng)新性的應(yīng)用,如多媒體應(yīng)用、人機(jī)界面、工業(yè)4.0、車載終端以及邊緣計(jì)算設(shè)備等。

2.硬件原理圖

注:硬件修改REFCLK上需要貼上27M的晶振,TEST2引腳需要通過4.7K電阻上拉到1.8V.

3軟件實(shí)現(xiàn)

3.1軟件介紹

內(nèi)核版本:Linux5.10;

SN65DSI86驅(qū)動(dòng):drivers/gpu/drm/bridge/ti-sn65dsi86.c

Panel驅(qū)動(dòng):drivers/gpu/drm/panel/panel-simple.c

3.2驅(qū)動(dòng)移植

內(nèi)核配置,需要打開如下兩項(xiàng)

CONFIG_DRM_TI_SN65DSI86=y

1)設(shè)備樹配置

/ { 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"; //設(shè)置自己的屏幕匹配參數(shù)組 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"; //默認(rèn)名字 //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>; //根據(jù)eDP屏的通道數(shù)設(shè)置,這里為2通道 data-lanes = <0 1>; ……

2)驅(qū)動(dòng)修改

添加顯示屏的顯示參數(shù)到驅(qū)動(dòng)中,修改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驅(qū)動(dòng)以適應(yīng)我們的板卡,修改drivers/gpu/drm/bridge/ti-sn65dsi86.c,修改DSI正確的模式,防止找不到注冊(cè)的panel出現(xiàn)報(bào)錯(cuò)“couldnotfindanypanelnode”,開機(jī)過程中打印1次是正常的,SN65DSI86的驅(qū)動(dòng)找不到Panel會(huì)被多次調(diào)用,直到找到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)調(diào)試報(bào)錯(cuò)

在調(diào)試過程中碰到“Linktrainingfailed,linkisoff”的報(bào)錯(cuò),是因?yàn)镾N65DSI86默認(rèn)只支持ASSR模式的eDP屏幕,對(duì)于不支持ASSR模式的eDP屏,硬件上則需要將TEST2引腳拉高到1.8V,且修改相關(guān)寄存器將芯片從ASSR模式變?yōu)橹С謽?biāo)準(zhǔn)的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屏幕會(huì)出現(xiàn)如下報(bào)錯(cuò):

[ 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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    134

    文章

    9045

    瀏覽量

    366806
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11225

    瀏覽量

    208916
  • MIPI
    +關(guān)注

    關(guān)注

    11

    文章

    308

    瀏覽量

    48555
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    i.MX8M Mini適配MIPI轉(zhuǎn)eDP芯片技術(shù)案例分享

    此方案使用HD-8MMN-CORE的核心板搭配TI公司的芯片SN65DSI86轉(zhuǎn)芯片實(shí)現(xiàn)。
    的頭像 發(fā)表于 05-08 14:14 ?1151次閱讀
    <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'>轉(zhuǎn)</b><b class='flag-5'>eDP</b><b class='flag-5'>芯片</b><b class='flag-5'>技術(shù)</b>案例分享

    米爾推出基于NXP i.MX8M系列芯片的MYD-JX8MX系列開發(fā)板

    隨著嵌入式及物聯(lián)網(wǎng)技術(shù)的飛速發(fā)展,高性能計(jì)算的嵌入式板卡已經(jīng)成為智能產(chǎn)品的基礎(chǔ)硬件平臺(tái)。為響應(yīng)行業(yè)應(yīng)用和滿足客戶需求,米爾電子推出基于NXP公司i.MX8M系列芯片的開發(fā)平臺(tái)MYD-JX8MX
    發(fā)表于 06-12 11:13 ?1429次閱讀

    迅為i.MX8M Mini開發(fā)板-多核異構(gòu)CPU低功耗

    、RS485等一應(yīng)俱全。i.MX8M Mini是沒有CAN 控制器的,我們通過CAN控制芯片引出了一路CAN接口;網(wǎng)口是自適應(yīng)的網(wǎng)口,可以自適應(yīng)成10M 、100
    發(fā)表于 06-29 10:29

    i.MX8M Mini轉(zhuǎn)i.MX8M Nano設(shè)計(jì)兼容性指導(dǎo)手冊(cè)

    i.MX 8M Mini轉(zhuǎn)i.MX 8M Nano設(shè)計(jì)兼容性指南
    發(fā)表于 12-13 06:36

    i.MX8M plus - MIPI CSI 2支持帶有虛擬通道ID的數(shù)據(jù)包?

    我的客戶計(jì)劃使用兩個(gè) MT9M114(來自 On-Semi)CMOS 傳感器并將兩個(gè) MIPI-CSI2 端口合并為一個(gè)端口(使用 Lattice FPGA 設(shè)備)。我的問題是,i.MX8M Plus
    發(fā)表于 03-17 06:41

    請(qǐng)問i.MX8M Plus的MIPI-CSI2接口是否支持非連續(xù)時(shí)鐘?

    你好社區(qū), 請(qǐng)問i.MX8M Plus的MIPI-CSI2接口是否支持非連續(xù)時(shí)鐘?我可以在哪個(gè)文件中找到它的信息?
    發(fā)表于 03-21 07:07

    最多有多少攝像頭可以與i.MX8M plus的2x MIPI-CSI配合使用?

    Plus 的 2x MIPI-CSI 接口。如果 i.mx8M plus 不適合 SVM 應(yīng)用,還有哪些 NXP AP 芯片組是 SVM 的良好解決方案?
    發(fā)表于 03-21 06:20

    i.MX8M Mini PCIe端點(diǎn)測(cè)試失敗的原因?

    硬件:i.MX8M Mini 客戶板軟件:L5.4.47_2.2.0客戶將他們的板作為標(biāo)準(zhǔn) PCIe 卡接口連接 x86 PC Linux 5.4.68 并遵循 PCI 測(cè)試用戶指南測(cè)試 i.MX8M
    發(fā)表于 03-23 06:30

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

    各位,我計(jì)劃使用 4 通道 mipi 將 48MP 相機(jī)與 i.MX8M Mini 套件集成。請(qǐng)幫助我了解 imx8m-mini 是否可以從傳感器獲取 8000x6000 分辨率的
    發(fā)表于 04-04 08:55

    i.MX8M Mini LPDDR4-3000跡線長度/延遲匹配怎么處理?

    我目前正在使用 LPDDR4-3000 作為內(nèi)存設(shè)計(jì)帶有 i.MX8M Mini 的定制 PCB。在將 LPDDR4-3000 路由到 i.MX8M Mini 時(shí),我有多個(gè)問題。我知道
    發(fā)表于 04-20 07:44

    i.MX8M系列總計(jì)算能力如何?

    我們正在評(píng)估 i.mx8m 系列(i.mx8m、i.mx8m plus 等)的總計(jì)算能力,包括 cpu 和 npu。
    發(fā)表于 04-24 07:39

    i.MX8M Mini不支持VPU H1編碼器圖像縮???

    在使用 H1 將視頻編碼為 H.264 之前,我嘗試在 i.MX8M Mini 上使用圖像縮小器。 但是函數(shù)EWLReadAsicConfig () 返回cfg_info
    發(fā)表于 05-04 09:02

    如何為i.MX8M Plus構(gòu)建SCFW?

    我們正在推出一款基于 i.MX8M Plus 的新板。我找到了技術(shù)說明 AN13275.pdf,其中包含有關(guān)編譯所有軟件的說明。 我目前被困在 SCFW 上。我已經(jīng)下載了 SCFW 移植工具包,其中
    發(fā)表于 05-17 12:58

    米爾科技恩智浦i.MX8Mi.MX8M Mini的區(qū)別

    很多客戶看到米爾電子MYC-C8MMX核心板及開發(fā)板、MYC-JX8MX核心板及開發(fā)板后都對(duì)恩智浦i.MX8Mi.MX8M Mini產(chǎn)生一
    的頭像 發(fā)表于 11-25 09:03 ?6714次閱讀
    米爾科技恩智浦<b class='flag-5'>i.MX8M</b>與<b class='flag-5'>i.MX8M</b> <b class='flag-5'>Mini</b>的區(qū)別

    【數(shù)字交通新力量】基于i.MX8M Plus核心板的RSU應(yīng)用案例-飛凌嵌入式

    基于i.MX8M Plus核心板的RSU應(yīng)用案例
    的頭像 發(fā)表于 03-13 14:09 ?746次閱讀
    【數(shù)字交通新力量】基于<b class='flag-5'>i.MX8M</b> Plus核心板的RSU應(yīng)用案例-飛凌嵌入式