1 /* 2 * Copyright (c) 2018 Intel Corporation 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 #include <stdio.h> 8 #include <string.h> 9 #include <zephyr/kernel.h> 10 #include <cmsis_os2.h> 11 12 extern uint32_t sys_clock_tick_get_32(void); 13 14 /** 15 * @brief Get RTOS Kernel Information. 16 */ osKernelGetInfo(osVersion_t * version,char * id_buf,uint32_t id_size)17osStatus_t osKernelGetInfo(osVersion_t *version, char *id_buf, uint32_t id_size) 18 { 19 uint32_t ver = sys_kernel_version_get(); 20 21 if (version != NULL) { 22 version->api = ver; 23 version->kernel = ver; 24 } 25 26 if ((id_buf != NULL) && (version != NULL)) { 27 snprintf(id_buf, id_size, 28 "Zephyr V%2"PRIu32".%2"PRIu32".%2"PRIu32, 29 SYS_KERNEL_VER_MAJOR(version->kernel), 30 SYS_KERNEL_VER_MINOR(version->kernel), 31 SYS_KERNEL_VER_PATCHLEVEL(version->kernel)); 32 } 33 34 return osOK; 35 } 36 37 /** 38 * @brief Lock the RTOS Kernel scheduler. 39 */ osKernelLock(void)40int32_t osKernelLock(void) 41 { 42 int temp = arch_current_thread()->base.sched_locked; 43 44 if (k_is_in_isr()) { 45 return osErrorISR; 46 } 47 48 k_sched_lock(); 49 50 return temp; 51 } 52 53 /** 54 * @brief Unlock the RTOS Kernel scheduler. 55 */ osKernelUnlock(void)56int32_t osKernelUnlock(void) 57 { 58 int temp = arch_current_thread()->base.sched_locked; 59 60 if (k_is_in_isr()) { 61 return osErrorISR; 62 } 63 64 k_sched_unlock(); 65 66 return temp; 67 } 68 69 /** 70 * @brief Restore the RTOS Kernel scheduler lock state. 71 */ osKernelRestoreLock(int32_t lock)72int32_t osKernelRestoreLock(int32_t lock) 73 { 74 arch_current_thread()->base.sched_locked = lock; 75 76 if (k_is_in_isr()) { 77 return osErrorISR; 78 } 79 80 if (lock < 0) { 81 return 1; /* locked */ 82 } else { 83 return 0; /* not locked */ 84 } 85 } 86 87 /** 88 * @brief Get the RTOS kernel tick count. 89 */ osKernelGetTickCount(void)90uint32_t osKernelGetTickCount(void) 91 { 92 return sys_clock_tick_get_32(); 93 } 94 95 /** 96 * @brief Get the RTOS kernel tick frequency. 97 */ osKernelGetTickFreq(void)98uint32_t osKernelGetTickFreq(void) 99 { 100 return CONFIG_SYS_CLOCK_TICKS_PER_SEC; 101 } 102 103 /** 104 * @brief Get the RTOS kernel system timer count. 105 */ osKernelGetSysTimerCount(void)106uint32_t osKernelGetSysTimerCount(void) 107 { 108 return k_cycle_get_32(); 109 } 110 111 /** 112 * @brief Get the RTOS kernel system timer frequency. 113 */ osKernelGetSysTimerFreq(void)114uint32_t osKernelGetSysTimerFreq(void) 115 { 116 return sys_clock_hw_cycles_per_sec(); 117 } 118 119 /** 120 * @brief Wait for Timeout (Time Delay). 121 */ osDelay(uint32_t ticks)122osStatus_t osDelay(uint32_t ticks) 123 { 124 if (k_is_in_isr()) { 125 return osErrorISR; 126 } 127 128 k_sleep(K_TICKS(ticks)); 129 130 return osOK; 131 } 132 133 /** 134 * @brief Wait until specified time. 135 */ osDelayUntil(uint32_t ticks)136osStatus_t osDelayUntil(uint32_t ticks) 137 { 138 uint32_t ticks_elapsed; 139 140 if (k_is_in_isr()) { 141 return osErrorISR; 142 } 143 144 ticks_elapsed = osKernelGetTickCount(); 145 k_sleep(K_TICKS(ticks - ticks_elapsed)); 146 147 return osOK; 148 } 149