1d9f0492fSopenharmony_ci/*
2d9f0492fSopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd.
3d9f0492fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4d9f0492fSopenharmony_ci * you may not use this file except in compliance with the License.
5d9f0492fSopenharmony_ci * You may obtain a copy of the License at
6d9f0492fSopenharmony_ci *
7d9f0492fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0
8d9f0492fSopenharmony_ci *
9d9f0492fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10d9f0492fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11d9f0492fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12d9f0492fSopenharmony_ci * See the License for the specific language governing permissions and
13d9f0492fSopenharmony_ci * limitations under the License.
14d9f0492fSopenharmony_ci */
15d9f0492fSopenharmony_ci
16d9f0492fSopenharmony_ci#ifndef BASE_STARTUP_PARAM_TRIE_H
17d9f0492fSopenharmony_ci#define BASE_STARTUP_PARAM_TRIE_H
18d9f0492fSopenharmony_ci#include <stdio.h>
19d9f0492fSopenharmony_ci
20d9f0492fSopenharmony_ci#include "init_hashmap.h"
21d9f0492fSopenharmony_ci#include "init_param.h"
22d9f0492fSopenharmony_ci#include "list.h"
23d9f0492fSopenharmony_ci#include "param_common.h"
24d9f0492fSopenharmony_ci#include "param_osadp.h"
25d9f0492fSopenharmony_ci#include "param_security.h"
26d9f0492fSopenharmony_ci
27d9f0492fSopenharmony_ci#ifdef __cplusplus
28d9f0492fSopenharmony_ci#if __cplusplus
29d9f0492fSopenharmony_ciextern "C" {
30d9f0492fSopenharmony_ci#endif
31d9f0492fSopenharmony_ci#endif
32d9f0492fSopenharmony_ci
33d9f0492fSopenharmony_ci#define PARAM_TRIE_STACK_SIZE 25
34d9f0492fSopenharmony_ci
35d9f0492fSopenharmony_ciINIT_LOCAL_API int InitWorkSpace(WorkSpace *workSpace, int onlyRead, uint32_t spaceSize);
36d9f0492fSopenharmony_ciINIT_LOCAL_API void CloseWorkSpace(WorkSpace *workSpace);
37d9f0492fSopenharmony_ci
38d9f0492fSopenharmony_ci#define GetTrieNode(workSpace, offset) (ParamTrieNode *)(((offset) == 0 || (offset) > (workSpace)->area->dataSize) ? \
39d9f0492fSopenharmony_ci    NULL : (workSpace)->area->data + (offset))
40d9f0492fSopenharmony_ci
41d9f0492fSopenharmony_ci#define GetTrieRoot(workSpace) \
42d9f0492fSopenharmony_ci    (ParamTrieNode *)(((workSpace)->area == NULL) ? NULL : (workSpace)->area->data + (workSpace)->area->firstNode)
43d9f0492fSopenharmony_ci
44d9f0492fSopenharmony_ciINIT_LOCAL_API void SaveIndex(uint32_t *index, uint32_t offset);
45d9f0492fSopenharmony_ci
46d9f0492fSopenharmony_ciINIT_LOCAL_API ParamTrieNode *AddTrieNode(WorkSpace *workSpace, const char *key, uint32_t keyLen);
47d9f0492fSopenharmony_ciINIT_LOCAL_API ParamTrieNode *FindTrieNode(
48d9f0492fSopenharmony_ci    WorkSpace *workSpace, const char *key, uint32_t keyLen, uint32_t *matchLabel);
49d9f0492fSopenharmony_ci
50d9f0492fSopenharmony_citypedef int (*TraversalTrieNodePtr)(const WorkSpace *workSpace, const ParamTrieNode *node, const void *cookie);
51d9f0492fSopenharmony_ciINIT_LOCAL_API int TraversalTrieNode(const WorkSpace *workSpace,
52d9f0492fSopenharmony_ci    const ParamTrieNode *subTrie, TraversalTrieNodePtr walkFunc, const void *cookie);
53d9f0492fSopenharmony_ci
54d9f0492fSopenharmony_ciINIT_LOCAL_API uint32_t AddParamSecurityNode(WorkSpace *workSpace, const ParamAuditData *auditData);
55d9f0492fSopenharmony_ciINIT_LOCAL_API uint32_t AddParamNode(WorkSpace *workSpace, uint8_t type,
56d9f0492fSopenharmony_ci    const char *key, uint32_t keyLen, const char *value, uint32_t valueLen, int mode);
57d9f0492fSopenharmony_ci
58d9f0492fSopenharmony_ciINIT_LOCAL_API uint32_t GetParamMaxLen(uint8_t type);
59d9f0492fSopenharmony_ciINIT_LOCAL_API ParamNode *GetParamNode(uint32_t index, const char *name);
60d9f0492fSopenharmony_ciINIT_LOCAL_API int AddParamEntry(uint32_t index, uint8_t type, const char *name, const char *value);
61d9f0492fSopenharmony_ci
62d9f0492fSopenharmony_ci#ifdef STARTUP_INIT_TEST
63d9f0492fSopenharmony_ciSTATIC_INLINE ParamTrieNode *FindTrieNode_(
64d9f0492fSopenharmony_ci    const WorkSpace *workSpace, const char *key, uint32_t keyLen, uint32_t *matchLabel);
65d9f0492fSopenharmony_ci#endif
66d9f0492fSopenharmony_ci
67d9f0492fSopenharmony_ci#define GetWorkSpaceSize(workSpace)     \
68d9f0492fSopenharmony_ci    ((workSpace == NULL) || (workSpace->area == NULL) ||     \
69d9f0492fSopenharmony_ci        (workSpace->area->spaceSizeOffset == 0) ||    \
70d9f0492fSopenharmony_ci        (workSpace->area->spaceSizeOffset >= workSpace->area->dataSize)) ? NULL : \
71d9f0492fSopenharmony_ci        (WorkSpaceSize*)(workSpace->area->data + workSpace->area->spaceSizeOffset)
72d9f0492fSopenharmony_ci
73d9f0492fSopenharmony_ci#ifdef __cplusplus
74d9f0492fSopenharmony_ci#if __cplusplus
75d9f0492fSopenharmony_ci}
76d9f0492fSopenharmony_ci#endif
77d9f0492fSopenharmony_ci#endif
78d9f0492fSopenharmony_ci#endif  // BASE_STARTUP_PARAM_TRIE_H