diff options
author | Biddu Singh <biddubhushan@google.com> | 2022-08-10 10:30:51 +0000 |
---|---|---|
committer | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | 2022-08-10 10:30:51 +0000 |
commit | 9f96bc93110589b833c6724412b3d60202cf769b (patch) | |
tree | dbba2643e0eebfc43907fc777d7c3824de471f89 | |
parent | fae29d487842224fe8f76148e572595af7993a09 (diff) | |
parent | f8cd7cae4b916b642c1798f179209cedf2bd8792 (diff) | |
download | native-9f96bc93110589b833c6724412b3d60202cf769b.tar.gz |
Merge "Added sensor_fuzzer Test: ./sensor_fuzzer" am: f8cd7cae4b
Original change: https://android-review.googlesource.com/c/platform/frameworks/native/+/2158836
Change-Id: I6ad7bff39cbeea18feaf9e7d1feee26bc2b7355f
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
-rw-r--r-- | libs/sensor/fuzz/sensor_fuzzer/Android.bp | 38 | ||||
-rw-r--r-- | libs/sensor/fuzz/sensor_fuzzer/sensor_fuzzer.cpp | 51 |
2 files changed, 89 insertions, 0 deletions
diff --git a/libs/sensor/fuzz/sensor_fuzzer/Android.bp b/libs/sensor/fuzz/sensor_fuzzer/Android.bp new file mode 100644 index 0000000000..cb17484748 --- /dev/null +++ b/libs/sensor/fuzz/sensor_fuzzer/Android.bp @@ -0,0 +1,38 @@ +/****************************************************************************** + * + * Copyright (C) 2022 The Android Open Source Project + * + * 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. + * + ***************************************************************************** + */ +cc_fuzz { + name: "sensor_fuzzer", + srcs: [ + "sensor_fuzzer.cpp", + ], + shared_libs: [ + "libsensor", + "libbinder", + "libcutils", + "libutils", + "liblog", + "libhardware", + "libpermission", + ], + export_shared_lib_headers: [ + "libbinder", + "libpermission", + "libhardware", + ], +} diff --git a/libs/sensor/fuzz/sensor_fuzzer/sensor_fuzzer.cpp b/libs/sensor/fuzz/sensor_fuzzer/sensor_fuzzer.cpp new file mode 100644 index 0000000000..129f4302c5 --- /dev/null +++ b/libs/sensor/fuzz/sensor_fuzzer/sensor_fuzzer.cpp @@ -0,0 +1,51 @@ +/****************************************************************************** + * + * Copyright (C) 2022 The Android Open Source Project + * + * 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. + * + ***************************************************************************** + */ +#include <fuzzer/FuzzedDataProvider.h> + +#include <sensor/Sensor.h> +using namespace android; + +const int MAX_STR_LEN = 32; + +extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { + FuzzedDataProvider fdp(data, size); + struct sensor_t sensor_type; + sensor_type.name = fdp.ConsumeBytesAsString(MAX_STR_LEN).c_str(); + sensor_type.vendor = fdp.ConsumeBytesAsString(MAX_STR_LEN).c_str(); + sensor_type.stringType = ""; + sensor_type.requiredPermission = ""; + sensor_type.version = fdp.ConsumeIntegral<int>(); + sensor_type.handle = fdp.ConsumeIntegral<int>(); + sensor_type.type = fdp.ConsumeIntegral<int>(); + sensor_type.maxRange = fdp.ConsumeFloatingPoint<float>(); + sensor_type.resolution = fdp.ConsumeFloatingPoint<float>(); + sensor_type.power = fdp.ConsumeFloatingPoint<float>(); + sensor_type.minDelay = fdp.ConsumeIntegral<int32_t>(); + sensor_type.fifoReservedEventCount = fdp.ConsumeIntegral<uint32_t>(); + sensor_type.fifoMaxEventCount = fdp.ConsumeIntegral<uint32_t>(); + int halVersion = fdp.ConsumeIntegral<int>(); + Sensor sensor1(&sensor_type, halVersion); + uint8_t buffer[size]; + for (int i = 0; i < size; i++) buffer[i] = data[i]; + sensor1.flatten(buffer, size); + std::vector<uint8_t> buffer1(sensor1.getFlattenedSize()); + auto ab = sensor1.unflatten(buffer1.data(), buffer1.size()); + return 0; +} + |