OpenGL内存泄漏引发的血案 在写正文之前笔者想说一下因为OpenGL的内存问题我是整整REVIEW&TEST了两周之久,在这里吐槽一下RK的工程师,申请完内存之后请注意回收!回收!回收!重要的事情说三遍!
OpenGL内存泄漏问题分析一:glGenTextures引发的内存泄漏 好了不吐槽了,现在开始步入正文,此次笔者遇到的OpenGL的内存泄漏问题有两处,一处是使用OpenGL渲染本地图片的时候频繁调用glGenTextures()用于产出textureId,代码如下:
public int createTextureObjectFromBitmap(int defaultId, Bitmap bitmap) {
//之前没有复用textureId,会导致内存泄漏
if (defaultId == 0) {
final int[] textureObjectIds = new int[1];
GLES20.glGenTextures(1, textureObjectIds, 0);
textureId = textureObjectIds[0];
if (textureId == 0) {
Log.e(TAG, "Could not generate a new OpenGL texture object!");
return 0;
if (bitmap != null && !bitmap.isRecycled()) {
GLES20.glBindTexture(GLES20.GL_TEXTURE_2D, textureId);
GLES20.glTexParameterf(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MIN_FILTER, GLES20.GL_NEAREST);
GLES20.glTexParameterf(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MAG_FILTER, GLES20.GL_LINEAR);
GLES20.glTexParameterf(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_WRAP_S, GLES20.GL_CLAMP_TO_EDGE);
GLES20.glTexParameterf(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_WRAP_T, GLES20.GL_CLAMP_TO_EDGE);
//根据以上指定的参数,生成一个2D纹理
//第一个参数指定了纹理目标(Target)。设置为GL_TEXTURE_2D意味着会生成与当前绑定的纹理对象在同一个目标上的纹理(任何绑定到GL_TEXTURE_1D和GL_TEXTURE_3D的纹理不会受到影响)。
//第二个参数为纹理指定多级渐远纹理的级别,如果你希望单独手动设置每个多级渐远纹理的级别的话。这里我们填0,也就是基本级别。
//第三个参数告诉OpenGL我们希望把纹理储存为何种格式。我们的图像只有RGB值,因此我们也把纹理储存为RGB值。
//第四个和第五个参数设置最终的纹理的宽度和高度。我们之前加载图像的时候储存了它们,所以我们使用对应的变量。
//下个参数应该总是被设为0(历史遗留问题)。
//第七第八个参数定义了源图的格式和数据类型。我们使用RGB值加载这个图像,并把它们储存为char(byte)数组,我们将会传入对应值。
//最后一个参数是真正的图像数据。
GLUtils.texImage2D(GLES20.GL_TEXTURE_2D, 0, bitmap, 0);
bitmap.recycle();
return textureId;
return 0;
看上面的代码发现GLES20.glGenTextures(1, textureObjectIds, 0)进行了复用,因为如果不复用会出现持续创建的问题,导致内存持续飙升,直到OOM,为什么会持续飙升呢?因为笔者在使用完纹理之后没有删除纹理,所以需要使用glDeleteTexture()来删除不使用的纹理。
OpenGL内存泄漏问题分析二:GraphicBuffer引发的内存泄漏
首先来看两段log:
08-31 17:34:36.352 11595 11595 D PluLog:CameraSurfaceRender.getCameraStatus(Line:472): Get camera status: PREPARED
08-31 17:34:36.354 11595 11595 W PluLog:AirService.checkFloatView(Line:254): The camera status is prepared, skipRelease: false
08-31 17:34:36.371 2376 14751 D CameraHal: cameraStream(515): cameraStream(515):on = 1
08-31 17:34:36.376 11595 14737 D mali_so : #00 pc 000000000056721c /vendor/lib64/egl/libGLES_mali.so
08-31 17:34:36.376 11595 14737 D mali_so : #01 pc 000000000056fc18 /vendor/lib64/egl/libGLES_mali.so
08-31 17:34:36.376 11595 14737 D mali_so : #02 pc 0000000000563d64 /vendor/lib64/egl/libGLES_mali.so
08-31 17:34:36.376 11595 14737 D mali_so : #03 pc 00000000005665ac /vendor/lib64/egl/libGLES_mali.so
08-31 17:34:36.376 11595 14737 D mali_so : #04 pc 00000000008d0608 /system/framework/arm64/boot-framework.oat (offset 0x614000)
08-31 17:34:36.377 11595 14737 E Parcel : fcntl(F_DUPFD_CLOEXEC) failed in Parcel::read, i is 1, fds[i] is -1, fd_count is 3, error: Too many open files
08-31 17:34:36.377 11595 14737 E Surface : dequeueBuffer: IGraphicBufferProducer::requestBuffer failed: -22
......
08-31 17:34:56.448 11595 11698 W GraphicBufferMapper: importBuffer(0x7c8f0b3d80) failed: 5
08-31 17:34:56.448 11595 11698 E GraphicBuffer: unflatten: registerBuffer failed: Unknown error -5 (5)
08-31 17:34:56.448 11595 11698 E Surface : dequeueBuffer: IGraphicBufferProducer::requestBuffer failed: 5
08-31 17:34:56.450 11595 11698 F OpenGLRenderer: Failed to set damage region on surface 0x7c90278180, error=EGL_BAD_ACCESS
08-31 17:34:56.451 411 14795 D NuPlayerDriver: notifyListener_l(0xef127af0), (1, 0, 0, -1), loop setting(0, 0)
08-31 17:34:56.453 411 7699 D NuPlayerDriver: NuPlayerDriver(0xef127a10) created, clientPid(2388)
--------- beginning of crash
08-31 17:34:56.453 11595 11698 F libc : Fatal signal 6 (SIGABRT), code -6 in tid 11698 (RenderThread), pid 11595 (om.qtimes.wonly)
08-31 17:34:56.469 408 408 E ffmExtractor: Cannot load library libffmpeg_utils.so dlerror = dlopen failed: library "libffmpeg_utils.so" not found
08-31 17:34:56.469 408 408 E ffmExtractor: lib open failed
08-31 17:34:56.475 411 14797 D NuPlayerDriver: notifyListener_l(0xef127a10), (1, 0, 0, -1), loop setting(0, 0)
08-31 17:34:56.477 411 7699 D NuPlayerDriver: NuPlayerDriver(0xef127c40) created, clientPid(2388)
08-31 17:34:56.489 408 408 E ffmExtractor: Cannot load library libffmpeg_utils.so dlerror = dlopen failed: library "libffmpeg_utils.so" not found
08-31 17:34:56.489 408 408 E ffmExtractor: lib open failed
08-31 17:34:56.498 411 14800 D NuPlayerDriver: notifyListener_l(0xef127c40), (1, 0, 0, -1), loop setting(0, 0)
08-31 17:34:56.503 2388 4676 I CameraHardwareInterface: Opening camera 0
08-31 17:34:56.504 2376 2376 I CamDev@1.0-impl: Opening camera 0
08-31 17:34:56.504 2376 2376 D CameraHal: camera_get_camera_info(1456): camera_get_camera_info(1456): camera_0 facing(0), orientation(0)
08-31 17:34:56.504 2376 2376 I CameraHal: camera_device_open(576): camera_device open
08-31 17:34:56.504 2376 2376 D CameraHal: gCameraHalLogLevel: 0
08-31 17:34:56.504 2376 2376 D vndksupport: Loading /vendor/lib/hw/gralloc.rk30board.so from current namespace instead of sphal namespace.
08-31 17:34:56.506 2376 2376 D CameraHal: CameraHal(116): it is a uvc camera!
08-31 17:34:56.506 2376 2376 D CameraHal: getCallingProcess(83): Calling process from sys.camera.callprocess is: com.qtimes.wonly
08-31 17:34:56.506 2376 2376 D CameraHal: getCallingProcess(83): Calling process from sys.camera.callprocess is: com.qtimes.wonly
08-31 17:34:56.604 2376 2376 D CameraHal: cameraCreate(391): Camera driver: uvcvideo Card Name:USB Camera Driver version: 4.4.189 CameraHal version: 1.81.13
08-31 17:34:56.604 2376 2376 D CameraHal: cameraCreate(398): mCamDriverSupportFmt: fmt = 1448695129(YUYV 4:2:2),index = 0
08-31 17:34:56.604 2376 2376 D CameraHal: cameraCreate(398): mCamDriverSupportFmt: fmt = 1196444237(Motion-JPEG),index = 1
08-31 17:34:56.604 2376 2376 D CameraHal: cameraCreate(436): cameraCreate(436): mCamDriverPreviewFmt(MJPG) is cameraHal and camera driver is also supported!!
08-31 17:34:56.604 2376 2376 D CameraHal: cameraCreate(438): mCamDriverPreviewFmt = 1196444237
08-31 17:34:56.604 2376 2376 D CameraHal: cameraCreate(444): cameraCreate(444): Current driver is uvcvideo, v4l2 memory is V4L2_MEMORY_MMAP
08-31 17:34:56.608 2376 2376 E CameraHal: initDefaultParameters(524): initDefaultParameters(524): mCamDriverCapability.card is error!
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(589): Support video sizes:(null)
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(604): Support Preview format: yuv420sp,yuv420p .. yuv420sp
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(606): Support Preview sizes: 640x480,320x240,320x180,1280x720,960x540,848x480,640x360,424x240,1920x1080 640x480
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(607): Support Preview FPS range: (15000,15000),(30000,30000)
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(608): Support Preview framerate: 10,15,20,30
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(609): Support Picture sizes: 640x480,320x240,320x180,1280x720,960x540,848x480,640x360,424x240,1920x1080
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(611): Support white balance: auto,incandescent,fluorescent,daylight,cloudy-daylight
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(613): Support color effect: none,mono,sepia
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(619): Support focus: fixed focus zone: 0
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(621): Support zoom: true(ratios: 100,105,110,115,120,125,130,135,140,145,150,155,160,165,170,175,180,185,190,195,200,205,210,215,220,225,230,235,240,245,250,255,260,265,270,275,280,285,290,295,300,)
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(625): Support exposure: (-3 -> 3)
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(629): Support anti-banding: off,50hz,60hz,auto anti-banding: off
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(631): Support hardware faces detecte: 2
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(632): Support software faces detecte: 0
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(633): Support video stabilization: false
08-31 17:34:56.609 2376 2376 D CameraHal: initDefaultParameters(634): Support recording hint: false
08-31 17:34:56.611 2376 2376 D CameraHal: cameraConfig(766): cameraConfig(766): Set framerate(30 fps) success
08-31 17:34:56.613 2376 2376 D CameraHal: cameraConfig(809): cameraConfig(809): Set white balance(auto) success
08-31 17:34:56.613 2376 2376 E CameraHal: cameraConfig(839): cameraConfig(839): Set effect(none) fail
08-31 17:34:56.614 2376 2376 D CameraHal: cameraConfig(886): cameraConfig(886): Set anti-banding Disabled
08-31 17:34:56.614 2376 2376 D CameraHal: cameraConfig(967): cameraConfig(967): Set exposure 0 0
08-31 17:34:56.615 2376 2376 D CameraHal: isNeedToRestartPreview(164): mPreviewFrame2AppW (640x480)
08-31 17:34:56.615 2376 2376 D CameraHal: isNeedToRestartPreview(165): mCamPreviewW (1280x720)
08-31 17:34:56.615 2376 2376 D CameraHal: isNeedToRestartPreview(166): video width (640x480)
08-31 17:34:56.632 14808 14808 I crash_dump64: obtaining output fd from tombstoned, type: kDebuggerdTombstone
08-31 17:34:56.633 419 419 I /system/bin/tombstoned: received crash request for pid 11595
08-31 17:34:56.634 14808 14808 I crash_dump64: performing dump of process 11595 (target tid = 11698)
08-31 17:34:56.635 14808 14808 F DEBUG : *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
08-31 17:34:56.635 14808 14808 F DEBUG : Build fingerprint: 'rockchip/rk3399pro/rk3399pro:8.1.0/OPM8.190405.001/081226:userdebug/test-keys'
08-31 17:34:56.635 14808 14808 F DEBUG : Revision: '0'
08-31 17:34:56.635 14808 14808 F DEBUG : ABI: 'arm64'
08-31 17:34:56.635 14808 14808 F DEBUG : pid: 11595, tid: 11698, name: RenderThread >>> com.qtimes.wonly <<<
08-31 17:34:56.635 14808 14808 F DEBUG : signal 6 (SIGABRT), code -6 (SI_TKILL), fault addr --------
08-31 17:34:56.640 14808 14808 F DEBUG : Abort message: 'Failed to set damage region on surface 0x7c90278180, error=EGL_BAD_ACCESS'
08-31 17:34:56.640 14808 14808 F DEBUG : x0 0000000000000000 x1 0000000000002db2 x2 0000000000000006 x3 0000000000000008
08-31 17:34:56.640 14808 14808 F DEBUG : x4 0000000000000000 x5 0000000000000000 x6 0000000000000000 x7 7f7f7f7f7f7f7f7f
08-31 17:34:56.640 14808 14808 F DEBUG : x8 0000000000000083 x9 0000000010000000 x10 0000007c930526a0 x11 0000000000000001
08-31 17:34:56.640 14808 14808 F DEBUG : x12 0000007c930527c0 x13 ffffffffffffffff x14 ff00000000000000 x15 ffffffffffffffff
08-31 17:34:56.640 14808 14808 F DEBUG : x16 000000620bed4fa8 x17 0000007d32f0552c x18 0000007c8f001010 x19 0000000000002d4b
08-31 17:34:56.640 14808 14808 F DEBUG : x20 0000000000002db2 x21 0000000000000083 x22 0000007ca71f1fb0 x23 0000007c90d8abd8
08-31 17:34:56.640 14808 14808 F DEBUG : x24 0000007c90d86e88 x25 0000007c90d86e1c x26 0000007c930531f8 x27 0000007c930531e0
08-31 17:34:56.640 14808 14808 F DEBUG : x28 0000007c93053300 x29 0000007c930526e0 x30 0000007d32eba760
08-31 17:34:56.640 14808 14808 F DEBUG : sp 0000007c930526a0 pc 0000007d32eba788 pstate 0000000060000000
08-31 17:34:56.680 14808 14808 F DEBUG :
08-31 17:34:56.680 14808 14808 F DEBUG : backtrace:
08-31 17:34:56.680 14808 14808 F DEBUG : #00 pc 000000000001d788 /system/lib64/libc.so (abort+120)
08-31 17:34:56.680 14808 14808 F DEBUG : #01 pc 0000000000007f08 /system/lib64/liblog.so (__android_log_assert+296)
08-31 17:34:56.680 14808 14808 F DEBUG : #02 pc 000000000006c6a0 /system/lib64/libhwui.so (android::uirenderer::renderthread::EglManager::damageFrame(android::uirenderer::renderthread::Frame const&, SkRect const&)+184)
08-31 17:34:56.680 14808 14808 F DEBUG : #03 pc 00000000000695b0 /system/lib64/libhwui.so (android::uirenderer::renderthread::OpenGLPipeline::draw(android::uirenderer::renderthread::Frame const&, SkRect const&, SkRect const&, android::uirenderer::FrameBuilder::LightGeometry const&, android::uirenderer::LayerUpdateQueue*, android::uirenderer::Rect const&, bool, bool, android::uirenderer::BakedOpRenderer::LightInfo const&, std::__1::vector<android::sp<android::uirenderer::RenderNode>, std::__1::allocator<android::sp<android::uirenderer::Render
08-31 17:34:56.681 14808 14808 F DEBUG : #04 pc 000000000006780c /system/lib64/libhwui.so (android::uirenderer::renderthread::CanvasContext::draw()+184)
08-31 17:34:56.681 14808 14808 F DEBUG : #05 pc 000000000006b47c /system/lib64/libhwui.so (android::uirenderer::renderthread::DrawFrameTask::run()+180)
08-31 17:34:56.681 14808 14808 F DEBUG : #06 pc 0000000000072a48 /system/lib64/libhwui.so (android::uirenderer::renderthread::RenderThread::threadLoop()+336)
08-31 17:34:56.681 14808 14808 F DEBUG : #07 pc 0000000000011478 /system/lib64/libutils.so (android::Thread::_threadLoop(void*)+280)
08-31 17:34:56.681 14808 14808 F DEBUG : #08 pc 00000000000a98c4 /system/lib64/libandroid_runtime.so (android::AndroidRuntime::javaThreadShell(void*)+140)
08-31 17:34:56.681 14808 14808 F DEBUG : #09 pc 0000000000067d80 /system/lib64/libc.so (__pthread_start(void*)+36)
08-31 17:34:56.681 14808 14808 F DEBUG : #10 pc 000000000001ec18 /system/lib64/libc.so (__start_thread+68)
08-31 17:34:58.556 419 419 E /system/bin/tombstoned: Tombstone written to: /data/tombstones/tombstone_03
08-31 16:59:33.110 3967 7974 E GLConsumer: [SurfaceTexture-4-3967-100] syncForReleaseLocked: error dup'ing native fence fd: 0x3000
08-31 16:59:33.111 3967 4075 E Parcel : fcntl(F_DUPFD_CLOEXEC) failed in Parcel::read, i is 0, fds[i] is -1, fd_count is 1, error: Too many open files
08-31 16:59:33.111 3967 4075 F OpenGLRenderer: Failed to set damage region on surface 0x7c851f03c0, error=EGL_BAD_ACCESS
08-31 16:59:33.112 2376 7992 E CameraHal: reprocessFrame(1031): ret = 0 input_width = 1280 input_height = 720
--------- beginning of crash
08-31 16:59:33.114 3967 4075 F libc : Fatal signal 6 (SIGABRT), code -6 in tid 4075 (RenderThread), pid 3967 (<unknown>)
08-31 16:59:33.116 285 513 E BufferQueueProducer: [SurfaceView - #0] disconnect: not connected (req=1)
08-31 16:59:33.116 3967 7974 W libEGL : EGLNativeWindowType 0x7c94e52010 disconnect failed
08-31 16:59:33.125 2376 7982 D vndksupport: Loading /vendor/lib/hw/gralloc.rk30board.so from current namespace instead of sphal namespace.
08-31 16:59:33.142 2376 7992 E CameraHal: reprocessFrame(1031): ret = 0 input_width = 1280 input_height = 720
08-31 16:59:33.155 3967 7974 E AndroidRuntime: FATAL EXCEPTION: GLThread 644
08-31 16:59:33.155 3967 7974 E AndroidRuntime: Process: com.qtimes.wonly, PID: 3967
08-31 16:59:33.155 3967 7974 E AndroidRuntime: java.lang.RuntimeException: Error during updateTexImage (see logcat for details)
08-31 16:59:33.155 3967 7974 E AndroidRuntime: at android.graphics.SurfaceTexture.nativeUpdateTexImage(Native Method)
08-31 16:59:33.155 3967 7974 E AndroidRuntime: at android.graphics.SurfaceTexture.updateTexImage(SurfaceTexture.java:243)
08-31 16:59:33.155 3967 7974 E AndroidRuntime: at com.qtimes.npucore.ssd.CameraSurfaceRender.onDrawFrame(CameraSurfaceRender.java:171)
08-31 16:59:33.155 3967 7974 E AndroidRuntime: at android.opengl.GLSurfaceView$GLThread.guardedRun(GLSurfaceView.java:1571)
08-31 16:59:33.155 3967 7974 E AndroidRuntime: at android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1270)
08-31 16:59:33.155 2376 7982 D vndksupport: Loading /vendor/lib/hw/gralloc.rk30board.so from current namespace instead of sphal namespace.
08-31 16:59:33.174 2376 7992 E CameraHal: reprocessFrame(1031): ret = 0 input_width = 1280 input_height = 720
08-31 16:59:33.176 3967 7975 D ServerManager: notifyPersonExist: true
08-31 16:59:33.187 2376 7982 D vndksupport: Loading /vendor/lib/hw/gralloc.rk30board.so from current namespace instead of sphal namespace.
08-31 16:59:33.188 480 2440 I WifiService: getWifiEnabledState uid=10048
08-31 16:59:33.196 480 2440 E memtrack: Couldn't load memtrack module
08-31 16:59:33.196 480 2440 W android.os.Debug: failed to get memory consumption info: -1
08-31 16:59:33.210 2376 7992 E CameraHal: reprocessFrame(1031): ret = 0 input_width = 1280 input_height = 720
08-31 16:59:33.222 2376 7982 D vndksupport: Loading /vendor/lib/hw/gralloc.rk30board.so from current namespace instead of sphal namespace.
08-31 16:59:33.242 2376 7992 E CameraHal: reprocessFrame(1031): ret = 0 input_width = 1280 input_height = 720
08-31 16:59:33.278 2376 7992 E CameraHal: reprocessFrame(1031): ret = 0 input_width = 1280 input_height = 720
08-31 16:59:33.280 7997 7997 I crash_dump64: obtaining output fd from tombstoned, type: kDebuggerdTombstone
08-31 16:59:33.281 419 419 I /system/bin/tombstoned: received crash request for pid 3967
08-31 16:59:33.282 7997 7997 I crash_dump64: performing dump of process 3967 (target tid = 4075)
08-31 16:59:33.283 7997 7997 F DEBUG : *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
08-31 16:59:33.283 7997 7997 F DEBUG : Build fingerprint: 'rockchip/rk3399pro/rk3399pro:8.1.0/OPM8.190405.001/081226:userdebug/test-keys'
08-31 16:59:33.283 7997 7997 F DEBUG : Revision: '0'
08-31 16:59:33.283 7997 7997 F DEBUG : ABI: 'arm64'
08-31 16:59:33.283 7997 7997 F DEBUG : pid: 3967, tid: 4075, name: RenderThread >>> com.qtimes.wonly <<<
08-31 16:59:33.283 7997 7997 F DEBUG : signal 6 (SIGABRT), code -6 (SI_TKILL), fault addr --------
08-31 16:59:33.287 7997 7997 F DEBUG : Abort message: 'Failed to set damage region on surface 0x7c851f03c0, error=EGL_BAD_ACCESS'
08-31 16:59:33.287 7997 7997 F DEBUG : x0 0000000000000000 x1 0000000000000feb x2 0000000000000006 x3 0000000000000008
08-31 16:59:33.287 7997 7997 F DEBUG : x4 0000000000000000 x5 0000000000000000 x6 0000000000000000 x7 7f7f7f7f7f7f7f7f
08-31 16:59:33.287 7997 7997 F DEBUG : x8 0000000000000083 x9 0000000010000000 x10 0000007c92af96a0 x11 0000000000000001
08-31 16:59:33.287 7997 7997 F DEBUG : x12 0000007c92af97c0 x13 ffffffffffffffff x14 ff00000000000000 x15 ffffffffffffffff
08-31 16:59:33.287 7997 7997 F DEBUG : x16 000000620bed4fa8 x17 0000007d32f0552c x18 0000000000000000 x19 0000000000000f7f
08-31 16:59:33.287 7997 7997 F DEBUG : x20 0000000000000feb x21 0000000000000083 x22 0000007c94e24b50 x23 0000007c953b9a18
08-31 16:59:33.287 7997 7997 F DEBUG : x24 0000007c953b5cc8 x25 0000007c953b5c5c x26 0000007c92afa1f8 x27 0000007c92afa1e0
08-31 16:59:33.287 7997 7997 F DEBUG : x28 0000007c92afa300 x29 0000007c92af96e0 x30 0000007d32eba760
08-31 16:59:33.287 7997 7997 F DEBUG : sp 0000007c92af96a0 pc 0000007d32eba788 pstate 0000000060000000
08-31 16:59:33.311 2376 7992 E CameraHal: reprocessFrame(1031): ret = 0 input_width = 1280 input_height = 720
08-31 16:59:33.337 7997 7997 F DEBUG :
08-31 16:59:33.337 7997 7997 F DEBUG : backtrace:
08-31 16:59:33.337 7997 7997 F DEBUG : #00 pc 000000000001d788 /system/lib64/libc.so (abort+120)
08-31 16:59:33.337 7997 7997 F DEBUG : #01 pc 0000000000007f08 /system/lib64/liblog.so (__android_log_assert+296)
08-31 16:59:33.337 7997 7997 F DEBUG : #02 pc 000000000006c6a0 /system/lib64/libhwui.so (android::uirenderer::renderthread::EglManager::damageFrame(android::uirenderer::renderthread::Frame const&, SkRect const&)+184)
08-31 16:59:33.337 7997 7997 F DEBUG : #03 pc 00000000000695b0 /system/lib64/libhwui.so (android::uirenderer::renderthread::OpenGLPipeline::draw(android::uirenderer::renderthread::Frame const&, SkRect const&, SkRect const&, android::uirenderer::FrameBuilder::LightGeometry const&, android::uirenderer::LayerUpdateQueue*, android::uirenderer::Rect const&, bool, bool, android::uirenderer::BakedOpRenderer::LightInfo const&, std::__1::vector<android::sp<android::uirenderer::RenderNode>, std::__1::allocator<android::sp<android::uirenderer::Render
08-31 16:59:33.339 7997 7997 F DEBUG : #04 pc 000000000006780c /system/lib64/libhwui.so (android::uirenderer::renderthread::CanvasContext::draw()+184)
08-31 16:59:33.339 7997 7997 F DEBUG : #05 pc 000000000006b47c /system/lib64/libhwui.so (android::uirenderer::renderthread::DrawFrameTask::run()+180)
08-31 16:59:33.339 7997 7997 F DEBUG : #06 pc 0000000000072a48 /system/lib64/libhwui.so (android::uirenderer::renderthread::RenderThread::threadLoop()+336)
08-31 16:59:33.339 7997 7997 F DEBUG : #07 pc 0000000000011478 /system/lib64/libutils.so (android::Thread::_threadLoop(void*)+280)
08-31 16:59:33.339 7997 7997 F DEBUG : #08 pc 00000000000a98c4 /system/lib64/libandroid_runtime.so (android::AndroidRuntime::javaThreadShell(void*)+140)
08-31 16:59:33.339 7997 7997 F DEBUG : #09 pc 0000000000067d80 /system/lib64/libc.so (__pthread_start(void*)+36)
08-31 16:59:33.339 7997 7997 F DEBUG : #10 pc 000000000001ec18 /system/lib64/libc.so (__start_thread+68)
相信很多见过次问题的人看到上面两个log文件很快就能发现问题点,但是笔者用了很久才找到核心点呀,就是error: Too many open files,这是什么问题呢?就是他妈的fd文件打开超出限制了,那么这个限制是多少呢?如何查看呢?
1.查找系统服务的Pid -> pidof system_server
2.cat /proc/系统pid/limits 这个Max open files的限制就是这个fd打开的限制
为了进一步确认这个问题,我们通过查看我们程序进程下的fd个数看看是不是持续增长,如果持续增长那么恭喜你找到原因了,再去查看增加的是哪些fd文件然后再看是什么原因导致的,笔者这里呢是由于AHardwareBuffer_allocate()这个函数申请完内存之后并没有进行AHardwareBuffer_release(),allocate这个函数是使用系统高效的GraphicBuffer,具体使用参考blog.csdn.net/u010116586/… ,所以呀使用底层库或者C语言编程的时候一定要记得释放内存!释放内存!释放内存!重要的事情说三遍!