1 /*
2  * Copyright (c) 2024 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 #include "hksgeneraterandom_fuzzer.h"
16 
17 #include <securec.h>
18 
19 #include "hks_api.h"
20 #include "hks_mem.h"
21 #include "hks_param.h"
22 #include "hks_type.h"
23 
24 #include "hks_fuzz_util.h"
25 
26 namespace OHOS {
27 namespace Security {
28 namespace Hks {
29 
DoSomethingInterestingWithMyAPI(uint8_t *data, size_t size)30 int DoSomethingInterestingWithMyAPI(uint8_t *data, size_t size)
31 {
32     if (data == nullptr || size < sizeof(uint32_t)) {
33         return -1;
34     }
35 
36     struct HksBlob random = { sizeof(uint32_t), ReadData<uint8_t *>(data, size, sizeof(uint32_t)) };
37 
38     WrapParamSet ps = ConstructHksParamSetFromFuzz(data, size);
39 
40     [[maybe_unused]] int ret = HksGenerateRandom(ps.s, &random);
41 
42     return 0;
43 }
44 }}}
45 
LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)46 extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
47 {
48     std::vector<uint8_t> v(data, data + size);
49     return OHOS::Security::Hks::DoSomethingInterestingWithMyAPI(v.data(), v.size());
50 }
51