Merge "Add an AIDL fuzzer for health service" am: 5c04494c60
am: b1165847fb
Original change: https://android-review.googlesource.com/c/platform/hardware/interfaces/+/2094863 Change-Id: Ibd4de8004027e98123fb4ad586766a3063af5722 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
commit
25c5d2e804
2 changed files with 103 additions and 0 deletions
|
@ -159,3 +159,70 @@ cc_binary {
|
||||||
init_rc: ["android.hardware.health-service.example_recovery.rc"],
|
init_rc: ["android.hardware.health-service.example_recovery.rc"],
|
||||||
overrides: ["charger.recovery"],
|
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",
|
||||||
|
],
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
36
health/aidl/default/fuzzer.cpp
Normal file
36
health/aidl/default/fuzzer.cpp
Normal 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;
|
||||||
|
}
|
Loading…
Reference in a new issue