1e509ee18Sopenharmony_ci/* 2e509ee18Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd. 3e509ee18Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4e509ee18Sopenharmony_ci * you may not use this file except in compliance with the License. 5e509ee18Sopenharmony_ci * You may obtain a copy of the License at 6e509ee18Sopenharmony_ci * 7e509ee18Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8e509ee18Sopenharmony_ci * 9e509ee18Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10e509ee18Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11e509ee18Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12e509ee18Sopenharmony_ci * See the License for the specific language governing permissions and 13e509ee18Sopenharmony_ci * limitations under the License. 14e509ee18Sopenharmony_ci */ 15e509ee18Sopenharmony_ci 16e509ee18Sopenharmony_ci#include "heapprofilerdispatch_fuzzer.h" 17e509ee18Sopenharmony_ci#include "ecmascript/napi/include/jsnapi.h" 18e509ee18Sopenharmony_ci#include "agent/heapprofiler_impl.h" 19e509ee18Sopenharmony_ci#include "tooling/dispatcher.h" 20e509ee18Sopenharmony_ci 21e509ee18Sopenharmony_ciusing namespace panda; 22e509ee18Sopenharmony_ciusing namespace panda::ecmascript; 23e509ee18Sopenharmony_ciusing namespace panda::ecmascript::tooling; 24e509ee18Sopenharmony_ci 25e509ee18Sopenharmony_ci#define MAXBYTELEN sizeof(int32_t) 26e509ee18Sopenharmony_ci 27e509ee18Sopenharmony_cinamespace OHOS { 28e509ee18Sopenharmony_ci void HeapprofilerDispatchFuzzTest(const uint8_t* data, size_t size) 29e509ee18Sopenharmony_ci { 30e509ee18Sopenharmony_ci RuntimeOption option; 31e509ee18Sopenharmony_ci option.SetLogLevel(RuntimeOption::LOG_LEVEL::ERROR); 32e509ee18Sopenharmony_ci auto vm = JSNApi::CreateJSVM(option); 33e509ee18Sopenharmony_ci if (size <= 0) { 34e509ee18Sopenharmony_ci return; 35e509ee18Sopenharmony_ci } 36e509ee18Sopenharmony_ci int32_t input = 0; 37e509ee18Sopenharmony_ci if (size > MAXBYTELEN) { 38e509ee18Sopenharmony_ci size = MAXBYTELEN; 39e509ee18Sopenharmony_ci } 40e509ee18Sopenharmony_ci if (memcpy_s(&input, MAXBYTELEN, data, size) != 0) { 41e509ee18Sopenharmony_ci std::cout << "memcpy_s failed!"; 42e509ee18Sopenharmony_ci UNREACHABLE(); 43e509ee18Sopenharmony_ci } 44e509ee18Sopenharmony_ci std::string str(data, data + size); 45e509ee18Sopenharmony_ci auto req = std::make_unique<DispatchRequest>(str); 46e509ee18Sopenharmony_ci auto heapProfiler = std::make_unique<HeapProfilerImpl>(vm, nullptr); 47e509ee18Sopenharmony_ci auto dispatcherImpl = 48e509ee18Sopenharmony_ci std::make_unique<HeapProfilerImpl::DispatcherImpl>(nullptr, std::move(heapProfiler)); 49e509ee18Sopenharmony_ci dispatcherImpl->Dispatch(*req); 50e509ee18Sopenharmony_ci JSNApi::DestroyJSVM(vm); 51e509ee18Sopenharmony_ci } 52e509ee18Sopenharmony_ci} 53e509ee18Sopenharmony_ci 54e509ee18Sopenharmony_ci// Fuzzer entry point. 55e509ee18Sopenharmony_ciextern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) 56e509ee18Sopenharmony_ci{ 57e509ee18Sopenharmony_ci // Run your code on data. 58e509ee18Sopenharmony_ci OHOS::HeapprofilerDispatchFuzzTest(data, size); 59e509ee18Sopenharmony_ci return 0; 60e509ee18Sopenharmony_ci}