diff options
author | Justin DeMartino <jjdemartino@google.com> | 2020-10-14 19:39:53 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2020-10-14 19:39:53 +0000 |
commit | 0d11af03e43f110b0bb160f7e20436d0043e3038 (patch) | |
tree | 48f8bcca856276ec73a86dd3fb26143d3ca64578 /libutils/LruCache_fuzz.cpp | |
parent | 075666ebd0dee8d0c4a2efa54f7c324a3f67ee2a (diff) | |
parent | a6c01e4e98d2b343dcecfc99611e2e6250c730db (diff) |
Merge changes from topic "SP1A.200921.001" into s-keystone-qcom-dev
* changes:
fs_mgr: adb-remount-test.sh: filter out more administrivia mounts.
Merge SP1A.200921.001 Change-Id: I90b97c4e9fb10b1f45e74def404823eed5b1aaa8
Diffstat (limited to 'libutils/LruCache_fuzz.cpp')
-rw-r--r-- | libutils/LruCache_fuzz.cpp | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/libutils/LruCache_fuzz.cpp b/libutils/LruCache_fuzz.cpp new file mode 100644 index 000000000..f8bacfcbc --- /dev/null +++ b/libutils/LruCache_fuzz.cpp @@ -0,0 +1,74 @@ +/* + * Copyright 2020 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 <functional> + +#include "fuzzer/FuzzedDataProvider.h" +#include "utils/LruCache.h" +#include "utils/StrongPointer.h" + +typedef android::LruCache<size_t, size_t> FuzzCache; + +static constexpr uint32_t MAX_CACHE_ENTRIES = 800; + +class NoopRemovedCallback : public android::OnEntryRemoved<size_t, size_t> { + public: + void operator()(size_t&, size_t&) { + // noop + } +}; + +static NoopRemovedCallback callback; + +static const std::vector<std::function<void(FuzzedDataProvider*, FuzzCache*)>> operations = { + [](FuzzedDataProvider*, FuzzCache* cache) -> void { cache->removeOldest(); }, + [](FuzzedDataProvider*, FuzzCache* cache) -> void { cache->peekOldestValue(); }, + [](FuzzedDataProvider*, FuzzCache* cache) -> void { cache->clear(); }, + [](FuzzedDataProvider*, FuzzCache* cache) -> void { cache->size(); }, + [](FuzzedDataProvider*, FuzzCache* cache) -> void { + android::LruCache<size_t, size_t>::Iterator iter(*cache); + while (iter.next()) { + iter.key(); + iter.value(); + } + }, + [](FuzzedDataProvider* dataProvider, FuzzCache* cache) -> void { + size_t key = dataProvider->ConsumeIntegral<size_t>(); + size_t val = dataProvider->ConsumeIntegral<size_t>(); + cache->put(key, val); + }, + [](FuzzedDataProvider* dataProvider, FuzzCache* cache) -> void { + size_t key = dataProvider->ConsumeIntegral<size_t>(); + cache->get(key); + }, + [](FuzzedDataProvider* dataProvider, FuzzCache* cache) -> void { + size_t key = dataProvider->ConsumeIntegral<size_t>(); + cache->remove(key); + }, + [](FuzzedDataProvider*, FuzzCache* cache) -> void { + cache->setOnEntryRemovedListener(&callback); + }}; + +extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { + FuzzedDataProvider dataProvider(data, size); + FuzzCache cache(MAX_CACHE_ENTRIES); + while (dataProvider.remaining_bytes() > 0) { + uint8_t op = dataProvider.ConsumeIntegral<uint8_t>() % operations.size(); + operations[op](&dataProvider, &cache); + } + + return 0; +} |