正点原子嵌入式linux驱动开发——RGB转HDMI

news2025/1/18 5:38:50

目前大多数的显示器都提供了HDMI接口,HDMI的应用范围也越来越广,但是STM32MP157这颗芯片原生并不支持HDMI显示。可以通过RGB转HDMI芯片将RGB信号转为HDMI信号,这样就可以连接HDMI显示器了。本章就来学习一下如何在正点原子的STM32MP1开发板上实现RGB转HDMI。

RGB转HDMI简介

STM32MP157这颗SOC没有HDMI外设,只有RGB屏幕接口,因此只能通过RGB转HDMI的芯片来实现HDMI连接。效果肯定是没法和原生支持HDMI接口的SOC比,当个玩具来玩一下还是可以的。因此本质上来讲还是RGB驱动,并非原生的HDMI驱动。

正点原子的STM32MP1开发板提供了RGB转HDMI模块,如下图所示:

SiI9022A芯片

这里使用SiI9022A这颗芯片来完成RGB转HDMI。SiI9022A以前是Silicon Image公司出品的,但是Silicon Image后来被Lattice收购了。

SiI9022A是一款HDMI传输芯片,适用于高清便携相机、数字相机和个人移动设备,可以灵活的将其他音视频接口转换为HDMI或者DVI格式。SiI9022A支持预编程HDCP键码,可以完全自动进行HDCP检测和鉴定。SiI9022A是一个视频转换芯片,支持输入视频格式有:xvYCC、BTA-T1004、ITU-R.656,内置DE发生器支持SYNC格式(RGB格式)。输出格式支持:HDMI、HDCP和DVI、最高支持1080P视频输出、支持HDMI A、HDMI C和Micro-D连接器。SiI9022A功能非常多,具体使用什么功能需要进行配置,因此SiI9022A提供了一个I2C接口用于配置

硬件原理图分析

先进行SiI9022A的硬件原理分析,打开开发板底版原理图,原理如下图所示:

SiI9022A原理图

上图就是板载的HDMI接口,在图中可以看出HDMI模块分为4部分:RGB接口、I2C2接口、I2S2音频接口和HDMI_CEC接口。主要还是使用RGB接口引脚获取显示数据,SiI9022A使用I2C来进行配置,这里使用STM32MP1的I2C2接口, 使用到了到PH4和PH5这两个引脚。另外还有一个中断INT一个复位HDMI_RESET分别连接到PH6和PA3引脚上。在本篇笔记里主要是实现HDMI的显示功能,其它接口就不用管它。

实验驱动编写

修改设备树

设置I2C2的pinmux

如果要实现HDMI显示,就要给SiI9022A提供RGB接口和I2C2接口,RGB接口在在之前的LCD屏幕的实验中已经有过学习,这里就不再讲解了。主要看一下I2C2接口的pinmux配置,打开stm32mp15-pinctrl.dtsi文件,然后找到如下内容:

示例代码 42. 3.1.1 I2C2 的 pinmux
1  i2c2_pins_a: i2c2-0 { 
2      pins { 
3          pinmux = <STM32_PINMUX('H', 4, AF4)>, /* I2C2_SCL */ 
4                  <STM32_PINMUX('H', 5, AF4)>; /* I2C2_SDA */ 
5          bias-disable; 
6          drive-open-drain; 
7          slew-rate = <0>; 
8      }; 
9  }; 
10 
11 i2c2_pins_sleep_a: i2c2-1 { 
12     pins {
13         pinmux = <STM32_PINMUX('H', 4, ANALOG)>, /* I2C2_SCL */ 
14                 <STM32_PINMUX('H', 5, ANALOG)>; /* I2C2_SDA */ 
15     }; 
16 };

示例代码42.3.1.1中,定义了I2C2接口的两个pinmux配置分别为:i2c2_pins_a和i2c2_pins_sleep_a。第一个默认的状态下使用,第二个是在sleep状态下使用。

添加HDMI的电源节点

Sii9022A需要一个1.2V电压,这个开发板上已经提供了,原理图上的XC6206P122MR芯片就是1.2V电源芯片。还需要在设备树中添加1.2V电压节点,供Sii9022A驱动程序使用。打开stm32mp157d-atk.dts文件,在根节点下添加如下内容所示:

示例代码 42. 3.1.2 HDMI 的电源节点
1 v1v2_hdmi regulator v1v2 hdmi {
2     compatible "regulator fixed"
3     regulator name "v1v2_
4     regulator min microvolt 1200000
5     regulator max microvolt 1200000
6     regulator always on
7     regulator boot on
8 };

这个就是提供一个简单的电压。

在i2c2节点追加HDMI子节点

在学习LCD驱动就有学到,RGB接口是不用再次修改的,只需要提供一个接口用来接收LTDC数据,HDMI就是用来接收LTDC接口的。在stm32mp157d-atk.dts文件下,用追加节点方式,把i2c2节点追加如下内容:

示例代码 4 2.3.1.3 追加的 I 2C2 节点内容
1  &i2c2 {
2      pinctrl-names = "default", "sleep";
3      pinctrl-0 = <&i2c2_pins_a>;
4      pinctrl-1 = <&i2c2_pins_sleep_a>;
5      status = "okay";
6
7      hdmi: hdmi-transmitter@39 {
8          compatible = "sil,sii9022";
9          reg = <0x39>;
10         iovcc-supply = <&v3v3>;
11         cvcc12-supply = <&v1v2_hdmi>;
12         reset-gpios = <&gpioa 3 GPIO_ACTIVE_LOW>;
13         interrupts = <6 IRQ_TYPE_EDGE_FALLING>;
14         interrupt-parent = <&gpioh>;
15         #sound-dai-cells = <1>;
16         status = "okay";
17
18         ports {
19             #address-cells = <1>;
20             #size-cells =<0>;
21
22             port@0 {
23                 reg = <0>;
24                 sii9022_in: endpoint {
25                     remote-endpoint = <&ltdc_ep0_out>;
26                 };
27             };
28         };
29     };
30 };

第2-4行,配置了I2C2的两个pinmux设置。

第7-29行,就是I2C2下的HDMI子节点,接着就分析这个节点比较重要的属性的作用。第12行,设置复位引脚为PA3,低电压有效。第13-14行,设置中断引脚为PH6,下降沿有效。第22-27行,port节点就是用来接收LTDC数据的接口,第25行就是引用了ltdc_ep0_out节点。

这里只是告诉了HDMI从LTDC接口获取数据,还需要告诉LTDC节点数据输出到HDMI,需要修改ltdc节点,修改完成以后的ltdc节点如下所示:

示例代码 4 2.3.1.4 基于 H DMI 接口的 L TDC
1  &ltdc {
2      pinctrl-names = "default", "sleep";
3      pinctrl-0 = <&ltdc_pins_b>;
4      pinctrl-1 = <&ltdc_pins_sleep_b>;
5      status = "okay";
6
7      port {
8          #address-cells = <1>;
9          #size-cells = <0>;
10
11         ltdc_ep0_out: endpoint@0 {
12             reg = <0>;
13             remote-endpoint = <&sii9022_in>;
14         };
15     };
16 };

第13行,就是告诉LTDC接口,数据输出到HDMI。

注意,需要将panel_rgb节点屏蔽掉,否则编译设备树的时候会如下所示警告:

Warning (graph_endpoint): /panel-rgb/port/endpoint: graph connection to node '/soc/display-controller@5a001000/port/endpoint@0' is not bidirectional

最后执行“make dtbs”命令,重新编译设备树。

使能内核自带sii902x驱动

ST提供的linux内核已经集成了sii902x驱动了同时已经使能了,还是需要看看如何使能这个配置,配置路径如下:

-> Device Drivers
-> Graphics support
-> Display Interface Bridges
-> <*> Silicon Image sii902x RGB/HDMI bridge //选中

将sii902x驱动编译进Linux内核中,如下图所示:

使能sii902x驱动

内核默认已经使能了sii902x驱动,如果没使能的话就按照上述方法使能,然后重新编译内核,得到新的内核和设备树。

RGB转HDMI测试

使用HDMI线将开发板和显示器连接起来,然后使用新编译得到的内核和设备树启动开发板,如果驱动工作正常,那么就会在HDMI显示器上显示信息,如下图所示(屏幕截图):

显示器显示

至此HDMI驱动工作正常,可以使用HDMI显示器来进行Linux下的图形开发,但是本教程后续依旧会使用LCD屏幕,可以根据自己的喜好选择HDMI显示器还是LCD屏幕即可。

总结

这一章比较简单,只要在设备树里面,添加hdmi的电源节点,然后在i2c2节点下追加hdmi子节点,最后在ltdc节点的remote-endpoint修改成hdmi。这样就可以使用HDMI显示屏来进行开发了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1133664.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

听说嵌入式门槛很高,值不值得学习?工资怎么样?

今日话题&#xff0c;嵌入式门槛很高&#xff0c;值不值得学习呢&#xff1f;关于嵌入式领域的门槛和薪酬&#xff0c;我有着五年的实际经验&#xff0c;我的看法是嵌入式岗位的门槛一般来说并不太高。只需掌握一些C语言编程和单片机知识&#xff0c;制作一个简单的电子产品就可…

会声会影2024 无损激活解锁完整旗舰版大师套装

会声会影2024 无损激活解锁完整旗舰版大师套装是功能非常强大的视频编辑软件&#xff0c;非常专业的使用效果&#xff0c;会声会影2024中文版可以针对剪辑电影进行使用&#xff0c;非常强大的色彩校正方式&#xff0c;无论什么光线下进行拍摄&#xff0c;都可以通过后期进行调整…

LinkedHashMap 源码解析

目录 一. 前言 二. 源码解析 2.1. 类结构 2.2. 成员变量 2.3. 构造方法 2.4. accessOrder 2.5. 添加元素 2.6. 获取元素 2.7. 删除元素 2.8. 迭代器 三. LRU简单实现 一. 前言 HashMap元素插入是无序的&#xff0c;为了让遍历顺序和插入顺序一致&#xff0c;我们可以…

海外网红评论:激发更高转化率的关键

随着社交媒体的兴起&#xff0c;海外网红营销已经成为企业推广产品和服务的一种重要方式。然而&#xff0c;在众多的海外网红营销策略中&#xff0c;网红评论的重要性往往被低估。事实上&#xff0c;海外网红评论可以在提高转化率方面发挥关键作用。本文Nox聚星将和大家深入探讨…

linux中好玩的数据流定向和管道命令一

知识点复习&#xff1a; 什么是数据流定向&#xff0c;个人理解就是将 一些结果信息不打印在屏幕上&#xff0c;而是定位在某一个文件里面 ll /wdf > file 会覆盖file的原内容 ll /wdf >> 会追加到原文件后面 比如在自己的目录新建1.TXT&#xff0c; 2.txt ll /…

制药企业计算机化系统验证(CSV)的重要性

上次我们介绍了>>《制药机械(设备)计算机化系统验证指南》&#xff0c;本期我们就来展开讲讲制药企业为什么需要以及如何进行计算机化系统验证。 计算机化系统验证&#xff08;Computerized Systems Validation&#xff0c;简称CSV&#xff09;是一种确保计算机化系统在药…

Java 新手如何使用Spring MVC 中的查询字符串和查询参数?

文章目录 什么是查询字符串和查询参数&#xff1f;步骤 1:步骤 2:步骤 3:步骤 4: 结论 &#x1f389;欢迎来到架构设计专栏~探索Java中的静态变量与实例变量 ☆* o(≧▽≦)o *☆嗨~我是IT陈寒&#x1f379;✨博客主页&#xff1a;IT陈寒的博客&#x1f388;该系列文章专栏&…

利用Jmeter对WebRTC应用进行压力测试

说明&#xff1a;WebRTC是一款开源的多人即时视频API&#xff0c;与一般的http请求不同&#xff0c;webrtc应用实际压力主要是码流 最近负责了一个WebRTC的视频会议性能测试&#xff0c;也蛮有意思的&#xff0c;因此将压测方案、思路记录下来 一、测试思路 1、WebRTC多人会…

安科瑞余压监控系统

安科瑞 崔丽洁 机械加压送风系统中为什么要设计旁通阀控制加压送风的正压值&#xff1f;火灾发生后&#xff0c;又能起到什么作用呢&#xff1f; 发生火灾时&#xff0c;绝大多数的人员伤亡不是因为火&#xff0c;而是烟气&#xff0c;随着可燃物的燃烧产生大量的高温烟气&…

【数据结构与算法】二叉树的知识讲解

目录 一&#xff0c;二叉树的结构深入认识 二&#xff0c;二叉树的遍历 三&#xff0c;二叉树的基本运算 3-1&#xff0c;计算二叉树的大小 3-2&#xff0c;统计二叉树叶子结点个数 3-3&#xff0c;计算第k层的节点个数 3-4&#xff0c;查找指定值的结点 一&#xff0c;二叉…

栈(Stack)的概念+MyStack的实现+栈的应用

文章目录 栈&#xff08;Stack&#xff09;一、 栈的概念1.栈的方法2.源码分析 二、MyStack的实现1.MyStack的成员变量2.push方法3.isEmpty方法和pop方法4.peek方法 三、栈的应用1.将递归转化为循环1.调用递归打印2.通过栈逆序打印链表 栈&#xff08;Stack&#xff09; 一、 栈…

【Javascript】数组的进阶操作

目录 splice 截取部分元素&#xff0c;保留剩下元素 清空数组 join 自定义分割符 concat 连接 a连接b b连接a a连接b,c 不会改变原数组 splice ⽤于删除或替换元素函数有返回值&#xff0c;返回的是被删除的元素这个⽅法会改变原来的数组 截取部分元素&#xff0…

黑金测评:电视盒子哪款好?双十一热销电视盒子排行榜

大家好&#xff0c;本期我们要分享的测评内容是关于电视盒子&#xff0c;双十一很多网友打算购入电视盒子&#xff0c;但并不了解电视盒子哪款好&#xff0c;本期我们自费测评了最热门的十款电视盒子&#xff0c;最终筛选出了五款最值得入手的电视盒子整理了这份电视盒子排行榜…

rust学习——智能指针

智能指针 在各个编程语言中&#xff0c;指针的概念几乎都是相同的&#xff1a;指针是一个包含了内存地址的变量&#xff0c;该内存地址引用或者指向了另外的数据。 在 Rust 中&#xff0c;最常见的指针类型是引用&#xff0c;引用通过 & 符号表示。不同于其它语言&#xf…

HCIA数据通信——基础设备配置

想了想&#xff0c;为了方便回顾复习&#xff0c;将理论和实践结合起来才是正确的&#xff0c;不然一边理论&#xff0c;又单独做实验这样不方便。 因此之前的文章都删了&#xff0c;还是以华为从头开始吧&#xff01;实验与理论应用结合起来做。 一&#xff0c;查看设备信息 …

大数据Flink(一百零二):SQL 聚合函数(Aggregate Function)

文章目录 SQL 聚合函数(Aggregate Function) SQL 聚合函数(Aggregate Function) Python UDAF,即 Python AggregateFunction。Python UDAF 用来针对一组数据进行聚合运算,比如同一个 window 下的多条数据、或者同一个 key 下的多条数据等。针对同一组输入数据,Python A…

【Linux】-docker配置容器并打包成镜像

查看本地的镜像: 容器和镜像的关系&#xff1a;容器是Object 镜像是class 一个镜像可以多个容器 docker commit 容器id 新镜像名称:版本号 运行容器&#xff1a; docker run -i -t ubuntu /bin/bash docker exec -it -u root zwbase /bin/bashdocker exec -it 会连接到容器…

部署基于efk+logstash+kafka构建日志收集平台并对nginx日志进行分析【待执行】

文章目录 1.1 安装zookeeper集群1.2 Zookeeper 配置1.2 安装kafka集群1.3 部署filebeat服务1.4 部署logstash1.5 部署es和kibana服务1.6 配置kibana ui界面1.7 对nginx进行日志分析 Filebeat采集日志kafka topic存起来日志->logstash去kafka获取日志&#xff0c;进行格式转换…

Qt 序列化函数和反序列化函数

文章目录 界面学生类序列化函数反序列化函数刷新所选择的下拉表值添加 界面 学生类 // 创建学生信息类 class studentInfo { public:QString id; // 学号QString name; // 学生姓名QString age; // 学生年龄// 重写QDataStream& operator<<操作符&…

Linux---(四)权限

文章目录 一、shell命令及运行原理1.什么是操作系统&#xff1f;2.外壳程序3.用户为什么不直接访问操作系统内核?4.操作系统内核为什么不直接把结果显示出来&#xff1f;非要加外壳程序&#xff1f;5.shell理解重点总结&#xff08;1&#xff09;shell是什么&#xff1f;&…