Android 4.4 Fence在SurfaceFlinger中的应用
网上关于android。fence的资料好少啊。差点儿没有,可是这个机制又在GUI系统中起着关键的数据,于是自己通读源代码和凝视。与大家分享下Fence究竟是怎么回事?
Fence即栅栏。栅栏的角色与它的名字很类似.一组线程能够使用栅栏来集体进行相互同步;在本质上,每一个线程在到达某种周知的状态时调用栅栏的wait()方法,堵塞起来,以等待其他全部參与线程调用wait()方法表明它们也到达了这个状态.一旦全部的线程都到达栅栏,它们就会集体解除堵塞,并一起继续运行;引起程序调用栅栏的wait()方法进行堵塞的那个状态叫做栅栏状态;
本篇主要讲述fence在surfaceflinger中的应用的理论基础。确切的说fence在producer和consumer对buffer处理的过程中是怎样协调他们同步的工作,从而保证buffer内容的准确性。而不会被篡改。
首先我们知道一个buffer有下面几种状态:
FREE->DEQUEUED->QUEUED->ACQUIRED->FREE
FREE状态时,producer就能够申请他了吗?答案是错的,他须要等一个signal。也就是NO_FENCE这个信号,由于有可能上一次申请的buffer正在被consumer作业中,所以要等待consumer发出finish的信号,而此时FREE状态下的buffer就好像被栅栏拦住了,这里是用Fence中wait()或者waitForever()方法。等一个NO_FENCCE信号,栅栏就会打开。进入到下一流程。
DEQUEUED是指producer已经申请了一个buffer从队列中出来了,还没有入队列或者取消buffer。这个状态下的buffer。producer想对其进行改动也就是填入UI数据时,必须等一个NO_FENCE信号。由于有可能其它owner正在对它进行操作。当信号一到,poducer就能够对其进行操作,操作完毕后发出一个NO_FENCE信号。
QUEUED状态下。也就是把buffer入队列,只是在这个操作前须要等一个NO_FENCE信号,就比方上一步dequeueBuffer完毕之后发的NO_FENCE.收到信号后才进行入队列操作或者取消buffer操作。
这个时候它的owner就变成BufferQueue了。
ACQUIRED状态也就是producer已经对buffer填充完毕,与前面一样它也要等到一个NO_FENCE信号,然后consumer才干对其进行操作。
操作完毕后会释放buffer,然后发出一个NO_FENCE
信号。
这下大概知道Fence的工作流程了吧。
当先前的全部者发出一个工作被完毕的时候,fence就会发一个信号。当一个buffer是free的时候,消费者已经完毕了从buffer里读出来东西或者假设它在queuebuffer一些操作之后调用了cancelBuffer当生产者完毕了对buffer的写操作。假设当buffer处于QUEUED状态时,这表明了生产者完毕了对buffer的填充。当buffer处于DEQUEUE或ACQUIRED状态时,fence已经被传给了消费者或者生产者连同buffer的所属者。这个时候fence被置为NO_FENCE.
Android 4.4 Fence在SurfaceFlinger中的应用的更多相关文章
- Android 12(S) 图像显示系统 - SurfaceFlinger之VSync-上篇(十六)
必读: Android 12(S) 图像显示系统 - 开篇 一.前言 为了提高Android系统的UI交互速度和操作的流畅度,在Android 4.1中,引入了Project Butter,即&quo ...
- Android 12(S) 图像显示系统 - SurfaceFlinger GPU合成/CLIENT合成方式 - 随笔1
必读: Android 12(S) 图像显示系统 - 开篇 一.前言 SurfaceFlinger中的图层选择GPU合成(CLIENT合成方式)时,会把待合成的图层Layers通过renderengi ...
- 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应用程序与 ...
- surfaceflinger中各个layer的排序
surfaceflinger的主要工作就是负责把上层传递下来的各个不同的layer进行composition. 这里,我们来讨论一下各个layer在surfaceflinger中的上下排序关系和相关的 ...
随机推荐
- android 源码编译sdk
源码下载好以后,想要编译sdk,结果一直失败,今天终于找到正确方法来解决这个问题了. 使用make sdk 编译命令,结果一直报找不到资源.找不到bin/sqite3等,后来操作如下命令就可以了 1. ...
- bzoj1070: [SCOI2007]修车(费用流)
1070: [SCOI2007]修车 题目:传送门 题解: 一道挺简单的费用流吧...胡乱建模走起 贴个代码... #include<cstdio> #include<cstring ...
- iOS数据持久化 -- Core Data
Core Data是一个功能强大的层,位于SQLite数据库之上,它避免了SQL的复杂性,能让我们以更自然的方式与数据库进行交互.Core Data将数据库行转换为OC对象(托管对象)来实现,这样无需 ...
- xss 多分类 优选 贝叶斯、逻辑回归、决策树
import re import numpy as np from sklearn import cross_validation from sklearn import datasets from ...
- CAP定理在分布式系统设计中的最新应用
本文翻译自国外InfoQ和计算机杂志上一篇2012年旧文,本文就有关数据同步进行了讨论,特别关注业务事务的不变性与一致性如何在分布式系统中巧妙保证,探讨了长时间运行的事务的补偿机制.这些对分布式系统设 ...
- 5.不用拷贝的对象可以用ref
#include <iostream> #include <string> #include <boost/bind.hpp> #include <boost ...
- 使用JSON Web Token设计单点登录系统--转
原文地址:https://leon_lizi.gitbooks.io/json-web-token/content/chapter2.html 用户认证八步走 所谓用户认证(Authenticatio ...
- canvas指定的宽高写在行间和写在style里面的区别?
上代码,指定的canvas宽高都一样,线条的粗细都是5px 1.宽:400:高:300:直接写在<canvas>里的效果: 2.删除<canvas>里的宽高,宽:400:高:3 ...
- 关于概率算法的问题,不知道逻辑错在哪里,求debug
做个骰子成功几率的分析,投n颗骰子,第一次投成功的几率是a,然后投成功的骰子,需要再投1次,这次成功的几率是b.第二次成功的骰子才算最终成功. 要分析出n颗骰子,最终成功0到n颗的概率. 我写了个算法 ...
- Spring:dispatchservlet
DispatcherServlet 是 Spring MVC 中负责请求调度的核心引擎,所有的请求将由此 Servlet 根据配置分发至各个逻辑处理单元.其内部同时也维护了一个ApplicationC ...