 357888a5e5
			
		
	
	357888a5e5
	
	
	
		
			
			implementing freeRTOS integration change get_period_frame_list from using lst_idx to hostid (fix bug) adding polling interval supported for interrupt: 1ms, 2ms, 4ms, 8ms - add interval_ms to get_period_head function - add bInterval to qhd_init - add support for sub-frame (less than 8 micro frames) interval - add bunch of test for interrupt different intervals
		
			
				
	
	
		
			183 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			183 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * 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
 | |
| //--------------------------------------------------------------------+
 | |
| #define OSAL_TASK_DECLARE(task_name) \
 | |
|   void task_name(void *p_task_para)
 | |
| 
 | |
| 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_LOOP_BEGIN \
 | |
|   while(1) {
 | |
| 
 | |
| #define OSAL_TASK_LOOP_END \
 | |
|   }
 | |
| 
 | |
| //------------- Sub Task -------------//
 | |
| #define OSAL_SUBTASK_BEGIN
 | |
| #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 -------------// TODO replace directly by TASK ASSERT
 | |
| #define SUBTASK_ASSERT_STATUS(...)               TASK_ASSERT_STATUS(__VA_ARGS__)
 | |
| #define SUBTASK_ASSERT_STATUS_WITH_HANDLER(...)  TASK_ASSERT_STATUS_WITH_HANDLER(__VA_ARGS__)
 | |
| #define SUBTASK_ASSERT(...)                      TASK_ASSERT(__VA_ARGS__)
 | |
| #define SUBTASK_ASSERT_WITH_HANDLER(...)         TASK_ASSERT_WITH_HANDLER(__VA_ARGS__)
 | |
| 
 | |
| //--------------------------------------------------------------------+
 | |
| // 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_ */
 | |
| 
 | |
| /** @} */
 |