【发布时间】:2018-02-19 16:28:10
【问题描述】:
我正在尝试使用此处描述的地址清理程序(https://github.com/google/sanitizers/wiki/AddressSanitizer,更准确地说是:https://github.com/google/sanitizers/wiki/AddressSanitizerOnAndroid)构建(使用 clang)我的应用程序,但我无法理解整个过程,尤其是使用 gradle。
看起来至少有 3 种方法可以启用它:
1°) 在第一个链接之后,t 表示您所要做的就是这样做:
将
-fsanitize=address添加到cppFlags + 可选-fno-omit-frame-pointer将
-fsanitize=address添加到链接器标志(有必要吗?)
2°) 在第二个链接之后,您似乎必须这样做:
- 和第一个一样
- root 设备,然后通过 adb 在其上运行 asan_device_setup
- 在某处添加
LD_PRELOAD=libclang_rt.asan-arm-android.so?我想它应该放在 gradle externalNativeBuild 的“参数”部分?但是应用程序在哪里可以找到这个库?我必须自己链接吗?还是它已经在设备上的某个地方?
3°)我还找到了一种“新”的方法,它不需要 root 访问权限(确实可以,但它是一个错误,需要在某个时候纠正):
https://virtualrealitypop.com/oreo-ndk-secrets-7d075a9b084
这个方法实际上做了第一点和第二点所做的事情,并且通过启动一个导出一些值的 shell 脚本来运行应用程序,以便 asan 工作。
就我的调查而言,我对在我的根模拟器上运行完全清理的应用程序(带有静态链接库)的正确方法有点困惑。
我走的更远是实际构建和启动应用程序(使用 2°),但没有指定 LD_PRELOAD 标志),但应用程序在某些 eglMakeCurrent 函数中崩溃,容器溢出甚至不是我的一部分代码,我没有得到任何堆栈:
02-19 16:26:21.553 28771-28789/com.mycompany.myapp I/zygote: Background concurrent copying GC freed 10159(1175KB) AllocSpace objects, 12(304KB) LOS objects, 50% free, 2MB/4MB, paused 144.861ms total 1.252s
[ 02-19 16:26:21.554 28771:28956 I/ ]
=================================================================
[ 02-19 16:26:21.554 28771:28956 I/ ]
[ 02-19 16:26:21.557 28771:28956 I/ ]
[ 02-19 16:26:21.563 28771:28956 I/ ]
==28771==ERROR: AddressSanitizer: container-overflow on address 0xa136e990 at pc 0xa49849e2 bp 0x82e60558 sp 0x82e60128
[ 02-19 16:26:21.563 28771:28956 I/ ]
[ 02-19 16:26:21.565 28771:28956 I/ ]
[ 02-19 16:26:21.566 28771:28956 I/ ]
WRITE of size 2 at 0xa136e990 thread T334 (GLThread 337)
[ 02-19 16:26:21.566 28771:28956 I/ ]
我不确定这是否是真正的溢出,因为我不确定我的所有应用程序都是用消毒剂构建的(我已经用它构建了我的 so+ 我所有的静态数据,但够了吗?),https://github.com/google/sanitizers/wiki/AddressSanitizerContainerOverflow 说如果你的整个应用没有使用消毒剂构建,您可能会得到误报。
所以我的问题是:
A°) 有人真的设法使用 android studio 构建了一个经过清理的应用程序吗?
B°) 如果是,那么正确的方法是什么(意味着将被支持的方法)?
【问题讨论】:
-
这个运气好吗?我也在努力让这个工作。
标签: android android-gradle-plugin clang address-sanitizer