1 /*
2 * Copyright (c) 2022 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16 #include "flowbufferadapterimpl_fuzzer.h"
17
18 #include <securec.h>
19 #include <sys/mman.h>
20
21 #include "ohos_adapter_helper.h"
22 #define private public
23 #include "flowbuffer_adapter_impl.h"
24
25 using namespace OHOS::NWeb;
26
27 namespace OHOS {
ApplyFlowBufferAdapterImplFuzzTest(const uint8_t* data, size_t size)28 bool ApplyFlowBufferAdapterImplFuzzTest(const uint8_t* data, size_t size)
29 {
30 if ((data == nullptr) || (size < sizeof(int32_t))) {
31 return false;
32 }
33 auto flowbufferAdapter = OhosAdapterHelper::GetInstance().CreateFlowbufferAdapter();
34 int fd = 0;
35 size_t scriptLength = 10;
36 auto ashmem = flowbufferAdapter->CreateAshmem(scriptLength, PROT_READ | PROT_WRITE, fd);
37 (void)ashmem;
38 flowbufferAdapter->StartPerformanceBoost();
39
40 auto flowbufferAdapter1 = OhosAdapterHelper::GetInstance().CreateFlowbufferAdapter();
41 int fd1;
42 size_t scriptLength1 = 10;
43 flowbufferAdapter1->CreateAshmem(scriptLength1, PROT_READ | PROT_WRITE, fd1);
44 auto ashmem1 = flowbufferAdapter->CreateAshmemWithFd(fd1, scriptLength1, PROT_READ);
45 (void)ashmem1;
46 flowbufferAdapter1->StartPerformanceBoost();
47 return true;
48 }
49 } // namespace OHOS
50
51 /* Fuzzer entry point */
LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)52 extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
53 {
54 /* Run your code on data */
55 OHOS::ApplyFlowBufferAdapterImplFuzzTest(data, size);
56 return 0;
57 }
58