I.MX6 Surfaceflinger 机制
/****************************************************************************
* I.MX6 Surfaceflinger 机制
* 说明:
* 最近需要去分析一下Surfaceflinger工作机制,记录一下相关的文档和主要的
* 处理函数。
*
* 2016-9-14 深圳 南山平山村 曾剑锋
***************************************************************************/ 一、参考文档:
. Android SurfaceFlinger服务启动过程源码分析
http://blog.csdn.net/yangwen123/article/details/11890941
. Android 开关机动画显示源码分析
http://blog.csdn.net/yangwen123/article/details/11680759
. 深入学习EGL
http://blog.sina.com.cn/s/blog_602f87700100p1e7.html
. Android hwcomposer模块接口
http://blog.sina.com.cn/s/blog_7213e0310102wmc0.html
. Android VSync信号产生过程源码分析
http://blog.csdn.net/yangwen123/article/details/16969907
. android HAL浅探
http://www.cnblogs.com/mr-nop/archive/2013/02/27/2935131.html
. Android: 显示系统模块加载以及调用流程
http://blog.csdn.net/hongzg1982/article/details/49681705 二、cat frameworks/native/services/surfaceflinger/SurfaceFlinger.cpp
......
status_t SurfaceFlinger::readyToRun()
{
ALOGI( "SurfaceFlinger's main thread ready to run. "
"Initializing graphics H/W..."); // initialize EGL for the default display
mEGLDisplay = eglGetDisplay(EGL_DEFAULT_DISPLAY);
eglInitialize(mEGLDisplay, NULL, NULL); // Initialize the H/W composer object. There may or may not be an
// actual hardware composer underneath.
mHwc = new HWComposer(this,
*static_cast<HWComposer::EventHandler *>(this)); // initialize the config and context
EGLint format = mHwc->getVisualID();
mEGLConfig = selectEGLConfig(mEGLDisplay, format);
mEGLContext = createGLContext(mEGLDisplay, mEGLConfig); LOG_ALWAYS_FATAL_IF(mEGLContext == EGL_NO_CONTEXT,
"couldn't create EGLContext"); // initialize our non-virtual displays
for (size_t i= ; i<DisplayDevice::NUM_DISPLAY_TYPES ; i++) {
DisplayDevice::DisplayType type((DisplayDevice::DisplayType)i);
mDefaultDisplays[i] = new BBinder();
wp<IBinder> token = mDefaultDisplays[i]; // set-up the displays that are already connected
if (mHwc->isConnected(i) || type==DisplayDevice::DISPLAY_PRIMARY) {
// All non-virtual displays are currently considered secure.
bool isSecure = true;
bool isSecure = true;
mCurrentState.displays.add(token, DisplayDeviceState(type));
sp<FramebufferSurface> fbs = new FramebufferSurface(*mHwc, i);
sp<SurfaceTextureClient> stc = new SurfaceTextureClient(
static_cast< sp<ISurfaceTexture> >(fbs->getBufferQueue()));
sp<DisplayDevice> hw = new DisplayDevice(this,
type, isSecure, token, stc, fbs, mEGLConfig);
if (i > DisplayDevice::DISPLAY_PRIMARY) {
// FIXME: currently we don't get blank/unblank requests
// for displays other than the main display, so we always
// assume a connected display is unblanked.
ALOGD("marking display %d as acquired/unblanked", i);
hw->acquireScreen();
}
mDisplays.add(token, hw);
}
} // we need a GL context current in a few places, when initializing
// OpenGL ES (see below), or creating a layer,
// or when a texture is (asynchronously) destroyed, and for that
// we need a valid surface, so it's convenient to use the main display
// for that.
sp<const DisplayDevice> hw(getDefaultDisplayDevice()); // initialize OpenGL ES
DisplayDevice::makeCurrent(mEGLDisplay, hw, mEGLContext);
initializeGL(mEGLDisplay); // start the EventThread
mEventThread = new EventThread(this);
mEventQueue.setEventThread(mEventThread); // initialize our drawing state
mDrawingState = mCurrentState; // We're now ready to accept clients...
mReadyToRunBarrier.open(); // set initial conditions (e.g. unblank default device)
initializeDisplays(); // start boot animation
startBootAnim(); return NO_ERROR;
}
...... 三、cat frameworks/native/services/surfaceflinger/DisplayHardware/HWComposer.cpp
......
// Load and prepare the hardware composer module. Sets mHwc.
void HWComposer::loadHwcModule()
{
hw_module_t const* module; if (hw_get_module(HWC_HARDWARE_MODULE_ID, &module) != ) {
ALOGE("%s module not found", HWC_HARDWARE_MODULE_ID);
return;
} int err = hwc_open_1(module, &mHwc);
if (err) {
ALOGE("%s device failed to initialize (%s)",
HWC_HARDWARE_COMPOSER, strerror(-err));
return;
} if (!hwcHasApiVersion(mHwc, HWC_DEVICE_API_VERSION_1_0) ||
hwcHeaderVersion(mHwc) < MIN_HWC_HEADER_VERSION ||
hwcHeaderVersion(mHwc) > HWC_HEADER_VERSION) {
ALOGE("%s device version %#x unsupported, will not be used",
HWC_HARDWARE_COMPOSER, mHwc->common.version);
hwc_close_1(mHwc);
mHwc = NULL;
return;
}
}
...... 四、cat hardware/imx/mx6/hwcomposer/hwcomposer.cpp
static int hwc_device_open(const struct hw_module_t* module, const char* name,
struct hw_device_t** device)
{ printf("fsl hwc_device_open().\n");
int status = -EINVAL;
if (!strcmp(name, HWC_HARDWARE_COMPOSER)) {
struct hwc_context_t *dev;
dev = (hwc_context_t*)malloc(sizeof(*dev)); /* initialize our state here */
// memset(dev, 0, sizeof(*dev)); /* initialize the procs */
dev->device.common.tag = HARDWARE_DEVICE_TAG;
dev->device.common.module = const_cast<hw_module_t*>(module);
dev->device.common.close = hwc_device_close; dev->device.prepare = hwc_prepare;
dev->device.set = hwc_set;
dev->device.common.version = HWC_DEVICE_API_VERSION_1_1;
dev->device.registerProcs = hwc_registerProcs;
dev->device.eventControl = hwc_eventControl;
dev->device.query = hwc_query;
dev->device.blank = hwc_blank;
dev->device.getDisplayConfigs = hwc_getDisplayConfigs;
dev->device.getDisplayAttributes = hwc_getDisplayAttributes; /* our private state goes below here */
dev->m_vsync_thread = new VSyncThread(dev);
dev->m_vsync_thread = new VSyncThread(dev);
dev->m_uevent_thread = new UeventThread(dev);
hwc_get_display_info(dev); hw_get_module(GRALLOC_HARDWARE_MODULE_ID, &dev->m_gralloc_module);
struct private_module_t *priv_m = (struct private_module_t *)dev->m_gralloc_module; for(int dispid=; dispid<HWC_NUM_DISPLAY_TYPES; dispid++) {
if(dev->mDispInfo[dispid].connected && dev->m_gralloc_module != NULL) {
int fbid = dev->mDispInfo[dispid].fb_num;
char fbname[HWC_STRING_LENGTH];
memset(fbname, , sizeof(fbname));
sprintf(fbname, "fb%d", fbid);
ALOGI("hwcomposer: open framebuffer %s", fbname);
dev->mFbDev[dispid] = (framebuffer_device_t*)fbid;
dev->m_gralloc_module->methods->open(dev->m_gralloc_module, fbname,
(struct hw_device_t**)&dev->mFbDev[dispid]);
}
} const hw_module_t *hwc_module;
if(hw_get_module(HWC_VIV_HARDWARE_MODULE_ID,
(const hw_module_t**)&hwc_module) < ) {
ALOGE("Error! hw_get_module viv_hwc failed");
goto nor_exit;
} if(hwc_open_1(hwc_module, &(dev->m_viv_hwc)) != ) {
ALOGE("Error! viv_hwc open failed");
goto nor_exit;
}
nor_exit: *device = &dev->device.common;
ALOGI("%s,%d", __FUNCTION__, __LINE__);
return ;
err_exit:
if(dev){
free(dev);
}
/****************************************/
}
return status;
}
I.MX6 Surfaceflinger 机制的更多相关文章
- Android系统Surface机制的SurfaceFlinger服务渲染应用程序UI的过程分析
参考:Android系统Surface机制的SurfaceFlinger服务渲染应用程序UI的过程分析 一句话概括一下Android应用程序显示的过程:Android应用程序调用SurfaceFlin ...
- [转]Android系统Surface机制的SurfaceFlinger服务简要介绍和学习计划
转自:Android系统Surface机制的SurfaceFlinger服务简要介绍和学习计划 前面我们从Android应用程序与SurfaceFlinger服务的关系出发,从侧面简单学习了Surfa ...
- Android系统Surface机制的SurfaceFlinger服务的线程模型分析
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/8062945 在前面两篇文章中,我们分析了Sur ...
- Android系统Surface机制的SurfaceFlinger服务对帧缓冲区(Frame Buffer)的管理分析
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/8046659 在前文中,我们分析了Surface ...
- Android系统Surface机制的SurfaceFlinger服务的启动过程分析
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/8022957 在前面一篇文章中,我们简要介绍了A ...
- Android系统Surface机制的SurfaceFlinger服务简要介绍和学习计划
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/8010977 前面我们从Android应用程序与 ...
- Surface机制(SurfaceFlinger服务)
Android系统Surface机制的SurfaceFlinger服务的线程模型分析http://blog.csdn.net/luoshengyang/article/details/8062945
- Android 12(S) 图形显示系统 - SurfaceFlinger的启动和消息队列处理机制(四)
1 前言 SurfaceFlinger作为Android图形显示系统处理逻辑的核心单元,我们有必要去了解其是如何启动,初始化及进行消息处理的.这篇文章我们就来简单分析SurfaceFlinger这个B ...
- 11.4 Android显示系统框架_APP与SurfaceFlinger内部机制分析
4.1 APP跟SurfaceFlinger之间的重要数据结构 一个应用程序有一个或者多个surface(一般只有一个),一个surface有一个或者多个buffer,这些buffer需要应用向sur ...
随机推荐
- 如何使用ssh远程编辑定时任务crontab?
linxu定时任务使用crontab,编辑crontab可以直接编辑:crontab -e:也可以直接读取文件 crontab file.这两种操作都不需要特殊权限sudo.区别在于,crontab ...
- 详解RocketMQ中的consumer
上述就是MQ中有关Consumer的类图,下面来介绍一下每个类 1.MQAdmin:底层类,上篇博客已经提过,就不再此重提 2.MQConsumer:Consumer公共的接口,常用的方法如下 如果消 ...
- C# 通过WebService方式 IIS发布网站 上传文件到服务器[转]
http://blog.sina.com.cn/s/blog_517cae3c0102v0y7.html 应用场景:要将本地的文件 上传到服务器的虚拟机上 网络环境:公司局域网(如下图中第二种) 开发 ...
- MQTT 测试工具介绍
eclipse paho 下载地址为: https://repo.eclipse.org/content/repositories/paho-releases/org/eclipse/paho/org ...
- 笔记09 WS,WCF
http://blog.csdn.net/avi9111/article/details/5655563 http://www.cnblogs.com/tearer/archive/2013/04/2 ...
- javascript 高级编程系列 - 基本数据类型
javascript中的基本数据类型包括: Undefined, Null, Boolean, Number, String 5种数据类型 1. Undefined 类型 (只有一个值 undefin ...
- 轻松搞定RabbitMQ(五)——路由选择
转自 http://blog.csdn.net/xiaoxian8023/article/details/48733249 翻译地址:http://www.rabbitmq.com/tutorials ...
- Active Directory的LDAP协议与DN(Distinguished Name)详解
前言 光copy几段代码的文章没什么意思,本章上最基础的代码,主要是为了从编程方面聊LDAP和DN,其它的后面聊,一步步慢慢来吧. Active Directory编程须知 1.域控服务器: Wind ...
- Continuous Integration with Selenium
I have seen a lot of queries from people who basically want to know how to blend Selenium, Maven, an ...
- 20181125 test
1.对一些不确定性的东西,还是需要一些勇气进行尝试 2.多阅读blog上的大咖的文章肯定会有提高的