fix issue with osal_none queue def
This commit is contained in:
		| @@ -103,7 +103,7 @@ | |||||||
| 	</linkedResources> | 	</linkedResources> | ||||||
| 	<filteredResources> | 	<filteredResources> | ||||||
| 		<filter> | 		<filter> | ||||||
| 			<id>1368599411514</id> | 			<id>1368600635222</id> | ||||||
| 			<name></name> | 			<name></name> | ||||||
| 			<type>26</type> | 			<type>26</type> | ||||||
| 			<matcher> | 			<matcher> | ||||||
|   | |||||||
| @@ -216,7 +216,7 @@ typedef osal_queue_t * osal_queue_handle_t; | |||||||
|  |  | ||||||
| // use to declare a queue, within the scope of tinyusb, should only use primitive type only | // use to declare a queue, within the scope of tinyusb, should only use primitive type only | ||||||
| #define OSAL_QUEUE_DEF(name, queue_depth, type)\ | #define OSAL_QUEUE_DEF(name, queue_depth, type)\ | ||||||
|   uint32_t name##_buffer[queue_depth];\ |   type name##_buffer[queue_depth];\ | ||||||
|   osal_queue_t name = {\ |   osal_queue_t name = {\ | ||||||
|       .buffer    = name##_buffer,\ |       .buffer    = name##_buffer,\ | ||||||
|       .depth     = queue_depth,\ |       .depth     = queue_depth,\ | ||||||
| @@ -230,6 +230,7 @@ static inline osal_queue_handle_t osal_queue_create(osal_queue_t * const p_queue | |||||||
|   return (osal_queue_handle_t) p_queue; |   return (osal_queue_handle_t) p_queue; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // TODO move to osal_none.c | ||||||
| // when queue is full, it will overwrite the oldest data in the queue | // when queue is full, it will overwrite the oldest data in the queue | ||||||
| static inline tusb_error_t osal_queue_send(osal_queue_handle_t const queue_hdl, void const * data) ATTR_ALWAYS_INLINE; | static inline tusb_error_t osal_queue_send(osal_queue_handle_t const queue_hdl, void const * data) ATTR_ALWAYS_INLINE; | ||||||
| static inline tusb_error_t osal_queue_send(osal_queue_handle_t const queue_hdl, void const * data) | static inline tusb_error_t osal_queue_send(osal_queue_handle_t const queue_hdl, void const * data) | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								vendor/cmsis_rtos_rtx/INC/cmsis_os.h
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/cmsis_rtos_rtx/INC/cmsis_os.h
									
									
									
									
										vendored
									
									
								
							| @@ -147,7 +147,7 @@ used throughout the whole project. | |||||||
| #define osFeature_MessageQ     1       ///< Message Queues:  1=available, 0=not available | #define osFeature_MessageQ     1       ///< Message Queues:  1=available, 0=not available | ||||||
| #define osFeature_Signals      16      ///< maximum number of Signal Flags available per thread | #define osFeature_Signals      16      ///< maximum number of Signal Flags available per thread | ||||||
| #define osFeature_Semaphore    65535   ///< maximum count for \ref osSemaphoreCreate function | #define osFeature_Semaphore    65535   ///< maximum count for \ref osSemaphoreCreate function | ||||||
| #define osFeature_Wait         0       ///< osWait function: 1=available, 0=not available | #define osFeature_Wait         1       ///< osWait function: 1=available, 0=not available | ||||||
| #define osFeature_SysTick      1       ///< osKernelSysTick functions: 1=available, 0=not available | #define osFeature_SysTick      1       ///< osKernelSysTick functions: 1=available, 0=not available | ||||||
|  |  | ||||||
| #if defined (__CC_ARM) | #if defined (__CC_ARM) | ||||||
|   | |||||||
							
								
								
									
										276
									
								
								vendor/cmsis_rtos_rtx/RTX_Conf_CM.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										276
									
								
								vendor/cmsis_rtos_rtx/RTX_Conf_CM.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,276 @@ | |||||||
|  | /*---------------------------------------------------------------------------- | ||||||
|  |  *      RL-ARM - RTX | ||||||
|  |  *---------------------------------------------------------------------------- | ||||||
|  |  *      Name:    RTX_Conf_CM.C | ||||||
|  |  *      Purpose: Configuration of CMSIS RTX Kernel for Cortex-M | ||||||
|  |  *      Rev.:    V4.70 | ||||||
|  |  *---------------------------------------------------------------------------- | ||||||
|  |  * | ||||||
|  |  * Copyright (c) 1999-2009 KEIL, 2009-2013 ARM Germany GmbH | ||||||
|  |  * All rights reserved. | ||||||
|  |  * Redistribution and use in source and binary forms, with or without | ||||||
|  |  * modification, are permitted provided that the following conditions are met: | ||||||
|  |  *  - Redistributions of source code must retain the above copyright | ||||||
|  |  *    notice, this list of conditions and the following disclaimer. | ||||||
|  |  *  - 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. | ||||||
|  |  *  - Neither the name of ARM  nor the names of its contributors may be used  | ||||||
|  |  *    to endorse or promote products derived from this software without  | ||||||
|  |  *    specific prior written permission. | ||||||
|  |  * | ||||||
|  |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "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 COPYRIGHT HOLDERS AND CONTRIBUTORS 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. | ||||||
|  |  *---------------------------------------------------------------------------*/ | ||||||
|  |  | ||||||
|  | #include "cmsis_os.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /*---------------------------------------------------------------------------- | ||||||
|  |  *      RTX User configuration part BEGIN | ||||||
|  |  *---------------------------------------------------------------------------*/ | ||||||
|  |  | ||||||
|  | //-------- <<< Use Configuration Wizard in Context Menu >>> ----------------- | ||||||
|  | // | ||||||
|  | // <h>Thread Configuration | ||||||
|  | // ======================= | ||||||
|  | // | ||||||
|  | //   <o>Number of concurrent running threads <0-250> | ||||||
|  | //   <i> Defines max. number of threads that will run at the same time. | ||||||
|  | //   <i> Default: 6 | ||||||
|  | #ifndef OS_TASKCNT | ||||||
|  |  #define OS_TASKCNT     7 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | //   <o>Default Thread stack size [bytes] <64-4096:8><#/4> | ||||||
|  | //   <i> Defines default stack size for threads with osThreadDef stacksz = 0 | ||||||
|  | //   <i> Default: 200 | ||||||
|  | #ifndef OS_STKSIZE | ||||||
|  |  #define OS_STKSIZE     50 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | //   <o>Main Thread stack size [bytes] <64-4096:8><#/4> | ||||||
|  | //   <i> Defines stack size for main thread. | ||||||
|  | //   <i> Default: 200 | ||||||
|  | #ifndef OS_MAINSTKSIZE | ||||||
|  |  #define OS_MAINSTKSIZE 50 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | //   <o>Number of threads with user-provided stack size <0-250> | ||||||
|  | //   <i> Defines the number of threads with user-provided stack size. | ||||||
|  | //   <i> Default: 0 | ||||||
|  | #ifndef OS_PRIVCNT | ||||||
|  |  #define OS_PRIVCNT     0 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | //   <o>Total stack size [bytes] for threads with user-provided stack size <0-4096:8><#/4> | ||||||
|  | //   <i> Defines the combined stack size for threads with user-provided stack size. | ||||||
|  | //   <i> Default: 0 | ||||||
|  | #ifndef OS_PRIVSTKSIZE | ||||||
|  |  #define OS_PRIVSTKSIZE 0 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | // <q>Check for stack overflow | ||||||
|  | // <i> Includes the stack checking code for stack overflow. | ||||||
|  | // <i> Note that additional code reduces the Kernel performance. | ||||||
|  | #ifndef OS_STKCHECK | ||||||
|  |  #define OS_STKCHECK    1 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | // <o>Processor mode for thread execution  | ||||||
|  | //   <0=> Unprivileged mode  | ||||||
|  | //   <1=> Privileged mode | ||||||
|  | // <i> Default: Privileged mode | ||||||
|  | #ifndef OS_RUNPRIV | ||||||
|  |  #define OS_RUNPRIV     0 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | // </h> | ||||||
|  |  | ||||||
|  | // <h>RTX Kernel Timer Tick Configuration | ||||||
|  | // ====================================== | ||||||
|  | // <q> Use Cortex-M SysTick timer as RTX Kernel Timer | ||||||
|  | // <i> Use the Cortex-M SysTick timer as a time-base for RTX. | ||||||
|  | #ifndef OS_SYSTICK | ||||||
|  |  #define OS_SYSTICK     1 | ||||||
|  | #endif | ||||||
|  | // | ||||||
|  | //   <o>Timer clock value [Hz] <1-1000000000> | ||||||
|  | //   <i> Defines the timer clock value. | ||||||
|  | //   <i> Default: 12000000  (12MHz) | ||||||
|  | #ifndef OS_CLOCK | ||||||
|  |  #define OS_CLOCK       100000000 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | //   <o>Timer tick value [us] <1-1000000> | ||||||
|  | //   <i> Defines the timer tick value. | ||||||
|  | //   <i> Default: 1000  (1ms) | ||||||
|  | #ifndef OS_TICK | ||||||
|  |  #define OS_TICK        10000 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | // </h> | ||||||
|  |  | ||||||
|  | // <h>System Configuration | ||||||
|  | // ======================= | ||||||
|  | // | ||||||
|  | // <e>Round-Robin Thread switching | ||||||
|  | // =============================== | ||||||
|  | // | ||||||
|  | // <i> Enables Round-Robin Thread switching. | ||||||
|  | #ifndef OS_ROBIN | ||||||
|  |  #define OS_ROBIN       1 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | //   <o>Round-Robin Timeout [ticks] <1-1000> | ||||||
|  | //   <i> Defines how long a thread will execute before a thread switch. | ||||||
|  | //   <i> Default: 5 | ||||||
|  | #ifndef OS_ROBINTOUT | ||||||
|  |  #define OS_ROBINTOUT   5 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | // </e> | ||||||
|  |  | ||||||
|  | // <e>User Timers | ||||||
|  | // ============== | ||||||
|  | //   <i> Enables user Timers | ||||||
|  | #ifndef OS_TIMERS | ||||||
|  |  #define OS_TIMERS      1 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | //   <o>Timer Thread Priority | ||||||
|  | //                        <1=> Low | ||||||
|  | //     <2=> Below Normal  <3=> Normal  <4=> Above Normal | ||||||
|  | //                        <5=> High | ||||||
|  | //                        <6=> Realtime (highest) | ||||||
|  | //   <i> Defines priority for Timer Thread | ||||||
|  | //   <i> Default: High | ||||||
|  | #ifndef OS_TIMERPRIO | ||||||
|  |  #define OS_TIMERPRIO   5 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | //   <o>Timer Thread stack size [bytes] <64-4096:8><#/4> | ||||||
|  | //   <i> Defines stack size for Timer thread. | ||||||
|  | //   <i> Default: 200 | ||||||
|  | #ifndef OS_TIMERSTKSZ | ||||||
|  |  #define OS_TIMERSTKSZ  50 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | //   <o>Timer Callback Queue size <1-32> | ||||||
|  | //   <i> Number of concurrent active timer callback functions. | ||||||
|  | //   <i> Default: 4 | ||||||
|  | #ifndef OS_TIMERCBQS | ||||||
|  |  #define OS_TIMERCBQS   4 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | // </e> | ||||||
|  |  | ||||||
|  | //   <o>ISR FIFO Queue size<4=>   4 entries  <8=>   8 entries | ||||||
|  | //                         <12=> 12 entries  <16=> 16 entries | ||||||
|  | //                         <24=> 24 entries  <32=> 32 entries | ||||||
|  | //                         <48=> 48 entries  <64=> 64 entries | ||||||
|  | //                         <96=> 96 entries | ||||||
|  | //   <i> ISR functions store requests to this buffer, | ||||||
|  | //   <i> when they are called from the interrupt handler. | ||||||
|  | //   <i> Default: 16 entries | ||||||
|  | #ifndef OS_FIFOSZ | ||||||
|  |  #define OS_FIFOSZ      16 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | // </h> | ||||||
|  |  | ||||||
|  | //------------- <<< end of configuration section >>> ----------------------- | ||||||
|  |  | ||||||
|  | // Standard library system mutexes | ||||||
|  | // =============================== | ||||||
|  | //  Define max. number system mutexes that are used to protect  | ||||||
|  | //  the arm standard runtime library. For microlib they are not used. | ||||||
|  | #ifndef OS_MUTEXCNT | ||||||
|  |  #define OS_MUTEXCNT    8 | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | /*---------------------------------------------------------------------------- | ||||||
|  |  *      RTX User configuration part END | ||||||
|  |  *---------------------------------------------------------------------------*/ | ||||||
|  |  | ||||||
|  | #define OS_TRV          ((uint32_t)(((double)OS_CLOCK*(double)OS_TICK)/1E6)-1) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /*---------------------------------------------------------------------------- | ||||||
|  |  *      Global Functions | ||||||
|  |  *---------------------------------------------------------------------------*/ | ||||||
|  |  | ||||||
|  | /*--------------------------- os_idle_demon ---------------------------------*/ | ||||||
|  |  | ||||||
|  | void os_idle_demon (void) { | ||||||
|  |   /* The idle demon is a system thread, running when no other thread is      */ | ||||||
|  |   /* ready to run.                                                           */ | ||||||
|  |  | ||||||
|  |   for (;;) { | ||||||
|  |     /* HERE: include optional user code to be executed when no thread runs.*/ | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #if (OS_SYSTICK == 0)   // Functions for alternative timer as RTX kernel timer | ||||||
|  |  | ||||||
|  | /*--------------------------- os_tick_init ----------------------------------*/ | ||||||
|  |  | ||||||
|  | // Initialize alternative hardware timer as RTX kernel timer | ||||||
|  | // Return: IRQ number of the alternative hardware timer | ||||||
|  | int os_tick_init (void) { | ||||||
|  |   return (-1);  /* Return IRQ number of timer (0..239) */ | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /*--------------------------- os_tick_val -----------------------------------*/ | ||||||
|  |  | ||||||
|  | // Get alternative hardware timer current value (0 .. OS_TRV) | ||||||
|  | uint32_t os_tick_val (void) { | ||||||
|  |   return (0); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /*--------------------------- os_tick_ovf -----------------------------------*/ | ||||||
|  |  | ||||||
|  | // Get alternative hardware timer overflow flag | ||||||
|  | // Return: 1 - overflow, 0 - no overflow | ||||||
|  | uint32_t os_tick_ovf (void) { | ||||||
|  |   return (0); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /*--------------------------- os_tick_irqack --------------------------------*/ | ||||||
|  |  | ||||||
|  | // Acknowledge alternative hardware timer interrupt | ||||||
|  | void os_tick_irqack (void) { | ||||||
|  |   /* ... */ | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif   // (OS_SYSTICK == 0) | ||||||
|  |  | ||||||
|  | /*--------------------------- os_error --------------------------------------*/ | ||||||
|  |  | ||||||
|  | void os_error (uint32_t err_code) { | ||||||
|  |   /* This function is called when a runtime error is detected. Parameter */ | ||||||
|  |   /* 'err_code' holds the runtime error code (defined in RTL.H).         */ | ||||||
|  |  | ||||||
|  |   /* HERE: include optional code to be executed on runtime error. */ | ||||||
|  |   for (;;); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /*---------------------------------------------------------------------------- | ||||||
|  |  *      RTX Configuration Functions | ||||||
|  |  *---------------------------------------------------------------------------*/ | ||||||
|  |  | ||||||
|  | #include "RTX_CM_lib.h" | ||||||
|  |  | ||||||
|  | /*---------------------------------------------------------------------------- | ||||||
|  |  * end of file | ||||||
|  |  *---------------------------------------------------------------------------*/ | ||||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach