Android环境下Mesa初始化流程重学习之eglCreateContext

2024-05-29 04:20

本文主要是介绍Android环境下Mesa初始化流程重学习之eglCreateContext,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Mesa初始化流程重学习之eglCreateContext


引言

没有啥好说的了,直接上手撸代码!总得找点事情干不是!我打工我快乐!我奋斗,我快乐!



一. 核心结构体之间的关联



在这里插入图片描述



二. eglCreateContext流程分析

eglCreateContext(...)//src/egl/main/eglapi.c_EGLContext *context;context = disp->Driver->CreateContext(disp, conf, share, attrib_list)//这里的Driver指向_eglDriver,定义在egl_dri2.c中dri2_create_context(...)//Called via eglCreateContext(), drv->CreateContext()struct dri2_egl_context *dri2_ctx;dri2_ctx = malloc(sizeof *dri2_ctx)dri2_ctx->dri_context = dri2_dpy->image_driver->createContextAttribs(...)//image_driver指向driImageDriverExtension,实现在dri_util.c中,指向driCreateContextAttribsreturn &dri2_ctx->base;driCreateContextAttribs(...) //src/gallium/frontends/dri/dri_util.c__DRIcontext *context;context = calloc(1, sizeof *context);context->driScreenPriv = screen;//__DRIscreen *screendri_create_context(...)//src/gallium/frontends/dri/dri_context.c__DRIscreen *sPriv = cPriv->driScreenPriv;struct dri_screen *screen = dri_screen(sPriv);struct dri_context *ctx = NULL;        ctx = CALLOC_STRUCT(dri_context);    cPriv->driverPrivate = ctx;//这个关系,后面必须通过关系图画出来ctx->cPriv = cPriv;ctx->sPriv = sPriv;ctx->st = st_api_create_context(&screen->base, &attribs, &ctx_err,st_share);ctx->st->st_manager_private = (void *) ctx;st_api_create_context(...) //src/mesa/state_tracker/st_manager.cstruct st_context *st;struct pipe_context *pipe;pipe = smapi->screen->context_create(smapi->screen, NULL, ctx_flags);//详见章节2.1st = st_create_context(api, pipe, mode_ptr, shared_ctx,&attribs->options, no_error,!!smapi->validate_egl_image);//详见章节2.2return &st->iface;

2.1 smapi->screen->context_create的实现

这块我们在前面分析时,已经提到过了。在vendor里面会进行赋值,如下:

struct pipe_screen *
xxx_gpu_create_screen(struct xxx_gpu_winsys *winsys)
{struct xxx_gpu_screen *screen = CALLOC_STRUCT(xxx_gpu_screen);if (!screen)return NULL;screen->ws = winsys;screen->base.get_name             = xxx_gpu_get_name;screen->base.get_vendor           = xxx_gpu_get_vendor;screen->base.get_device_vendor    = xxx_gpu_get_device_vendor;screen->base.get_param            = xxx_gpu_get_param;screen->base.get_paramf           = xxx_gpu_get_paramf;screen->base.get_shader_param     = xxx_gpu_get_shader_param;screen->base.get_compute_param    = xxx_gpu_get_compute_param;screen->base.get_compiler_options = xxx_gpu_get_compiler_options;screen->base.is_format_supported  = xxx_gpu_is_format_supported;screen->base.get_timestamp   = xxx_gpu_get_timestamp;screen->base.context_create  = xxx_gpu_context_create;screen->base.destroy         = xxx_gpu_destroy_screen;screen->base.fence_reference = xxx_gpu_fence_reference;screen->base.fence_finish    = xxx_gpu_fence_finish;screen->base.fence_get_fd    = xxx_gpu_fence_get_fd;xxx_gpu_screen_resource_init(&screen->base);slab_create_parent(&screen->transfer_pool, sizeof(struct xxx_gpu_transfer), 16);glsl_type_singleton_init_or_ref();return &screen->base;
}

2.2 st_create_context的实现

接着继续往下看:

xxx_gpu_create_screen(...)//src/gallium/drivers/xxx_gpu/xxx_gpu_screen.cscreen->base.context_create  = xxx_gpu_context_create;xxx_gpu_context_create(...)//src/gallium/drivers/xxx_gpu/xxx_gpu_context.cstruct xxx_gpu_screen *screen = xxx_gpu_screen(pscreen);struct xxx_gpu_context *ctx = CALLOC_STRUCT(xxx_gpu_context);ctx->base.screen = pscreen;ctx->base.priv = priv;ctx->ws = screen->ws;...ctx->base.flush = xxx_gpu_flush;...

我们接着继续分析_mesa_initialize_context

_mesa_initialize_context

_mesa_initialize_context(...)//src/mesa/main/context.cctx->Driver = *driverFunctions;/* setup the API dispatch tables with all nop functions */ctx->OutsideBeginEnd = _mesa_alloc_dispatch_table(false);_mesa_alloc_dispatch_table(...)//src/mesa/main/context.cstruct _glapi_table *table = _mesa_new_nop_table(numEntries, glthread)//和gl_dispatch分发有关struct _glapi_table *_mesa_new_nop_table(unsigned numEntries, bool glthread){struct _glapi_table *table;table = _glapi_new_nop_table(numEntries);return table;}            return table;_glapi_table *_glapi_new_nop_table(...)//src/mapi/mapi_glapi.cstruct _glapi_table *table;table = malloc(num_entries * sizeof(mapi_func));memcpy(table, table_noop_array, num_entries * sizeof(mapi_func));return table//build-android-aarch64/src/mapi/shared-glapi/glapi_mapi_tmp.h   
static void APIENTRY noopFlush(void)
{noop_warn("glFlush");
}
const mapi_func table_noop_array[] = {...(mapi_func) noopFlush,...
}

我们接着继续分析st_create_context_priv

st_create_context_priv

st_create_context_priv(...)//src/mesa/state_tracker/st_context.cstruct pipe_screen *screen = pipe->screen;struct st_context *st = CALLOC_STRUCT( st_context);    ctx->st = st;st->ctx = ctx;st->screen = screen;st->pipe = pipe;   _mesa_initialize_dispatch_tables(ctx);_mesa_initialize_dispatch_tables(...) //src/mesa/main/context.c_mesa_init_dispatch(ctx)//build-android-aarch64/src/mapi/glapi/gen/api_exec_init.cZ这个是构建完成以后生成的struct _glapi_table *table = ctx->OutsideBeginEnd;//还记得这个地方是怎么被赋值的吗SET_Flush(table, _mesa_Flush);//我们以这个实现来进行举例说明// build-android-arm/src/mesa/main/dispatch.h   
#define SET_Flush(disp, func) do { \void (GLAPIENTRYP fn)(void) = func; \SET_by_offset(disp, _gloffset_Flush, fn); \
} while (0)  #define SET_by_offset(disp, offset, fn) \do { \if ( (offset) < 0 ) { \/* fprintf( stderr, "[%s:%u] SET_by_offset(%p, %d, %s)!\n", */ \/*         __func__, __LINE__, disp, offset, # fn); */ \/* abort(); */ \} \else { \( (_glapi_proc *) (disp) )[offset] = (_glapi_proc) fn; \} \} while(0)

这里的核心是_glapi_table,它在前面已经被初始化了!



mesa 调试 —— 运行时函数栈的打印
Mesa GL Dispatch
mesa调用主线分析与理解

这篇关于Android环境下Mesa初始化流程重学习之eglCreateContext的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Spring AI ectorStore的使用流程

《SpringAIectorStore的使用流程》SpringAI中的VectorStore是一种用于存储和检索高维向量数据的数据库或存储解决方案,它在AI应用中发挥着至关重要的作用,本文给大家介... 目录一、VectorStore的基本概念二、VectorStore的核心接口三、VectorStore的

Centos环境下Tomcat虚拟主机配置详细教程

《Centos环境下Tomcat虚拟主机配置详细教程》这篇文章主要讲的是在CentOS系统上,如何一步步配置Tomcat的虚拟主机,内容很简单,从目录准备到配置文件修改,再到重启和测试,手把手带你搞定... 目录1. 准备虚拟主机的目录和内容创建目录添加测试文件2. 修改 Tomcat 的 server.X

python之流程控制语句match-case详解

《python之流程控制语句match-case详解》:本文主要介绍python之流程控制语句match-case使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录match-case 语法详解与实战一、基础值匹配(类似 switch-case)二、数据结构解构匹

Spring组件初始化扩展点BeanPostProcessor的作用详解

《Spring组件初始化扩展点BeanPostProcessor的作用详解》本文通过实战案例和常见应用场景详细介绍了BeanPostProcessor的使用,并强调了其在Spring扩展中的重要性,感... 目录一、概述二、BeanPostProcessor的作用三、核心方法解析1、postProcessB