2

我正在运行一个使用 ScreenshotClient 循环捕获屏幕的本机进程。随机运行几次后,当我关闭进程时,我得到“服务'SurfaceFlinger'死亡”并且屏幕重新启动。这在 android 4.2 中不会发生。

这是回溯:

I/DEBUG   (  111): backtrace:
I/DEBUG   (  111):     #00  pc 0002a61e  /system/lib/libgui.so
I/DEBUG   (  111):     #01  pc 0002f205  /system/lib/libgui.so (android::Surface::queueBuffer(ANativeWindowBuffer*, int)+220)
I/DEBUG   (  111):     #02  pc 0002e2cd  /system/lib/libgui.so (android::Surface::hook_queueBuffer(ANativeWindow*, ANativeWindowBuffer*, int)+10)
I/DEBUG   (  111):     #03  pc 00017fb9  /system/lib/libsurfaceflinger.so
I/DEBUG   (  111):     #04  pc 0001b6f1  /system/lib/libsurfaceflinger.so
I/DEBUG   (  111):     #05  pc 00015e6f  /system/lib/libsurfaceflinger.so
I/DEBUG   (  111):     #06  pc 00010767  /system/lib/libutils.so (android::Looper::pollInner(int)+394)
I/DEBUG   (  111):     #07  pc 00010869  /system/lib/libutils.so (android::Looper::pollOnce(int, int*, int*, void**)+92)
I/DEBUG   (  111):     #08  pc 00016089  /system/lib/libsurfaceflinger.so
I/DEBUG   (  111):     #09  pc 00016f7b  /system/lib/libsurfaceflinger.so (android::SurfaceFlinger::run()+6)
I/DEBUG   (  111):     #10  pc 000008fd  /system/bin/surfaceflinger
I/DEBUG   (  111):     #11  pc 0000e403  /system/lib/libc.so (__libc_init+50)
I/DEBUG   (  111):     #12  pc 000007dc  /system/bin/surfaceflinger
4

2 回答 2

0

在过去的几天里,我已经看到 3 个 SurfaceFlinger 崩溃了。似乎实现中存在错误。由于我使用的是 S5,我不能说这是三星特定的问题还是一般的 Android 4.4.2 问题。您正在使用哪种设备?

要从此问题中恢复,您只需重新启动设备即可。有时我设法执行“kill -9”(我使用“ps | grep”获得了 pid)并在不重新启动设备的情况下使所有内容恢复运行。我曾经杀死剩余/挂起的surfaceflinger或mediaserver服务。因为它在被杀死后会自动重启,所以之后一切都很好。

由于这些是设备随附的二进制文件,因此可能无法解决此问题。但机会很小:如果二进制文件与 AOSP(Android 开源项目http://source.android.com/ )中的二进制文件相同,您可以尝试编译这些文件并替换手机上的文件(请备份首先是原始的)。

如果二进制文件是特定于设备的,您可能会在设备供应商的开源页面上找到它们。就像三星设备的http://opensource.samsung.com/。这些源代码通常很容易编译,并且可以替换手机上的二进制文件。

除此之外,我认为只剩下报告这个问题了。

于 2014-05-04T19:22:28.483 回答
0

当我干净地关闭进程而不是杀死它时,SurfaceFlinger 不会再死了。

于 2014-05-11T08:48:28.600 回答