0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

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

3天内不再提示

峰会回顾第10期 | 开源图形驱动在OpenHarmony上的使用和落地

OpenHarmony TSC 来源:OpenHarmony TSC 作者:OpenHarmony TSC 2023-05-15 09:30 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

演讲嘉宾 | 黄 然

回顾整理 | 廖 涛

排版校对 | 李萍萍

12114eb4-f2c0-11ed-a6d0-dac502259ad0.png

嘉宾简介

黄然,华为终端BG软件部资深图形技术专家,华为终端游戏标准、工具和分析创始人,GPU Turbo黑科技核心成员,在OpenHarmony社区上担任开源图形驱动SIG、游戏SIG、兼容性工作组组长等职务。

内容来源

第一届开放原子开源基金会OpenHarmony技术峰会——OS内核及视窗分论坛

正 文 内 容

图形驱动也是一种软件程序,它串联了操作系统和应用程序与计算机图形硬件进行通信和交互,是发挥硬件性能为操作系统提供高质量图形显示的关键环节。OpenHarmony在开源图形驱动的使用和落地上做了哪些工作呢?OpenHarmony游戏SIG组、图形驱动SIG组组长、华为终端图形资深技术专家黄然在第一届OpenHarmony技术峰会上给大家带来了几点分享。

125998e0-f2c0-11ed-a6d0-dac502259ad0.png

01

OpenHarmony图形驱动面临的挑战

图形驱动技术的演进始终跟GPU硬件的发展相关。1975年至今,随着GPU硬件由早期的专业领域高端图形工作站发展到台式机GPU显卡,再到如今的移动终端、云和服务器GPU显卡,图形驱动API也由OpenGL演进到了DirectX。

12f11dc8-f2c0-11ed-a6d0-dac502259ad0.png

目前,图形驱动领域的主流厂商都对自身的核心代码闭源,Arm Mali、Qualcomm Adreno和Nvidia等开源图形驱动也并没有特别“Open”。

随着开源运动的兴起和成功,AMD英特尔等公司的图形驱动开源建立了良好的生态,也取得了不错的效果。对OpenHarmony这样一个完全开源的操作系统来说,图形开源驱动有很好的借鉴和学习意义,当然也存在着诸多挑战。掌握开源图形驱动有多难呢?首先图形驱动的开发和研究需要具备扎实的软硬件开发功底,且由于开源图形驱动在国内的发展很慢,少有开发者专门从事该项工作,缺乏技术交流和实践经验分享。下图为黄然老师前期在开源驱动领域学习和研究所做的笔记:

此外,对于OpenHarmony来说,当前大部分的小厂商无法获得闭源GPU厂商的支持,导致视觉流畅体验较差,限制了非常多OpenHarmony产品的商用,在一定程度上也阻碍了OpenHarmony生态的推广。

02

开源图形驱动架构介绍

由于从驱动角度,OpenHarmony富设备的内核是基于Linux的,故首先介绍下Linux开源驱动的整体架构。整个驱动的架构可以分为2D和3D两个部分,2D部分的比较老的框架是基于X11,而比较新的框架是基于Wayland。

3D的部分驱动通过mesa,将OpenGLES或者Vulkan的API以及shader转化为硬件的ISA。而2D的DDX驱动通过glamor也可以走到mesa层,这样避免了2D和3D分岔的驱动路线(过去曾经是分岔的,2D走DDX)。

整体的驱动是UMS+KMS结构,UMS负责用户层驱动的解析,而KMS用来做显示和硬件渲染,通过libdrm和DRM来形成UMS到KMS的传递。

1347dd7a-f2c0-11ed-a6d0-dac502259ad0.png

在图形驱动中有几个关键概念:

一是LLVM、TGSI和Gallium。TGSI是一种用于描述着色器的中间语言,是所有驱动程序使用的唯一中间表示,所有的Shader都会转化为中间的IR。而Gallium是LLVM的后端,能够基于不同硬件进行不同硬件的ISA绘制,如图中的radeonsi就是AMD的radeon的后端渲染。

13930106-f2c0-11ed-a6d0-dac502259ad0.png

二是ISA。ISA由控制流(CF)指令、ALU指令、通过纹理缓存提取的指令和通过顶点缓存提取的指令组成,其中控制流程序通过使用控制流指令(条件跳转、循环和子例程)来指导程序子句的流,包括内存分配指令和其他指令,这些指令可以指定顶点和几何程序何时完成相关操作,类似CPU汇编语言。

三是Fence。Fence能够让GPU和CPU协调工作,提高图像显示的速度。通过Fence机制产生的GPU的事件,能够保证用户态程序下发的渲染命令被顺序执行,从而保证上层应用程序渲染相关数据的一致性。

13aa541e-f2c0-11ed-a6d0-dac502259ad0.png

03

开源图形驱动在OpenHarmony上的移植

OpenHarmony驱动框架支持多种接入模式,能够实现南向硬件的快速部署。其中,显示框架支持Display_Gralloc、Display_Gfx和Device HDI的3类南向接口,其中,Display_Gralloc负责内存分配;Display_Gfx负责图形硬件2D绘制,可以用于离线合成;Device HDI负责显示设备特性管理,包括屏幕显示,在线及离线硬件合成,硬件Vsync,显示设备色彩管理等。在开发板能力支持方面,RK3568和HI3516dv300支持DRM内存分配、DRM送显以及硬件离线合成,HI3751V350支持支持FbDev 和DmaBuf-Heap、支持FbDev显示,不支持硬件离线合成。

13b66844-f2c0-11ed-a6d0-dac502259ad0.png

针对上述OpenHarmony驱动框架的整体情况,开源GPU驱动的适配工作主要分为以下3个阶段进行:(1)验证内核panfrost驱动和用户态panfrost驱动可以正常工作;(2)开源GPU驱动适配OpenHarmony(Flutter+weston)旧框架;(3)开源GPU驱动适配OpenHarmony(RenderService)新框架。目前,越来越多的兴趣开发者参与到了OpenHarmony的开源图形驱动适配和移植的工作中,近期有一些用户已经成功将高通开源驱动移植到移动终端上,使其能够运行一些2D和3D的应用。这意味着开源驱动在OpenHarmony上生态正在朝着良好的方向发展。

从GLmark2跑分情况来看,OpenHarmony开源驱动在2D的纹理处理等方面表现比闭源驱动优异,在关键的着色和阴影、地形等偏3D的方面表现还较差。即便如此,在2D和3D开源图形驱动上的性能提升已经足以满足绝大多数产品的需求。

当然,在这个过程中,还有一些伙伴参考当前的工作,把高通的freedreno开源驱动也完成了移植,并且可以在小米等手机上可以运行和使用开源驱动,如下:

13cb5a24-f2c0-11ed-a6d0-dac502259ad0.png

未来我们还会在X86基础的AMD以及Intel GPU上使能开源驱动,服务于OpenHamrony,也希望更多的小伙伴可以一起加入社区微信群SIG-OpenGfxDrv共建图形驱动,对应的gitee链接为:https://gitee.com/openharmony/third_party_mesa3d

04

总结&展望

真正想做好图形竞争力,就要了解GPU的工作机制和图形驱动原理,OpenHarmony社区正是一个交流和学习的良好平台;OpenHarmony开源图形驱动是未来趋势,也会是历史最终选择,希望有越来越多的兴趣开发者能够参与到开源图形驱动的适配和移植工作中来,共建OpenHarmony生态。

E N D

点击下方阅读原文获取演讲PPT。

关注我们,获取更多精彩。


审核编辑黄宇


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

    关注

    3

    文章

    4046

    浏览量

    45585
  • OpenHarmony
    +关注

    关注

    31

    文章

    3928

    浏览量

    20729
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    活动邀请 | 相约2025 GOTC全球开源技术峰会,与M5Stack共探AI驱动造物新未来

    一年一度的GOTC全球开源技术峰会将于2025年11月1日至2日北京通州通明湖会展中心盛大举行。本届峰会以“万源共振,智构未来”为主题,汇聚国内外技术专家、企业代表与创客社区力量,聚
    的头像 发表于 10-31 16:31 1574次阅读
    活动邀请 | 相约2025 GOTC全球<b class='flag-5'>开源</b>技术<b class='flag-5'>峰会</b>,与M5Stack共探AI<b class='flag-5'>驱动</b>造物新未来

    2025开放原子园区行暨小米开源峰会圆满落幕

    近日,开放原子园区行(小米站)暨2025小米开源峰会在小米园区成功举办。本次活动聚焦推动开源落地产业一线,不仅展示了开源技术最新成果,更以搭
    的头像 发表于 10-30 09:36 377次阅读

    【置顶公告】视美泰开源鸿蒙系列产品业务咨询与商务合作通道正式开启!

    尊敬的电子发烧友社区成员、合作伙伴及行业同仁: 视美泰作为开源鸿蒙(OpenHarmony)生态的积极推动者,始终致力于为行业提供高性能、高可靠性的智能硬件解决方案及生态赋能服务。为进一步深化
    发表于 10-20 16:23

    第三届大会回顾3 | FFRT并发框架在OpenHarmony中的设计与实践

    ,特别是多核处理器,可以显著提高程序的运行速度和整体性能,从而改善用户体验。OpenHarmony的FFRT并发编程模型为开发者提供了构建异步并发任务的能力,以更高效地开发和管理并发任务。FFRT是如何设计与实现的,有哪些重
    的头像 发表于 06-21 16:53 993次阅读
    第三届大会<b class='flag-5'>回顾</b><b class='flag-5'>第</b>3<b class='flag-5'>期</b> | FFRT并发框架在<b class='flag-5'>OpenHarmony</b>中的设计与实践

    开源鸿蒙图形与游戏分论坛圆满举办

    近日,开源鸿蒙开发者大会2025(OHDC.2025)图形与游戏分论坛深圳圆满举办。本次分论坛由开源鸿蒙图形SIG & 游戏SIG组组长、
    的头像 发表于 06-05 15:30 1111次阅读

    请问下,openharmony支持哪一款龙芯的开发板?有没有开源的龙芯的openharmony源码?

    想买个2k0300的开发板学习龙芯和openharmony,愣是没有看到提供openharmony源码的,也没与看到开源的代码。giteeope
    发表于 04-26 13:06

    OpenHarmony应用开发精品课程第七来啦

    OpenHarmony应用开发精品课程第七来啦
    的头像 发表于 04-15 14:15 517次阅读
    <b class='flag-5'>OpenHarmony</b>应用开发精品课程第七<b class='flag-5'>期</b>来啦

    【北京迅为】iTOP-RK3568开发板OpenHarmony系统南向驱动开发-4章 UART基础知识

    【北京迅为】iTOP-RK3568开发板OpenHarmony系统南向驱动开发-4章 UART基础知识
    的头像 发表于 03-17 15:50 862次阅读
    【北京迅为】iTOP-RK3568开发板<b class='flag-5'>OpenHarmony</b>系统南向<b class='flag-5'>驱动</b>开发-<b class='flag-5'>第</b>4章 UART基础知识

    视美泰受邀出席2025国际开源节暨万物智联生态峰会,共绘开源创新蓝图

    在数字化转型浪潮迭起的时代背景下,国际开源节暨万物智联生态峰会于2025年1月4日至5日中国深圳隆重召开,作为全球开源技术与智能物联网领域的年度盛事,本次
    的头像 发表于 02-05 17:09 737次阅读
    视美泰受邀出席2025国际<b class='flag-5'>开源</b>节暨万物智联生态<b class='flag-5'>峰会</b>,共绘<b class='flag-5'>开源</b>创新蓝图

    回顾OpenHarmony社区2024年度精彩瞬间

    ”或“开源鸿蒙”)社区2024年度工作会议于深圳盛大启幕,这场备受瞩目的盛会汇聚了开源鸿蒙社区众多成员单位,共同回顾过去一年OpenHarmony社区
    的头像 发表于 01-17 12:34 1583次阅读

    软通动力荣获“2024年度开源鸿蒙社区卓越单位”

    近日,一场聚焦开源生态发展的重要盛会——OpenHarmony年度工作会议深圳成功举行。本次会议由开放原子开源基金会指导,OpenHarmony
    的头像 发表于 01-15 15:53 775次阅读

    OpenHarmony城市技术论坛12——合肥站圆满举办

    2024年12月23日,OpenHarmony城市技术论坛(以下简称“技术论坛”)12——合肥站于中国科学技术大学高新校区圆满举办。本次技术论坛聚焦于“智能时代基础软件与数据管理”的主题,深入
    的头像 发表于 12-26 09:14 1314次阅读
    <b class='flag-5'>OpenHarmony</b>城市技术论坛<b class='flag-5'>第</b>12<b class='flag-5'>期</b>——合肥站圆满举办

    圣诞特辑 |开源芯片系列讲座25:RISC-V架构高性能领域的进展与挑战

    鹭岛论坛开源芯片系列讲座25「RISC-V架构高性能领域的进展与挑战」圣诞夜(周三)20:00精彩开播期待与您云相聚,共襄学术盛宴!|直播信息报告题目RISC-V架构
    的头像 发表于 12-24 08:03 1180次阅读
    圣诞特辑 |<b class='flag-5'>开源</b>芯片系列讲座<b class='flag-5'>第</b>25<b class='flag-5'>期</b>:RISC-V架构<b class='flag-5'>在</b>高性能领域的进展与挑战

    鸿蒙原生开源库ViewPoolOpenHarmony社区正式上线

    近日,由伙伴参与共建的鸿蒙原生开源库“ViewPool”OpenHarmony社区正式上线。这个开发库是基于OpenHarmony技术孵化的成果,充分发挥了平台的技术特性,同时融入了
    的头像 发表于 12-20 14:44 855次阅读

    直播预约 |开源芯片系列讲座25:RISC-V架构高性能领域的进展与挑战

    鹭岛论坛开源芯片系列讲座25「RISC-V架构高性能领域的进展与挑战」12月25日(周三)20:00精彩开播期待与您云相聚,共襄学术盛宴!|直播信息报告题目RISC-V架构
    的头像 发表于 12-13 17:01 775次阅读
    直播预约 |<b class='flag-5'>开源</b>芯片系列讲座<b class='flag-5'>第</b>25<b class='flag-5'>期</b>:RISC-V架构<b class='flag-5'>在</b>高性能领域的进展与挑战