一.什么是Render script,以及mtk平台GPU support情况

[DESCRIPTION]

1.什么是RenderScript ?

2.RenderScript 干什么?

3.MTK平台GPU support状况?

 
[SOLUTION]

1.什么是RenderScript

RenderScript 是一种低级的高性能编程语言,提供了一套API,封装了着色器语言的使用和配置, 用于3D渲染和处理密集型计算

2.RenderScript 干什么?

a. 帮助书写更加高效的OpenGL程序

b.利用GPU的计算能力 ,可以让APP使用到GPU來做一些数学运算并加速,因为GPU的并行运算能力会比CPU 高。GPU和CPU的浮点计算能力差异的原因是:GPU是特别为计算密集,高并行度计算设计的,因此将有更多晶体管用于数据处理而不是数据缓存和流量控制

3.MTK平台GPU support状况?

MT6572 Mali-400 / MT6582 Mali-400 MP2 / MT6588, MT6592 Mali-450 MP4 均不support,

power VR也之后95/K2平台才有support该选项

二. 如何使用pvr tune工具分析GPU性能

 
【Tool】
 
首先到下列网址下载相应的安装档(SDK):
 
 
【How to use】
 
安装相应的SDK后,会发现两个目录:PVRPerfServer 和 PVRTune。
 
请按照以下步骤进行录取pvrtune档案:
 
1. PVRTuneDeveloper裡有個APK: PVRPerfServer/Android_armeabi_armeabi-v7a_x86_mips/PVRPerfServerDeveloper.apk, 安装这个apk在手机上,然后点击进
入,他会提示输入command,不用理会,直接点击ok即可。
2.在pc端口启用cmd命令行模式,输入:adb forward tcp:6520 tcp:6520
3.打开\PVRTune\Windows_x86_32下面的PVRTuneDeveloper.exe在connect to:
 
后面输入localhost 点击Go。即可连上手机并进入新的页面。在新页面的左边的Counter
 
Table 如下图所示:

选择常用的:
0 CPU load;
9 SGX task load: 3D core
10 SGX task load: TA core
都拖到中间的view 0窗口中,就会有相应的线条显示。
 
4.开始在手机模拟现象,当出现卡顿或是变慢现象后,点击file --save 就可以将录取的
结果保存成一个xxx.pvrtune的文件提供给MTK分析。
 
【Analysis】
 
对xxx.pvrtune初步的分析方法:参照下图为例.
 
A: 彩条部分表示GPU正在工作时候的状态,从右边的框图可以看到当时3D处于BUSY状态,而且可以
 
看到当时处理的是那个进程(GPU处理进程为PID8513),并且当时CPU的load处于76.6%。左图中彩条
 
间隔部分为GPU处于idle状态,表示当时GPU并不忙碌。
 

B:红线框出来的部分表示当时的PID 8513的frame rate为50.并且一直处于变化之中。

三.在开发者选项中,什么是4x MSAA和如何使用GPU呈现模式分析

4x MSAA: 多重取样抗锯齿模式,处理模型最外层的多边形单元,对边缘进行4倍的放大处理,然后进行边缘模糊过渡算法,有效改善边缘锯齿作用。

GPU呈现模式分析:

以launcher为例:勾选了上述“GPU呈现模式分析”之后,输入如下命令

adb shell kill -9 pid_of_launcher

这时launcher会重启,重启完了之后,你就开始滑动桌面,操作几次之后,再下如下命令

adb shell dumpsys gfxinfo pid_of_launcher >launcher_gfxinfo.txt

打开launcher_gfxinfo.txt,如下所示:

Profile data in ms:

Draw Process Execute

25.00 15.70 8.53

......

这些数据就是GPU呈现时间:

draw: view system draw所耗费的时间,主要是在遍历view tree,跑每个view的onDraw方法所用的时间。

Process:HWUI 去 draw view tree的所有displaylist所用的时间 。

Execute:eglSwapBuffer所耗费的时间,这个可以理解成GPU绘制所用的时间

四.什么是OpenCL以及mtk平台支持情况

OpenCL (Open Computing Language,开放计算语言) 是一个为异构平台编写程序的框架,此异构平台
 
可由CPU,GPU或其他类型的处理器组成,说的通俗易懂一点,OpenCL是一套利用处理器(CPU,GPU,或者
 
其他处理器)并行运算能力来进行开发的API标准(到目前为止,CPU的并行处理能力跟GPU的并行处理能
 
力是无法相提并论的,简单来说,是因为CPU每个核有只有一个计算单元,但是GPU一个核却有多达成
 
百上千个计算单元)。
 
以目前mtk所使用的GPU来说,因为缺少相关的DDK以及驱动,所以目前还没有support该框架编程。
 

五.GPU参数理解:

– SGX544, 286MHz

– 50.05M tri/sec and max. 572M pixel/sec

SGX544: Imagination Technologies PowerVR SGX Serial GPU

286MHz: GPU Frequency

D/s or tri/sec: Triangle fill rate /Texel fill rate, 多边形填充率/纹理填充率

Pixel/s: Pixel fill rate,像素填充率

Note1:多边形生成率即3D GPU每秒能画出多少骨架(三角形),由于3D贴图,效果渲染都需要在这些骨架上进行。所以多边形生成率越高,3D芯片/卡能提供的画面越细腻;

Note2:像素填充率, 即每秒钟GPU能在输出的画面上画出的点的数量

举例来,如果你将屏幕分辩率高在800X600。则在屏幕上构成每幅图像均需800X600=480000像素。再以每项秒钟屏幕刷新60次算,在此分辩率下所需的最小像素填充率即为60X800X600=两千八百八十万像素/秒。

可以通过adb获取gpu一些信息.

adb shell cat /proc/gpufreq/gpufreq_opp_dump

六.在分析画面异常问题时,有时需要抓取OpenGLES log,以便分析送给GPU的指令流是怎么样的?

进入Settings->developer options->Enable OpenGL trace,勾选logcat
然后手机连接usb至电脑,执行如下命令:
adb shell stop
adb shell start
然后再开启mobile log,抓取复现过程的log

MTK平台 GPU 相关知识的更多相关文章

  1. 关于MTK平台CC相关的Log查询

    关于MTK平台CC相关的Log查询 在外场问题中,经常会出现通话相关的故障.这里简单总结一下通话相关log的分析点: 主叫方:主叫方,是指主动发起通话的一方. 初步定位问题, 用户发起通话时,AP端的 ...

  2. MTK 平台上查询当前使用的摄像头模组及所支持预览分辨率

    1,MTK 平台如何查询当前使用的是哪颗摄像头及相关的模组信息? 在该目录下可以查到当前平台及相关项目的配置文件 ProjectConfig.mk \ALPS.JB.MP.V1_W_20120919\ ...

  3. HTML入门基础教程相关知识

    HTML入门基础教程 html是什么,什么是html通俗解答: html是hypertext markup language的缩写,即超文本标记语言.html是用于创建可从一个平台移植到另一平台的超文 ...

  4. 引用 字库编码Unicode相关知识

    引用 weifeng.shen 的 字库编码Unicode相关知识 1.      各地编码 首先说明一下现在常用的一些编码方案: 1.         在中国,大陆最常用的就是GBK18030编码, ...

  5. 关于MTK平台SIM-ME Lock的配置方案

    针对一些运营商的锁网需求,MTK平台已经对其有很好的支持.绝大多数的海外需求可以通过直接配置相关文件来完成.这里简单描述一下配置方法,不做原理分析. 相关数据结构分析: Modem中与SML锁网配置相 ...

  6. MTK平台Android项目APK预置方案

    项目开发中,通常需要向系统中预置一些APK,这里简单介绍一下MTK平台预置APK的方法. 需要预置的apk可以放置在目录:vendor/mediate/${Project}/artifacts/out ...

  7. LDA模型了解及相关知识

    什么是LDA? LDA是基于贝叶斯模型的,涉及到贝叶斯模型离不开“先验分布”,“数据(似然)”和"后验分布"三块.贝叶斯相关知识:先验分布 + 数据(似然)= 后验分布. 贝叶斯模 ...

  8. podSpec文件相关知识整理

    上一篇文章整理了我用SVN创建私有库的过程,本文将整理一下有关podSpec文件的相关知识. podSpec中spec的全称是“Specification”,说明书的意思.顾名思义,这是用来描述你这个 ...

  9. X86 寻址方式、AT&T 汇编语言相关知识、AT&T 与 Intel 汇编语言的比较、gcc 嵌入式汇编

    注:本分类下文章大多整理自<深入分析linux内核源代码>一书,另有参考其他一些资料如<linux内核完全剖析>.<linux c 编程一站式学习>等,只是为了更好 ...

随机推荐

  1. 一个页面通过iframe,获取另一个页面的form

    document.getElementsByTagName("iframe")[0].contentWindow.document.forms[0].submit(); var z ...

  2. C#特性的介绍及应用场景

    1.特性的任务:特性就是为了支持对象添加一些自我描述的信息,不影响类封装的前提添加额外信息.如果你用这个信息,那特性就有用:如果你不需要这个信息,那么这个特性就没用. 2.特性的基类:Attribut ...

  3. Actionscript,AS3,MXML,Flex,Flex Builder,Flash Builder,Flash,AIR,Flash Player之关系

    转自zrong's blog:http://zengrong.net/post/1295.htm ActionScript ActionScript通常简称为AS,它是Flash平台的语言.AS编写的 ...

  4. lua centos 安装报错

    yum install libtermcap-devel ncurses-devel libevent-devel readline-devel

  5. Objective -C Object initialization 对象初始化

    Objective -C Object initialization 对象初始化 1.1 Allocating Objects  分配对象 Allocation is the process by w ...

  6. 学习 微信小程序 大神不要笑

  7. KVM环境下vCPU绑定到物理CPU

    在KVM环境中测试虚拟系统性能时,如果宿主机是有两个CPU socket的硬件,会碰到由于vCPU在不同物理CPU上浮动导致测试RFC2544时出现少量丢包的现象,测试结果非常不稳定.可以将vCPU绑 ...

  8. list map接口传递

    1.传参时可以设置为jsonArray的格式 JSONArray array = new JSONArray(); JSONObject json = new JSONObject(); json.p ...

  9. ARP是如何工作的?

    我们知道,当我们在浏览器里面输入网址时,DNS服务器会自动把它解析为IP地址,浏览器实际上查找的是IP地址而不是网址.那么IP地址是如何转换为第二层物理地址(即MAC地址)的呢? 在局域网中,这是通过 ...

  10. MFC程序最小化到系统托盘及其响应函数

    预备知识: Windows API函数: WINSHELLAPI BOOL WINAPI Shell_NotifyIcon( DWORD dwMessage, PNOTIFYICONDATA pnid ...