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