aboutsummaryrefslogtreecommitdiff
path: root/src/jmh/java/com/code_intelligence/jazzer/runtime/FuzzerCallbacksOptimizedCritical.java
diff options
context:
space:
mode:
authorMark <mteffeteller@google.com>2023-06-22 00:59:06 +0000
committerAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2023-06-22 00:59:06 +0000
commit33edd6723662ea34453766bfdca85dbfdd5342b8 (patch)
tree68cf332a40b94b2d28b256b19b916f99220bb0c4 /src/jmh/java/com/code_intelligence/jazzer/runtime/FuzzerCallbacksOptimizedCritical.java
parentba37c2e361c2ba91bacc47fcae5383c52e50f6be (diff)
parentf1ff6ce482549c51088d0a4b011d676904ad2506 (diff)
downloadjazzer-api-master.tar.gz
Original change: https://android-review.googlesource.com/c/platform/external/jazzer-api/+/2627336 Change-Id: Iaaed944c1e9e457640f7055fc57e8678f90f4603 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
Diffstat (limited to 'src/jmh/java/com/code_intelligence/jazzer/runtime/FuzzerCallbacksOptimizedCritical.java')
-rw-r--r--src/jmh/java/com/code_intelligence/jazzer/runtime/FuzzerCallbacksOptimizedCritical.java46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/jmh/java/com/code_intelligence/jazzer/runtime/FuzzerCallbacksOptimizedCritical.java b/src/jmh/java/com/code_intelligence/jazzer/runtime/FuzzerCallbacksOptimizedCritical.java
new file mode 100644
index 00000000..1c09e9ad
--- /dev/null
+++ b/src/jmh/java/com/code_intelligence/jazzer/runtime/FuzzerCallbacksOptimizedCritical.java
@@ -0,0 +1,46 @@
+// Copyright 2022 Code Intelligence GmbH
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+package com.code_intelligence.jazzer.runtime;
+
+import com.github.fmeum.rules_jni.RulesJni;
+import java.io.UnsupportedEncodingException;
+
+/**
+ * Optimized implementations of the libFuzzer callbacks that do rely on the deprecated
+ * CriticalJNINatives feature. Methods with `Java` in their name implement some parts in Java.
+ */
+public final class FuzzerCallbacksOptimizedCritical {
+ static {
+ RulesJni.loadLibrary("fuzzer_callbacks", FuzzerCallbacksOptimizedCritical.class);
+ }
+
+ static native void traceCmpInt(int arg1, int arg2, int pc);
+
+ static native void traceSwitch(long val, long[] cases, int pc);
+
+ static native void traceMemcmp(byte[] b1, byte[] b2, int result, int pc);
+
+ static void traceStrstrJava(String haystack, String needle, int pc)
+ throws UnsupportedEncodingException {
+ // Note that we are not encoding as modified UTF-8 here: The FuzzedDataProvider transparently
+ // converts CESU8 into modified UTF-8 by coding null bytes on two bytes. Since the fuzzer is
+ // more likely to insert literal null bytes, having both the fuzzer input and the reported
+ // string comparisons be CESU8 should perform even better than the current implementation using
+ // modified UTF-8.
+ traceStrstrInternal(needle.substring(0, Math.min(needle.length(), 64)).getBytes("CESU8"), pc);
+ }
+
+ private static native void traceStrstrInternal(byte[] needle, int pc);
+}