13d0407baSopenharmony_ci/*
23d0407baSopenharmony_ci * Copyright (c) 2022 FuZhou Lockzhiner Electronic Co., Ltd. All rights reserved.
33d0407baSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
43d0407baSopenharmony_ci * you may not use this file except in compliance with the License.
53d0407baSopenharmony_ci * You may obtain a copy of the License at
63d0407baSopenharmony_ci *
73d0407baSopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
83d0407baSopenharmony_ci *
93d0407baSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
103d0407baSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
113d0407baSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
123d0407baSopenharmony_ci * See the License for the specific language governing permissions and
133d0407baSopenharmony_ci * limitations under the License.
143d0407baSopenharmony_ci */
153d0407baSopenharmony_ci
163d0407baSopenharmony_ci/**
173d0407baSopenharmony_ci * @addtogroup Lockzhiner
183d0407baSopenharmony_ci *
193d0407baSopenharmony_ci * @file thread.h
203d0407baSopenharmony_ci */
213d0407baSopenharmony_ci
223d0407baSopenharmony_ci#ifndef LZ_HARDWARE_THREAD_H
233d0407baSopenharmony_ci#define LZ_HARDWARE_THREAD_H
243d0407baSopenharmony_ci
253d0407baSopenharmony_ci#define LZ_HARDWARE_THREAD_STACK_SIZE              0x1000
263d0407baSopenharmony_ci#define LZ_HARDWARE_THREAD_PRIO                    6
273d0407baSopenharmony_ci
283d0407baSopenharmony_citypedef void (*ThreadFunc)(void *arg);
293d0407baSopenharmony_ci
303d0407baSopenharmony_ci/**
313d0407baSopenharmony_ci * @brief Create a thread.
323d0407baSopenharmony_ci *
333d0407baSopenharmony_ci *
343d0407baSopenharmony_ci *
353d0407baSopenharmony_ci * @param threadID Indicates the thread ID.
363d0407baSopenharmony_ci * @param func Indicates the thread callback function.
373d0407baSopenharmony_ci * @param arg Indicates input parameter of callback function.
383d0407baSopenharmony_ci * @param owner Indicates the owner process who create thread.
393d0407baSopenharmony_ci * @return Returns {@link LZ_HARDWARE_SUCCESS} if the thread is created successfully;
403d0407baSopenharmony_ci * returns {@link LZ_HARDWARE_FAILURE} otherwise. For details about other return values.
413d0407baSopenharmony_ci */
423d0407baSopenharmony_ci
433d0407baSopenharmony_ciint CreateThread(unsigned int *threadID, ThreadFunc func, void *arg, const char *owner);
443d0407baSopenharmony_ci
453d0407baSopenharmony_ci/**
463d0407baSopenharmony_ci * @brief Destroy a thread.
473d0407baSopenharmony_ci *
483d0407baSopenharmony_ci *
493d0407baSopenharmony_ci *
503d0407baSopenharmony_ci * @param threadID Indicates the thread ID.
513d0407baSopenharmony_ci * @return Returns {@link LZ_HARDWARE_SUCCESS} if the thread is destoried successfully;
523d0407baSopenharmony_ci * returns {@link LZ_HARDWARE_FAILURE} otherwise. For details about other return values, see the chip description.
533d0407baSopenharmony_ci */
543d0407baSopenharmony_ci
553d0407baSopenharmony_ciint DestroyThread(unsigned int threadID);
563d0407baSopenharmony_ci
573d0407baSopenharmony_ci#endif
583d0407baSopenharmony_ci
59