1*eb293b8fSAndroid Build Coastguard Worker /* 2*eb293b8fSAndroid Build Coastguard Worker * Copyright 2020 The Android Open Source Project 3*eb293b8fSAndroid Build Coastguard Worker * 4*eb293b8fSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*eb293b8fSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*eb293b8fSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*eb293b8fSAndroid Build Coastguard Worker * 8*eb293b8fSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*eb293b8fSAndroid Build Coastguard Worker * 10*eb293b8fSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*eb293b8fSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*eb293b8fSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*eb293b8fSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*eb293b8fSAndroid Build Coastguard Worker * limitations under the License. 15*eb293b8fSAndroid Build Coastguard Worker */ 16*eb293b8fSAndroid Build Coastguard Worker 17*eb293b8fSAndroid Build Coastguard Worker #pragma once 18*eb293b8fSAndroid Build Coastguard Worker 19*eb293b8fSAndroid Build Coastguard Worker #include <elf.h> 20*eb293b8fSAndroid Build Coastguard Worker #include <sys/mman.h> 21*eb293b8fSAndroid Build Coastguard Worker 22*eb293b8fSAndroid Build Coastguard Worker #include <memory> 23*eb293b8fSAndroid Build Coastguard Worker #include <string> 24*eb293b8fSAndroid Build Coastguard Worker #include <vector> 25*eb293b8fSAndroid Build Coastguard Worker 26*eb293b8fSAndroid Build Coastguard Worker #include <fuzzer/FuzzedDataProvider.h> 27*eb293b8fSAndroid Build Coastguard Worker #include <unwindstack/DexFiles.h> 28*eb293b8fSAndroid Build Coastguard Worker #include <unwindstack/Maps.h> 29*eb293b8fSAndroid Build Coastguard Worker #include <unwindstack/Regs.h> 30*eb293b8fSAndroid Build Coastguard Worker #include <unwindstack/RegsArm.h> 31*eb293b8fSAndroid Build Coastguard Worker #include <unwindstack/RegsArm64.h> 32*eb293b8fSAndroid Build Coastguard Worker #include <unwindstack/RegsRiscv64.h> 33*eb293b8fSAndroid Build Coastguard Worker #include <unwindstack/RegsX86.h> 34*eb293b8fSAndroid Build Coastguard Worker #include <unwindstack/RegsX86_64.h> 35*eb293b8fSAndroid Build Coastguard Worker 36*eb293b8fSAndroid Build Coastguard Worker #include "../ElfFake.h" 37*eb293b8fSAndroid Build Coastguard Worker #include "utils/MemoryFake.h" 38*eb293b8fSAndroid Build Coastguard Worker 39*eb293b8fSAndroid Build Coastguard Worker #include "fuzzer/FuzzedDataProvider.h" 40*eb293b8fSAndroid Build Coastguard Worker 41*eb293b8fSAndroid Build Coastguard Worker using unwindstack::ArchEnum; 42*eb293b8fSAndroid Build Coastguard Worker using unwindstack::DexFiles; 43*eb293b8fSAndroid Build Coastguard Worker using unwindstack::Elf; 44*eb293b8fSAndroid Build Coastguard Worker using unwindstack::ElfFake; 45*eb293b8fSAndroid Build Coastguard Worker using unwindstack::ElfInterfaceFake; 46*eb293b8fSAndroid Build Coastguard Worker using unwindstack::FunctionData; 47*eb293b8fSAndroid Build Coastguard Worker using unwindstack::Maps; 48*eb293b8fSAndroid Build Coastguard Worker using unwindstack::Memory; 49*eb293b8fSAndroid Build Coastguard Worker using unwindstack::MemoryFake; 50*eb293b8fSAndroid Build Coastguard Worker using unwindstack::Regs; 51*eb293b8fSAndroid Build Coastguard Worker using unwindstack::StepData; 52*eb293b8fSAndroid Build Coastguard Worker 53*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kArchCount = 5; 54*eb293b8fSAndroid Build Coastguard Worker 55*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kMaxSoNameLen = 150; 56*eb293b8fSAndroid Build Coastguard Worker 57*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kMaxFuncNameLen = 50; 58*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kMaxFuncCount = 100; 59*eb293b8fSAndroid Build Coastguard Worker 60*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kMaxJitElfFiles = 20; 61*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kJitElfPadding = 32; 62*eb293b8fSAndroid Build Coastguard Worker 63*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kMaxStepCount = 100; 64*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kMaxMapEntryCount = 50; 65*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kMaxBuildIdLen = 100; 66*eb293b8fSAndroid Build Coastguard Worker static constexpr uint8_t kMaxMapInfoNameLen = 150; 67*eb293b8fSAndroid Build Coastguard Worker 68*eb293b8fSAndroid Build Coastguard Worker std::unique_ptr<unwindstack::Regs> GetRegisters(unwindstack::ArchEnum arch); 69*eb293b8fSAndroid Build Coastguard Worker std::unique_ptr<unwindstack::Maps> GetMaps(FuzzedDataProvider* data_provider); 70*eb293b8fSAndroid Build Coastguard Worker std::vector<std::string> GetStringList(FuzzedDataProvider* data_provider, uint max_str_len, 71*eb293b8fSAndroid Build Coastguard Worker uint max_strings); 72*eb293b8fSAndroid Build Coastguard Worker unwindstack::ArchEnum GetArch(FuzzedDataProvider* data_provider); 73*eb293b8fSAndroid Build Coastguard Worker 74*eb293b8fSAndroid Build Coastguard Worker void AddMapInfo(uint64_t start, uint64_t end, uint64_t offset, uint64_t flags, const char* name, 75*eb293b8fSAndroid Build Coastguard Worker Elf* elf = nullptr); 76*eb293b8fSAndroid Build Coastguard Worker void PutElfFilesInMemory(MemoryFake* memory, FuzzedDataProvider* data_provider); 77*eb293b8fSAndroid Build Coastguard Worker 78*eb293b8fSAndroid Build Coastguard Worker std::unique_ptr<unwindstack::DexFiles> GetDexFiles(FuzzedDataProvider* data_provider, 79*eb293b8fSAndroid Build Coastguard Worker std::shared_ptr<unwindstack::Memory> memory, 80*eb293b8fSAndroid Build Coastguard Worker uint max_libraries, uint max_library_length, 81*eb293b8fSAndroid Build Coastguard Worker unwindstack::ArchEnum arch); 82