support aliyun sdk on TencentOS tiny

sample: examples\aliyun_iotkit_csdk_mqtt
project: board\TencentOS_tiny_EVB_MX_Plus\KEIL\aliyun_iotkit_csdk_mqtt
This commit is contained in:
dcxajichu
2019-10-31 16:36:28 +08:00
parent 30ea36a7ab
commit 8c24d921b0
692 changed files with 199829 additions and 0 deletions

View File

@@ -0,0 +1,354 @@
/*
* Copyright (C) 2015-2018 Alibaba Group Holding Limited
*/
#include <stdlib.h>
#include <string.h>
#include <stdarg.h>
#include "infra_types.h"
#include "infra_defs.h"
#include "wrappers_defs.h"
#define HAL_SEM_MAX_COUNT (10)
#define HAL_SEM_INIT_COUNT (0)
#define DEFAULT_THREAD_NAME "linkkit_task"
#define DEFAULT_THREAD_SIZE (256)
#define TASK_STACK_ALIGN_SIZE (4)
/**
* @brief Deallocate memory block
*
* @param[in] ptr @n Pointer to a memory block previously allocated with platform_malloc.
* @return None.
* @see None.
* @note None.
*/
void HAL_Free(void *ptr)
{
vPortFree(ptr);
}
/**
* @brief Allocates a block of size bytes of memory, returning a pointer to the beginning of the block.
*
* @param [in] size @n specify block size in bytes.
* @return A pointer to the beginning of the block.
* @see None.
* @note Block value is indeterminate.
*/
void *HAL_Malloc(uint32_t size)
{
return pvPortMalloc(size);
}
/**
* @brief Create a mutex.
*
* @retval NULL : Initialize mutex failed.
* @retval NOT_NULL : The mutex handle.
* @see None.
* @note None.
*/
void *HAL_MutexCreate(void)
{
QueueHandle_t sem;
sem = xSemaphoreCreateMutex();
if (0 == sem) {
return NULL;
}
return sem;
}
/**
* @brief Destroy the specified mutex object, it will release related resource.
*
* @param [in] mutex @n The specified mutex.
* @return None.
* @see None.
* @note None.
*/
void HAL_MutexDestroy(void *mutex)
{
QueueHandle_t sem;
if (mutex == NULL) {
return;
}
sem = (QueueHandle_t)mutex;
vSemaphoreDelete(sem);
}
/**
* @brief Waits until the specified mutex is in the signaled state.
*
* @param [in] mutex @n the specified mutex.
* @return None.
* @see None.
* @note None.
*/
void HAL_MutexLock(void *mutex)
{
BaseType_t ret;
QueueHandle_t sem;
if (mutex == NULL) {
return;
}
sem = (QueueHandle_t)mutex;
ret = xSemaphoreTake(sem, 0xffffffff);
while (pdPASS != ret) {
ret = xSemaphoreTake(sem, 0xffffffff);
}
}
/**
* @brief Releases ownership of the specified mutex object..
*
* @param [in] mutex @n the specified mutex.
* @return None.
* @see None.
* @note None.
*/
void HAL_MutexUnlock(void *mutex)
{
QueueHandle_t sem;
if (mutex == NULL) {
return;
}
sem = (QueueHandle_t)mutex;
(void)xSemaphoreGive(sem);
}
/**
* @brief Writes formatted data to stream.
*
* @param [in] fmt: @n String that contains the text to be written, it can optionally contain embedded format specifiers
that specifies how subsequent arguments are converted for output.
* @param [in] ...: @n the variable argument list, for formatted and inserted in the resulting string replacing their respective specifiers.
* @return None.
* @see None.
* @note None.
*/
void HAL_Printf(const char *fmt, ...)
{
va_list args;
va_start(args, fmt);
vprintf(fmt, args);
va_end(args);
fflush(stdout);
}
/**
* @brief create a semaphore
*
* @return semaphore handle.
* @see None.
* @note The recommended value of maximum count of the semaphore is 255.
*/
void *HAL_SemaphoreCreate(void)
{
QueueHandle_t sem = 0;
sem = xSemaphoreCreateCounting(HAL_SEM_MAX_COUNT, HAL_SEM_INIT_COUNT);
if (0 == sem) {
return NULL;
}
return sem;
}
/**
* @brief destory a semaphore
*
* @param[in] sem @n the specified sem.
* @return None.
* @see None.
* @note None.
*/
void HAL_SemaphoreDestroy(void *sem)
{
QueueHandle_t queue;
if (sem == NULL) {
return;
}
queue = (QueueHandle_t)sem;
vSemaphoreDelete(queue);
}
/**
* @brief signal thread wait on a semaphore
*
* @param[in] sem @n the specified semaphore.
* @return None.
* @see None.
* @note None.
*/
void HAL_SemaphorePost(void *sem)
{
QueueHandle_t queue;
if (sem == NULL) {
return;
}
queue = (QueueHandle_t)sem;
(void)xSemaphoreGive(queue);
}
/**
* @brief wait on a semaphore
*
* @param[in] sem @n the specified semaphore.
* @param[in] timeout_ms @n timeout interval in millisecond.
If timeout_ms is PLATFORM_WAIT_INFINITE, the function will return only when the semaphore is signaled.
* @return
@verbatim
= 0: The state of the specified object is signaled.
= -1: The time-out interval elapsed, and the object's state is nonsignaled.
@endverbatim
* @see None.
* @note None.
*/
int HAL_SemaphoreWait(void *sem, uint32_t timeout_ms)
{
BaseType_t ret = 0;
QueueHandle_t queue;
if (sem == NULL) {
return -1;
}
queue = (QueueHandle_t)sem;
ret = xSemaphoreTake(queue, timeout_ms);
if (pdPASS != ret) {
return -1;
}
return 0;
}
/**
* @brief Sleep thread itself.
*
* @param [in] ms @n the time interval for which execution is to be suspended, in milliseconds.
* @return None.
* @see None.
* @note None.
*/
void HAL_SleepMs(uint32_t ms)
{
osDelay(ms);
}
/**
* @brief Writes formatted data to string.
*
* @param [out] str: @n String that holds written text.
* @param [in] len: @n Maximum length of character will be written
* @param [in] fmt: @n Format that contains the text to be written, it can optionally contain embedded format specifiers
that specifies how subsequent arguments are converted for output.
* @param [in] ...: @n the variable argument list, for formatted and inserted in the resulting string replacing their respective specifiers.
* @return bytes of character successfully written into string.
* @see None.
* @note None.
*/
int HAL_Snprintf(char *str, const int len, const char *fmt, ...)
{
va_list args;
int rc;
va_start(args, fmt);
rc = vsnprintf(str, len, fmt, args);
va_end(args);
return rc;
}
/**
* @brief create a thread
*
* @param[out] thread_handle @n The new thread handle, memory allocated before thread created and return it, free it after thread joined or exit.
* @param[in] start_routine @n A pointer to the application-defined function to be executed by the thread.
This pointer represents the starting address of the thread.
* @param[in] arg @n A pointer to a variable to be passed to the start_routine.
* @param[in] hal_os_thread_param @n A pointer to stack params.
* @param[out] stack_used @n if platform used stack buffer, set stack_used to 1, otherwise set it to 0.
* @return
@verbatim
= 0: on success.
= -1: error occur.
@endverbatim
* @see None.
* @note None.
*/
int HAL_ThreadCreate(
void **thread_handle,
void *(*work_routine)(void *),
void *arg,
hal_os_thread_param_t *hal_os_thread_param,
int *stack_used)
{
char *name;
size_t stacksize;
osThreadDef_t thread_def;
osThreadId handle;
if (thread_handle == NULL) {
return -1;
}
if (work_routine == NULL) {
return -1;
}
if (hal_os_thread_param == NULL) {
return -1;
}
if (stack_used == NULL) {
return -1;
}
if (stack_used != NULL) {
*stack_used = 0;
}
if (!hal_os_thread_param->name) {
name = DEFAULT_THREAD_NAME;
} else {
name = hal_os_thread_param->name;
}
if (hal_os_thread_param->stack_size == 0) {
stacksize = DEFAULT_THREAD_SIZE;
} else {
stacksize = hal_os_thread_param->stack_size;
}
thread_def.name = name;
thread_def.pthread = (os_pthread)work_routine;
thread_def.tpriority = (osPriority)hal_os_thread_param->priority;
thread_def.instances = 0;
thread_def.stacksize = (stacksize + TASK_STACK_ALIGN_SIZE - 1) / TASK_STACK_ALIGN_SIZE;
handle = osThreadCreate(&thread_def, arg);
if (NULL == handle) {
return -1;
}
*thread_handle = (void *)handle;
return 0;
}
/**
* @brief Retrieves the number of milliseconds that have elapsed since the system was boot.
*
* @return the number of milliseconds.
* @see None.
* @note None.
*/
uint64_t HAL_UptimeMs(void)
{
return (uint64_t)xTaskGetTickCount();
}