aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorvanhauser-thc <vh@thc.org>2021-02-22 12:43:39 +0100
committervanhauser-thc <vh@thc.org>2021-02-22 12:43:39 +0100
commit8c133b607cdbde60e6c922236947f7a69c9190f2 (patch)
tree80c07adca02b8d4edc7a228aeca4fbdfe427ffd7
parent2785c8b197a1e7f109fa4dfb47fdd82eca0ad008 (diff)
downloadafl++-8c133b607cdbde60e6c922236947f7a69c9190f2.tar.gz
stdstring fix attempt
-rw-r--r--instrumentation/afl-compiler-rt.o.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/instrumentation/afl-compiler-rt.o.c b/instrumentation/afl-compiler-rt.o.c
index dba4dc65..324d541d 100644
--- a/instrumentation/afl-compiler-rt.o.c
+++ b/instrumentation/afl-compiler-rt.o.c
@@ -1653,12 +1653,19 @@ static u8 *get_llvm_stdstring(u8 *string) {
void __cmplog_rtn_gcc_stdstring_cstring(u8 *stdstring, u8 *cstring) {
+ if (unlikely(!__afl_cmp_map)) return;
+ if (!area_is_mapped(stdstring, 32) || !area_is_mapped(cstring, 32)) return;
+
__cmplog_rtn_hook(get_gcc_stdstring(stdstring), cstring);
}
void __cmplog_rtn_gcc_stdstring_stdstring(u8 *stdstring1, u8 *stdstring2) {
+ if (unlikely(!__afl_cmp_map)) return;
+ if (!area_is_mapped(stdstring1, 32) || !area_is_mapped(stdstring2, 32))
+ return;
+
__cmplog_rtn_hook(get_gcc_stdstring(stdstring1),
get_gcc_stdstring(stdstring2));
@@ -1666,12 +1673,17 @@ void __cmplog_rtn_gcc_stdstring_stdstring(u8 *stdstring1, u8 *stdstring2) {
void __cmplog_rtn_llvm_stdstring_cstring(u8 *stdstring, u8 *cstring) {
+ if (unlikely(!__afl_cmp_map)) return;
+ if (!area_is_mapped(stdstring, 32) || !area_is_mapped(cstring, 32)) return;
__cmplog_rtn_hook(get_llvm_stdstring(stdstring), cstring);
}
void __cmplog_rtn_llvm_stdstring_stdstring(u8 *stdstring1, u8 *stdstring2) {
+ if (unlikely(!__afl_cmp_map)) return;
+ if (!area_is_mapped(stdstring1, 32) || !area_is_mapped(stdstring2, 32))
+ return;
__cmplog_rtn_hook(get_llvm_stdstring(stdstring1),
get_llvm_stdstring(stdstring2));