1094332d3Sopenharmony_ci/*
2094332d3Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd.
3094332d3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4094332d3Sopenharmony_ci * you may not use this file except in compliance with the License.
5094332d3Sopenharmony_ci * You may obtain a copy of the License at
6094332d3Sopenharmony_ci *
7094332d3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8094332d3Sopenharmony_ci *
9094332d3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10094332d3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11094332d3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12094332d3Sopenharmony_ci * See the License for the specific language governing permissions and
13094332d3Sopenharmony_ci * limitations under the License.
14094332d3Sopenharmony_ci */
15094332d3Sopenharmony_ci
16094332d3Sopenharmony_ci#include "huks_hdi_fuzzer.h"
17094332d3Sopenharmony_ci#include "huks_hdi_passthrough_adapter.h"
18094332d3Sopenharmony_ci#include "huks_hdi_fuzz_common.h"
19094332d3Sopenharmony_ci
20094332d3Sopenharmony_ci#include <cstddef>
21094332d3Sopenharmony_ci#include <cstdint>
22094332d3Sopenharmony_ci#include <securec.h>
23094332d3Sopenharmony_ci
24094332d3Sopenharmony_cistruct HuksHdi *g_instance = nullptr;
25094332d3Sopenharmony_ci
26094332d3Sopenharmony_ci#define PARAMSET_SIZE 108
27094332d3Sopenharmony_ci#define PRIVATE_KEY_SIZE 320
28094332d3Sopenharmony_ci#define PUBLIC_KEY_SIZE 52
29094332d3Sopenharmony_ci
30094332d3Sopenharmony_cibool DoSomethingInterestingWithMyAPI(const uint8_t* data, size_t size)
31094332d3Sopenharmony_ci{
32094332d3Sopenharmony_ci    if (data == nullptr || size <= (PARAMSET_SIZE + PRIVATE_KEY_SIZE + PUBLIC_KEY_SIZE)) {
33094332d3Sopenharmony_ci        return false;
34094332d3Sopenharmony_ci    }
35094332d3Sopenharmony_ci    uint8_t *myData = static_cast<uint8_t *>(malloc(sizeof(uint8_t) * size));
36094332d3Sopenharmony_ci    if (myData == nullptr) {
37094332d3Sopenharmony_ci        return false;
38094332d3Sopenharmony_ci    }
39094332d3Sopenharmony_ci    (void)memcpy_s(myData, size, data, size);
40094332d3Sopenharmony_ci    struct HksBlob privatekey = { PRIVATE_KEY_SIZE, myData + PARAMSET_SIZE };
41094332d3Sopenharmony_ci    struct HksParamSet *paramSetIn = reinterpret_cast<struct HksParamSet *>(myData);
42094332d3Sopenharmony_ci    paramSetIn->paramSetSize = PARAMSET_SIZE;
43094332d3Sopenharmony_ci#ifdef HUKS_HDI_SOFTWARE
44094332d3Sopenharmony_ci    if (HuksFreshParamSet(paramSetIn, false) != 0) {
45094332d3Sopenharmony_ci        free(myData);
46094332d3Sopenharmony_ci        return false;
47094332d3Sopenharmony_ci    }
48094332d3Sopenharmony_ci#endif
49094332d3Sopenharmony_ci    struct HksBlob publickey = {
50094332d3Sopenharmony_ci        .data = myData + PARAMSET_SIZE + PRIVATE_KEY_SIZE,
51094332d3Sopenharmony_ci        .size = PUBLIC_KEY_SIZE
52094332d3Sopenharmony_ci    };
53094332d3Sopenharmony_ci    uint8_t buffer[1024];
54094332d3Sopenharmony_ci    struct HksBlob out = {
55094332d3Sopenharmony_ci        .data = buffer,
56094332d3Sopenharmony_ci        .size = sizeof(buffer)
57094332d3Sopenharmony_ci    };
58094332d3Sopenharmony_ci    (void)g_instance->HuksHdiAgreeKey(paramSetIn, &privatekey, &publickey, &out);
59094332d3Sopenharmony_ci    free(myData);
60094332d3Sopenharmony_ci    return true;
61094332d3Sopenharmony_ci}
62094332d3Sopenharmony_ci
63094332d3Sopenharmony_ci/* Fuzzer entry point */
64094332d3Sopenharmony_ciextern "C" int32_t LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
65094332d3Sopenharmony_ci{
66094332d3Sopenharmony_ci    if (InitHuksCoreEngine(&g_instance) != 0) {
67094332d3Sopenharmony_ci        return -1;
68094332d3Sopenharmony_ci    }
69094332d3Sopenharmony_ci    DoSomethingInterestingWithMyAPI(data, size);
70094332d3Sopenharmony_ci    return 0;
71094332d3Sopenharmony_ci}
72