Merge "Add an AIDL fuzzer for health service"

This commit is contained in:
Hamzeh Zawawy 2022-05-12 19:59:15 +00:00 committed by Gerrit Code Review
commit 5c04494c60
2 changed files with 103 additions and 0 deletions

View file

@ -159,3 +159,70 @@ cc_binary {
init_rc: ["android.hardware.health-service.example_recovery.rc"],
overrides: ["charger.recovery"],
}
// AIDL Fuzz version of libhealth2impl.
cc_library_static {
name: "fuzz_libhealth_aidl_impl",
defaults: [
"libhealth_aidl_common_defaults",
"libhealth_aidl_charger_defaults",
],
recovery_available: true,
export_include_dirs: ["include"],
export_static_lib_headers: [
"libbatterymonitor",
],
srcs: [
"ChargerUtils.cpp",
"health-convert.cpp",
"HalHealthLoop.cpp",
"Health.cpp",
"LinkedCallback.cpp",
],
target: {
recovery: {
exclude_srcs: [
"ChargerUtils.cpp",
],
},
},
}
cc_fuzz {
name: "android.hardware.health-service.aidl_fuzzer",
defaults: [
"libhealth_aidl_impl_user",
],
static_libs: [
"android.hardware.health-V1-ndk",
"libbase",
"libbinder_random_parcel",
"libcutils",
"liblog",
"libutils",
"fuzz_libhealth_aidl_impl",
],
target: {
android: {
shared_libs: [
"libbinder_ndk",
"libbinder",
],
},
host: {
static_libs: [
"libbinder_ndk",
"libbinder",
],
},
darwin: {
enabled: false,
},
},
srcs: ["fuzzer.cpp"],
fuzz_config: {
cc: [
"hamzeh@google.com",
],
},
}

View file

@ -0,0 +1,36 @@
/*
* 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 <fuzzbinder/libbinder_ndk_driver.h>
#include <fuzzer/FuzzedDataProvider.h>
#include <android-base/logging.h>
#include <android/binder_interface_utils.h>
#include <health-impl/Health.h>
#include <health/utils.h>
using aidl::android::hardware::health::Health;
using android::fuzzService;
using ndk::SharedRefBase;
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
auto config = std::make_unique<healthd_config>();
::android::hardware::health::InitHealthdConfig(config.get());
auto binder = ndk::SharedRefBase::make<Health>("default", std::move(config));
fuzzService(binder->asBinder().get(), FuzzedDataProvider(data, size));
return 0;
}