/* * osal_freeRTOS.h * * Created on: Feb 2, 2013 * Author: hathach */ /* * Software License Agreement (BSD License) * Copyright (c) 2012, hathach (tinyusb.org) * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * 3. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY * OF SUCH DAMAGE. * * This file is part of the tiny usb stack. */ /** \file * \brief TBD * * \note TBD */ /** \ingroup TBD * \defgroup TBD * \brief TBD * * @{ */ #ifndef _TUSB_OSAL_FREERTOS_H_ #define _TUSB_OSAL_FREERTOS_H_ #include "osal_common.h" //------------- FreeRTOS Headers -------------// #include "FreeRTOS.h" #include "semphr.h" #include "queue.h" //#include "task.h" #ifdef __cplusplus extern "C" { #endif //--------------------------------------------------------------------+ // TICK API //--------------------------------------------------------------------+ #define osal_tick_get xTaskGetTickCount //--------------------------------------------------------------------+ // TASK API //--------------------------------------------------------------------+ typedef struct { signed portCHAR const * name; pdTASK_CODE code; unsigned portSHORT stack_depth; unsigned portBASE_TYPE prio; } osal_task_t; #define OSAL_TASK_DEF(task_name, task_code, task_stack_depth, task_prio) \ osal_task_t task_name = {\ .name = #task_name , \ .code = task_code , \ .stack_depth = task_stack_depth , \ .prio = task_prio \ }; #define OSAL_TASK_FUNCTION(task_name) \ void task_name(void *p_task_para) #define OSAL_TASK_LOOP_BEGIN \ while(1) { #define OSAL_TASK_LOOP_END \ } //------------- Sub Task -------------// #define OSAL_SUBTASK_BEGIN // TODO refractor move #define OSAL_SUBTASK_END //------------- Task Assert -------------// #define TASK_RESTART // TODO FreeRTOS TASK_ASSERT need to omit do while to get continue statement works. #define _TASK_ASSERT_ERROR_HANDLER(error, func_call) \ func_call; TASK_RESTART; #define TASK_ASSERT(condition) #define TASK_ASSERT_STATUS(sts) #define TASK_ASSERT_WITH_HANDLER(condition, func_call) \ ASSERT_DEFINE_WITH_HANDLER(_TASK_ASSERT_ERROR_HANDLER, func_call, ,\ condition, TUSB_ERROR_OSAL_TASK_FAILED, "%s", "evaluated to false") //------------- Sub Task Assert -------------// #define SUBTASK_ASSERT_STATUS TASK_ASSERT_STATUS #define SUBTASK_ASSERT_STATUS_WITH_HANDLER TASK_ASSERT_STATUS_WITH_HANDLER #define SUBTASK_ASSERT TASK_ASSERT #define SUBTASK_ASSERT_WITH_HANDLER TASK_ASSERT_WITH_HANDLER //--------------------------------------------------------------------+ // Semaphore API //--------------------------------------------------------------------+ #define OSAL_SEM_DEF(name) typedef xSemaphoreHandle osal_semaphore_handle_t; // create FreeRTOS binary semaphore with zero as init value TODO: omit semaphore take from vSemaphoreCreateBinary API, should double checks this #define osal_semaphore_create(x) \ xQueueGenericCreate( ( unsigned portBASE_TYPE ) 1, semSEMAPHORE_QUEUE_ITEM_LENGTH, queueQUEUE_TYPE_BINARY_SEMAPHORE ) static inline tusb_error_t osal_semaphore_post(osal_semaphore_handle_t const sem_hdl) ATTR_ALWAYS_INLINE; static inline tusb_error_t osal_semaphore_post(osal_semaphore_handle_t const sem_hdl) { portBASE_TYPE taskWaken; return (xSemaphoreGiveFromISR(sem_hdl, &taskWaken) == pdTRUE) ? TUSB_ERROR_NONE : TUSB_ERROR_OSAL_SEMAPHORE_FAILED; } static inline void osal_semaphore_wait(osal_semaphore_handle_t const sem_hdl, uint32_t msec, tusb_error_t *p_error) ATTR_ALWAYS_INLINE; static inline void osal_semaphore_wait(osal_semaphore_handle_t const sem_hdl, uint32_t msec, tusb_error_t *p_error) { (*p_error) = ( xSemaphoreTake(sem_hdl, osal_tick_from_msec(msec)) == pdPASS ) ? TUSB_ERROR_NONE : TUSB_ERROR_OSAL_TIMEOUT; } //--------------------------------------------------------------------+ // QUEUE API //--------------------------------------------------------------------+ typedef struct{ uint8_t const depth ; ///< buffer size } osal_queue_t; typedef xQueueHandle osal_queue_handle_t; #define OSAL_QUEUE_DEF(name, queue_depth, type)\ osal_queue_t name = {\ .depth = queue_depth\ } #define osal_queue_create(p_queue) \ xQueueCreate((p_queue)->depth, sizeof(uint32_t)) static inline void osal_queue_receive (osal_queue_handle_t const queue_hdl, uint32_t *p_data, uint32_t msec, tusb_error_t *p_error) ATTR_ALWAYS_INLINE; static inline void osal_queue_receive (osal_queue_handle_t const queue_hdl, uint32_t *p_data, uint32_t msec, tusb_error_t *p_error) { (*p_error) = ( xQueueReceive(queue_hdl, p_data, osal_tick_from_msec(msec)) == pdPASS ) ? TUSB_ERROR_NONE : TUSB_ERROR_OSAL_TIMEOUT; } static inline tusb_error_t osal_queue_send(osal_queue_handle_t const queue_hdl, const void * data) ATTR_ALWAYS_INLINE; static inline tusb_error_t osal_queue_send(osal_queue_handle_t const queue_hdl, const void * data) { portBASE_TYPE taskWaken; return ( xQueueSendFromISR(queue_hdl, data, &taskWaken) == pdTRUE ) ? TUSB_ERROR_NONE : TUSB_ERROR_OSAL_QUEUE_FAILED; } #ifdef __cplusplus } #endif #endif /* _TUSB_OSAL_FREERTOS_H_ */ /** @} */