【GPU驅動開發】- mesa編譯與鏈接過程詳細分析

前言

不必害怕未知,無需恐懼犯錯,做一個Creator!

一、總體框架圖

暫時無法在飛書文檔外展示此內容
在這里插入圖片描述

二、Mesa API 處理 OpenGL 函數調用

Mesa API 負責實現 OpenGL 和其他圖形 API 的函數接口。Mesa API 表是一個重要的數據結構,用于存儲 OpenGL 函數的指針、版本信息、擴展支持等。_glapi_table 包含了大量的函數指針,每個指針對應于一個特定的 OpenGL 函數。這些指針在運行時被動態設置為對應的實現函數,例如 glCompileShader()、glLinkProgram() 等。
暫時無法在飛書文檔外展示此內容

src/mesa/shaderapi.c:實現OpenGL API和Mesa函數接口的對應。

三、State Tacker對GLSL代碼鏈接處理

在鏈接過程,state tracker層協調著色器程序的鏈接,將多個著色器鏈接為最終可執行的著色器程序,即NIR。并且將鏈接后的著色器程序最終傳遞給gallium驅動。ST層還管理著色器對象的狀態,包括編譯狀態、鏈接狀態等。
暫時無法在飛書文檔外展示此內容

src/mesa/state_tracker/st_glsl_to_nir.c:在ST層主要實現了 GLSL 到 NIR 的轉換功能,包括 GLSL 程序的鏈接、NIR 的最終化、優化以及統一變量的處理。

四、GLSL 編譯器對GLSL代碼編譯和鏈接處理

在編譯過程,當應用程序通過OpenGL函數調用提交GLSL著色器源代碼時,Mesa API將GLSL代碼傳遞給GLSL編譯器,并進行編譯生成Mesa IR中間表示。
在鏈接過程,ST層負責將Mesa IR中間表示傳遞給GLSL編譯器,GLSL編譯器將Mesa IR轉化成NIR并回傳給ST層進行后續處理。
1、編譯過程,GLSL源碼轉化成IR

  • src/compiler/glsl/glsl_parser_extras.cpp :提供了對 GLSL 源代碼的解析和語法分析所需的額外功能,包括處理預處理指令、處理注釋、管理源代碼中的位置信息
  • src/compiler/glsl/ast_to_hir.cpp: 將抽象語法樹(AST)轉換為高級中間表示(HIR)的過程。
    在這里插入圖片描述

2、鏈接過程,IR轉化成NIR
src/compiler/glsl/glsl_to_nir.cpp:在Compiler層負責將GLSL源碼轉化成NIR,包括GLSL IR的釋放和NIR的創建和驗證
暫時無法在飛書文檔外展示此內容

五、NIR轉換與優化

GLSL IR 通常會被轉換為 NIR(New Intermediate Representation)。st_glsl_to_nir.cpp 文件負責 GLSL 到 NIR 的轉換,其中 NIR 提供了更抽象和可優化的中間表示。優化后的NIR將提供給gallium層供各個硬件驅動層進行轉化。
暫時無法在飛書文檔外展示此內容

GLSL編譯器轉化成NIR后,在ST還需進行以下處理和優化:

  • NIR 統一變量處理
  • 統一變量的位置分配
  • 頂點著色器輸入位置分配
  • 變量位置的分配
  • NIR 向量化和坐標系變換
  • NIR 緩存加載和存儲
  • 釋放 NIR 變體

六、核心數據結構

_glapi_table 結構體:
_glapi_table 結構體是 Mesa API 層的核心數據結構,包含了 OpenGL 函數的指針、版本信息、擴展支持等。它被用于表示 OpenGL API 的實現層次。

struct _glapi_table {/* OpenGL function pointers */GET_DISPATCH_PTR();
/* Version information */GLuint Version; 
/* Extension support */GLuint Extensions[32];
};

st_context結構體:
st_context 是一個表示Gallium3D狀態跟蹤上下文的結構體,負責跟蹤和管理圖形狀態、與Gallium3D框架進行交互。

struct st_context
{struct st_context_iface iface;struct gl_context *ctx;struct pipe_context *pipe;struct draw_context *draw;  /< For selection/feedback/rastpos only */
**   struct draw_stage *feedback_stage;  /**< For GL_FEEDBACK rendermode */struct draw_stage *selection_stage;  /< For GL_SELECT rendermode */
**   struct draw_stage *rastpos_stage;  /**< For glRasterPos */
// 省略
};

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/717505.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/717505.shtml
英文地址,請注明出處:http://en.pswp.cn/news/717505.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

c# 獲得進程的標題

使用 System.Diagnostics.Process 類來獲取所有 Internet Explorer 進程的標題。以下是如何做到這一點的代碼示例&#xff1a; using System; using System.Diagnostics;class Program {static void Main(){foreach (Process process in Process.GetProcessesByName("iex…

數據中臺的演進與實踐——構建企業的數字核心_光點科技

數據中臺&#xff0c;一個在近年來被頻繁提及的概念&#xff0c;已經成為眾多企業數字化轉型的核心組成部分。然而&#xff0c;盡管它的重要性被業界廣泛認可&#xff0c;對于數據中臺的深入理解和有效實踐仍然是許多企業面臨的挑戰。在本文中&#xff0c;我們將從數據中臺的演…

從租完ecs云服務器 使用docker建立用戶 全過程

一 登錄root用戶 ssh root公網ip 輸入密碼&#xff0c;若沒有密碼可以前往阿里云設置服務器root密碼 二 創建新用戶 并賦予 新用戶sudo權限 adduser $USER usermod -aG sudo $USER 三 Ubuntu安裝docker sudo apt-get remove docker docker-engine docker.io containerd ru…

藍橋杯:門牌制作

題目 小藍要為一條街的住戶制作門牌號。 這條街一共有2020 位住戶&#xff0c;門牌號從1 到2020 編號。 小藍制作門牌的方法是先制作0 到9 這幾個數字字符&#xff0c;最后根據需要將字符粘貼到門牌上&#xff0c;例如門牌1017 需要依次粘貼字符1、0、1、7&#xff0c;即需要1…

反向代理原理

反向代理是一種網絡應用架構模式&#xff0c;主要用于將對一個或多個后端服務器的請求進行轉發、負載均衡和緩存&#xff0c;以提高系統的安全性、性能和可靠性。 其原理如下&#xff1a; 1. 客戶端向反向代理發送請求。 2. 反向代理服務器接收請求&#xff0c;并根據預設的規…

基于window安裝Elasticsearch詳細教程

目錄 一、安裝Java環境1.1 Java版本選擇 二、下載和安裝ES2.1 下載地址2.2 文件目錄 3、啟動服務3.1 以管理員身份打開cmd3.2 首次登錄會有密碼&#xff0c;需要記住3.3 訪問 一、安裝Java環境 1.1 Java版本選擇 官網地址&#xff1a;https://www.elastic.co/cn/support/matr…

9個接口性能優化方案,RT從9000ms到180ms

昨天接到生產 SkyWalking 鏈路監控告警: 服務的百分位數響應時間在過去的 10 分鐘內超過 2000 毫秒的次數達到 3 次。 經過不斷的優化&#xff0c;將接口從 9000ms 優化到 180ms&#xff0c;先看結果 優化前&#xff1a; 優化后&#xff1a; 廢話不多我們開始 一、定位性能差的…

Maven實戰(2)之搭建maven私服

一, 背景: 如果使用國外鏡像,下載速度比較慢; 如果使用阿里云鏡像,速度還算OK,但是假如網速不好的時候,其實也是比較慢的; 如果沒有網的情況下更加下載不了. 二, 本地倉庫、個人/公司私服、遠程倉庫關系如下: 三, 下載安裝nexus私服 略

Notepad3:告別Windows記事本,輕松進行文本編輯

名人說&#xff1a;莫道桑榆晚&#xff0c;為霞尚滿天。——劉禹錫&#xff08;劉夢得&#xff0c;詩豪&#xff09; 創作者&#xff1a;Code_流蘇(CSDN)&#xff08;一個喜歡古詩詞和編程的Coder&#x1f60a;&#xff09; 目錄 一、什么是Notepad3&#xff1f;①Notepad3②核…

openGauss學習筆記-234 openGauss性能調優-系統調優-資源負載管理-資源管理準備-設置控制組

文章目錄 openGauss學習筆記-234 openGauss性能調優-系統調優-資源負載管理-資源管理準備-設置控制組234.1 背景信息234.2 前提條件234.3 操作步驟234.3.1 創建子Class控制組和Workload控制組234.3.2 更新控制組的資源配額234.3.3 刪除控制組 234.4 查看控制組的信息 openGauss…

第八節 龍晰Anolis 8.8 安裝 DDE 桌面環境

一、前言 最小化安裝的龍晰 Anolis OS 8.8 是不帶圖形化界面的&#xff0c;只能使用命令行&#xff0c;有些時候需要用到桌面環境&#xff0c;而DDE (Deepin Desktop Enviroment) 就是很好的桌面環境&#xff0c;它是指龍晰 Anolis 所搭載的中國自主桌面環境&#xff0c;用起來…

客戶快遞信息管理系統——導入文件識別存儲

客戶快遞信息管理系統背景&#xff1a; 目前不少公司都提供網購服務&#xff0c;為了將商品快遞給客戶&#xff0c;就必須保存和管理客戶的姓名、電話號碼、郵寄地址等信息。為此&#xff0c;本項目要求完成一個小型客戶快遞信息管理系統&#xff0c;完成對客戶快遞信息的建立…

C++構造函數析構函數

構造和析構函數用于管理對象的初始化和清理工作&#xff0c;確保對象的正確生命周期管理。以下是其重要特性&#xff1a; 構造函數不能是虛函數 從存儲空間角度&#xff1a; 虛函數是需要通過虛函數表和虛指針來調用的&#xff0c;如果用虛函數實現構造函數&#xff0c;而對象…

【算法沉淀】刷題筆記:并查集 帶權并查集+實戰講解

&#x1f389;&#x1f389;歡迎光臨&#x1f389;&#x1f389; &#x1f3c5;我是蘇澤&#xff0c;一位對技術充滿熱情的探索者和分享者。&#x1f680;&#x1f680; &#x1f31f;特別推薦給大家我的最新專欄《數據結構與算法&#xff1a;初學者入門指南》&#x1f4d8;&am…

Day13:信息打點-JS架構框架識別泄漏提取API接口枚舉FUZZ爬蟲插件項目

目錄 JS前端架構-識別&分析 JS前端架構-開發框架分析 前端架構-半自動Burp分析 前端架構-自動化項目分析 思維導圖 章節知識點 Web&#xff1a;語言/CMS/中間件/數據庫/系統/WAF等 系統&#xff1a;操作系統/端口服務/網絡環境/防火墻等 應用&#xff1a;APP對象/API接…

QML學習之Text

文本顯示是界面開發中的重要內容&#xff0c;在Qt Quick模塊中提供了 Text 項來進行文本的顯示&#xff0c;其中可以使用 font 屬性組對文本字體進行設置&#xff1a; font.bold&#xff1a;是否加粗&#xff0c;取值為true或false font.capitalization&#xff1a;大寫策略&a…

01.20 校招 實習 內推 面經

綠*泡*泡VX&#xff1a; neituijunsir 交流*裙 &#xff0c;內推/實習/校招匯總表格 1、校招 | 中興微電子2024屆校園招聘 校招 | 中興微電子2024屆校園招聘 2、長城汽車2024大學生開放日上大分&#xff01; 長城汽車2024大學生開放日上大分&#xff01; 3、校招 | 江淮汽…

java程序員的金三銀四求職寶典(二)

程序員的金三銀四求職寶典 隨著春天的腳步漸近&#xff0c;對于許多程序員來說&#xff0c;一年中最繁忙、最重要的面試季節也隨之而來。金三銀四&#xff0c;即三月和四月&#xff0c;被廣大程序員視為求職的黃金時期。在這兩個月里&#xff0c;各大公司紛紛開放招聘&#xf…

倒計時36天

C-小紅關雞_牛客周賽 Round 35 (nowcoder.com) //超時 134.17/175 主要是循環這部分的問題 #include <bits/stdc.h> using namespace std; #define int long long const int N 2e5 6; const int inf 0x3f3f3f3f; int a[N]; void solve() {int n,k;cin>>n>…

多模態大語言模型的ai反饋增強機器人操作研究

本研究關注于利用大語言模型&#xff08;LLMs&#xff09;提供的自動化偏好反饋來增強決策過程 ○ 提出了一種多模態LLM&#xff0c;稱為CriticGPT&#xff0c;可以理解機器人操作任務中的軌跡視頻&#xff0c;并提供分析和偏好反饋 ○ 從獎勵建模的角度驗證了CriticGPT生成的…