123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233 |
- /*
- * Copyright (c) 2017 Actions Semi Co., Ltd.
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * Author: wh<wanghui@actions-semi.com>
- *
- * Change log:
- * 2017/7/7: Created by wh.
- */
- #include "os_common_api.h"
- #include "string.h"
- #include <zephyr.h>
- #include <sys/atomic.h>
- #define MAX_THREAD_TERMINAL_NUM 3
- struct thread_terminal_info_t{
- os_thread *wait_terminal_thread;
- os_sem terminal_sem;
- };
- static struct thread_terminal_info_t thread_terminal_info[MAX_THREAD_TERMINAL_NUM] = {0};
- /**thread function */
- int os_thread_create(char *stack, size_t stack_size,
- void (*entry)(void *, void *, void*),
- void *p1, void *p2, void *p3,
- int prio, u32_t options, int delay) {
- k_tid_t tid = NULL;
- os_thread *thread = NULL;
- thread = (os_thread *)stack;
- tid = k_thread_create(thread, (os_thread_stack_t *)&stack[sizeof(os_thread)],
- stack_size - sizeof(os_thread),
- entry,
- p1, p2, p3,
- prio,
- options,
- SYS_TIMEOUT_MS(delay));
- return (int)tid;
- }
- int os_thread_prepare_terminal(int tid)
- {
- int ret = 0;
- struct thread_terminal_info_t *terminal_info = NULL;
- os_sched_lock();
- for (int i = 0; i < MAX_THREAD_TERMINAL_NUM; i++){
- if(!thread_terminal_info[i].wait_terminal_thread) {
- terminal_info = &thread_terminal_info[i];
- break;
- }
- }
- if (!terminal_info) {
- SYS_LOG_ERR("%d busy\n", tid);
- ret = -EBUSY;
- goto exit;
- }
- terminal_info->wait_terminal_thread = (os_thread *)tid;
- os_sem_init(&terminal_info->terminal_sem, 0, 1);
- SYS_LOG_INF(" 0x%x ok\n",tid);
- exit:
- os_sched_unlock();
- return ret;
- }
- int os_thread_wait_terminal(int tid)
- {
- int ret = 0;
- struct thread_terminal_info_t *terminal_info = NULL;
- os_sched_lock();
- for (int i = 0; i < MAX_THREAD_TERMINAL_NUM; i++){
- if((uintptr_t)thread_terminal_info[i].wait_terminal_thread == tid) {
- terminal_info = &thread_terminal_info[i];
- }
- }
- os_sched_unlock();
- if (!terminal_info) {
- SYS_LOG_ERR("terminal tid %d not found\n",tid);
- ret = -EBUSY;
- goto exit;
- }
- if (k_thread_join(terminal_info->wait_terminal_thread, SYS_TIMEOUT_MS(5000))) {
- SYS_LOG_ERR("timeout \n");
- ret = -EBUSY;
- goto exit;
- }
- os_sched_lock();
- terminal_info->wait_terminal_thread = NULL;
- os_sched_unlock();
- SYS_LOG_INF(" 0x%x ok\n",tid);
- exit:
- return ret;
- }
- const char *os_thread_get_name_by_prio(int prio)
- {
- struct k_thread *thread_list = (struct k_thread *)(_kernel.threads);
- unsigned int key = irq_lock();
- while (thread_list != NULL) {
- int thread_prio = k_thread_priority_get(thread_list);
- if (prio == thread_prio) {
- break;
- }
- thread_list = (struct k_thread *)thread_list->next_thread;
- }
- irq_unlock(key);
- if (thread_list) {
- return k_thread_name_get(thread_list);
- }
- return "NULL";
- }
- static bool low_latency_mode = true;
- int system_check_low_latencey_mode(void)
- {
- #ifdef CONFIG_OS_LOW_LATENCY_MODE
- return low_latency_mode ? 1 : 0;
- #else
- return 0;
- #endif
- }
- void system_set_low_latencey_mode(bool low_latencey)
- {
- low_latency_mode = low_latencey;
- }
- s32_t os_sleep(int timeout)
- {
- return k_sleep(SYS_TIMEOUT_MS(timeout));
- }
- int os_sem_take(os_sem *sem, s32_t timeout)
- {
- return k_sem_take(sem, SYS_TIMEOUT_MS(timeout));
- }
- int os_mutex_lock(os_mutex * mutex, s32_t timeout)
- {
- return k_mutex_lock(mutex, SYS_TIMEOUT_MS(timeout));
- }
- int os_delayed_work_submit(os_delayed_work *work, s32_t delay)
- {
- return k_delayed_work_submit(work, SYS_TIMEOUT_MS(delay));
- }
- int os_delayed_work_submit_to_queue(os_work_q *work_q, os_delayed_work *work, s32_t delay)
- {
- return k_delayed_work_submit_to_queue(work_q, work, SYS_TIMEOUT_MS(delay));
- }
- void *os_fifo_get(os_fifo *fifo, int32_t timeout)
- {
- return k_fifo_get(fifo, SYS_TIMEOUT_MS(timeout));
- }
- int os_msgq_put(os_msgq *msgq, const void *data, int32_t timeout)
- {
- return k_msgq_put(msgq, data, SYS_TIMEOUT_MS(timeout));
- }
- int os_msgq_get(os_msgq *msgq, void *data, int32_t timeout)
- {
- return k_msgq_get(msgq, data, SYS_TIMEOUT_MS(timeout));
- }
- bool os_is_in_isr(void)
- {
- return k_is_in_isr();
- }
- void os_printk(const char *fmt, ...)
- {
- va_list ap;
- va_start(ap, fmt);
- if (IS_ENABLED(CONFIG_LOG_PRINTK)) {
- log_printk(fmt, ap);
- } else {
- vprintk(fmt, ap);
- }
- va_end(ap);
- }
- #ifndef CONFIG_ACTLOG_USE_NANOLOG
- void actlog_printk_nano(uint32_t pack_data, const char *fmt, ...)
- {
- va_list ap;
- va_start(ap, fmt);
- if (IS_ENABLED(CONFIG_LOG_PRINTK)) {
- log_printk(fmt, ap);
- } else {
- vprintk(fmt, ap);
- }
- va_end(ap);
- }
- #endif
|