| 
									
										
										
										
											2019-03-20 16:11:42 +07:00
										 |  |  | /* 
 | 
					
						
							|  |  |  |  * The MIT License (MIT) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2018, hathach (tinyusb.org) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | 
					
						
							|  |  |  |  * of this software and associated documentation files (the "Software"), to deal | 
					
						
							|  |  |  |  * in the Software without restriction, including without limitation the rights | 
					
						
							|  |  |  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | 
					
						
							|  |  |  |  * copies of the Software, and to permit persons to whom the Software is | 
					
						
							|  |  |  |  * furnished to do so, subject to the following conditions: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The above copyright notice and this permission notice shall be included in | 
					
						
							|  |  |  |  * all copies or substantial portions of the Software. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 
					
						
							|  |  |  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
					
						
							|  |  |  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | 
					
						
							|  |  |  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
					
						
							|  |  |  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | 
					
						
							|  |  |  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | 
					
						
							|  |  |  |  * THE SOFTWARE. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of the TinyUSB stack. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2013-01-26 01:37:15 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 14:31:11 +07:00
										 |  |  | #ifdef CFG_TUSB_OS
 | 
					
						
							|  |  |  | #undef CFG_TUSB_OS
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-17 22:57:11 +07:00
										 |  |  | void setUp(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void tearDown(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if 0 // TODO enable
 | 
					
						
							| 
									
										
										
										
											2013-01-26 01:37:15 +07:00
										 |  |  | #include "unity.h"
 | 
					
						
							| 
									
										
										
										
											2014-04-17 20:40:34 +07:00
										 |  |  | #include "tusb_errors.h"
 | 
					
						
							| 
									
										
										
										
											2013-01-30 12:55:44 +07:00
										 |  |  | #include "osal_none.h"
 | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-30 17:53:37 +07:00
										 |  |  | #define QUEUE_DEPTH 10
 | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | uint32_t statements[10]; | 
					
						
							| 
									
										
										
										
											2013-01-30 17:53:37 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-04 16:07:42 +07:00
										 |  |  | OSAL_SEM_DEF(sem); | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | osal_semaphore_handle_t sem_hdl; | 
					
						
							| 
									
										
										
										
											2013-01-26 01:37:15 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-10 01:13:31 +07:00
										 |  |  | OSAL_QUEUE_DEF(queue, QUEUE_DEPTH, uint32_t); | 
					
						
							| 
									
										
										
										
											2013-01-30 17:53:37 +07:00
										 |  |  | osal_queue_handle_t queue_hdl; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-27 16:19:22 +07:00
										 |  |  | OSAL_MUTEX_DEF(mutex); | 
					
						
							|  |  |  | osal_mutex_handle_t mutex_hdl; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-26 01:37:15 +07:00
										 |  |  | void setUp(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  |   memset(statements, 0, sizeof(statements)); | 
					
						
							| 
									
										
										
										
											2013-09-13 22:30:11 +07:00
										 |  |  |   sem_hdl   = osal_semaphore_create (OSAL_SEM_REF(sem)); | 
					
						
							|  |  |  |   queue_hdl = osal_queue_create     (OSAL_QUEUE_REF(queue)); | 
					
						
							|  |  |  |   mutex_hdl = osal_mutex_create     (OSAL_MUTEX_REF(mutex)); | 
					
						
							| 
									
										
										
										
											2013-01-26 01:37:15 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void tearDown(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Semaphore
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | void test_semaphore_create(void) | 
					
						
							| 
									
										
										
										
											2013-01-26 01:37:15 +07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  |   TEST_ASSERT_EQUAL_PTR(&sem, sem_hdl); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, sem); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_semaphore_post(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   osal_semaphore_post(sem_hdl); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, sem); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2013-01-30 17:53:37 +07:00
										 |  |  | // blocking service such as semaphore wait need to be invoked within a task's loop
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-27 16:19:22 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Mutex
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | void test_mutex_create(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL_PTR(&mutex, mutex_hdl); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, mutex); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_mutex_release(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   osal_mutex_release(mutex_hdl); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, mutex); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // Queue
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | void test_queue_create(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-01-30 17:53:37 +07:00
										 |  |  |   TEST_ASSERT_EQUAL_PTR(&queue, queue_hdl); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(QUEUE_DEPTH, queue_hdl->depth); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL_PTR(queue_buffer, queue_hdl->buffer); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, queue_hdl->count); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, queue_hdl->wr_idx); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, queue_hdl->rd_idx); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_queue_send(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   uint32_t const item = 0x1234; | 
					
						
							| 
									
										
										
										
											2013-04-10 01:13:31 +07:00
										 |  |  |   osal_queue_send(queue_hdl, &item); | 
					
						
							| 
									
										
										
										
											2013-01-30 17:53:37 +07:00
										 |  |  |   TEST_ASSERT_EQUAL(1, queue_hdl->count); | 
					
						
							| 
									
										
										
										
											2013-04-10 01:13:31 +07:00
										 |  |  |   TEST_ASSERT_EQUAL_MEMORY(&item, queue_hdl->buffer + (queue_hdl->rd_idx * queue_hdl->item_size), 4); | 
					
						
							| 
									
										
										
										
											2013-01-26 01:37:15 +07:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2013-01-30 17:53:37 +07:00
										 |  |  | // blocking service such as semaphore wait need to be invoked within a task's loop
 | 
					
						
							| 
									
										
										
										
											2013-01-26 01:37:15 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  | // TASK SEMAPHORE
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-03-10 19:28:38 +07:00
										 |  |  | tusb_error_t sample_task_semaphore(void) | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-02-01 10:33:43 +07:00
										 |  |  |   tusb_error_t error = TUSB_ERROR_NONE; | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   OSAL_TASK_LOOP_BEGIN | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   statements[0]++; | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   osal_semaphore_wait(sem_hdl, OSAL_TIMEOUT_WAIT_FOREVER, &error); | 
					
						
							|  |  |  |   statements[1]++; | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   osal_semaphore_wait(sem_hdl, OSAL_TIMEOUT_WAIT_FOREVER, &error); | 
					
						
							|  |  |  |   statements[2]++; | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   osal_semaphore_wait(sem_hdl, OSAL_TIMEOUT_WAIT_FOREVER, &error); | 
					
						
							|  |  |  |   statements[3]++; | 
					
						
							| 
									
										
										
										
											2013-02-01 12:00:34 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   osal_semaphore_wait(sem_hdl, OSAL_TIMEOUT_NORMAL, &error); | 
					
						
							|  |  |  |   statements[4]++; | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(TUSB_ERROR_OSAL_TIMEOUT, error); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OSAL_TASK_LOOP_END | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_task_with_semaphore(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   // several invoke before sempahore is available
 | 
					
						
							| 
									
										
										
										
											2013-02-01 12:00:34 +07:00
										 |  |  |   for(uint32_t i=0; i<10; i++) | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  |     sample_task_semaphore(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[0]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  |   // invoke after posting semaphore
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  |   osal_semaphore_post(sem_hdl); | 
					
						
							|  |  |  |   sample_task_semaphore(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[1]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-01 10:33:43 +07:00
										 |  |  |   // post 2 consecutive times
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  |   osal_semaphore_post(sem_hdl); | 
					
						
							|  |  |  |   osal_semaphore_post(sem_hdl); | 
					
						
							|  |  |  |   sample_task_semaphore(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[2]); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-01 10:33:43 +07:00
										 |  |  |   // timeout
 | 
					
						
							| 
									
										
										
										
											2018-04-10 14:31:11 +07:00
										 |  |  |   for(uint32_t i=0; i<(OSAL_TIMEOUT_NORMAL*CFG_TUSB_OS_TICKS_PER_SECOND)/1000 - 1  ; i++) // not enough time
 | 
					
						
							| 
									
										
										
										
											2013-02-01 12:00:34 +07:00
										 |  |  |     osal_tick_tock(); | 
					
						
							|  |  |  |   sample_task_semaphore(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, statements[4]); | 
					
						
							|  |  |  |   osal_tick_tock(); | 
					
						
							|  |  |  |   sample_task_semaphore(); | 
					
						
							| 
									
										
										
										
											2013-02-01 10:33:43 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-30 11:35:37 +07:00
										 |  |  |   // reach end of task loop, back to beginning
 | 
					
						
							|  |  |  |   sample_task_semaphore(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(2, statements[0]); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-27 16:19:22 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // TASK MUTEX
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | tusb_error_t mutex_sample_task1(void) // occupy mutex and not release it
 | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   tusb_error_t error = TUSB_ERROR_NONE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OSAL_TASK_LOOP_BEGIN | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   statements[0]++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   osal_mutex_wait(mutex_hdl, OSAL_TIMEOUT_WAIT_FOREVER, &error); | 
					
						
							|  |  |  |   statements[2]++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OSAL_TASK_LOOP_END | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | tusb_error_t mutex_sample_task2(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   tusb_error_t error = TUSB_ERROR_NONE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OSAL_TASK_LOOP_BEGIN | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   statements[1]++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   osal_mutex_wait(mutex_hdl, OSAL_TIMEOUT_WAIT_FOREVER, &error); | 
					
						
							|  |  |  |   statements[3]++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   osal_mutex_wait(mutex_hdl, OSAL_TIMEOUT_NORMAL, &error); | 
					
						
							|  |  |  |   statements[5]++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(TUSB_ERROR_OSAL_TIMEOUT, error); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OSAL_TASK_LOOP_END | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_task_with_mutex(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   // several invoke before mutex is available
 | 
					
						
							|  |  |  |   mutex_sample_task1(); | 
					
						
							|  |  |  |   for(uint32_t i=0; i<10; i++) { | 
					
						
							|  |  |  |     mutex_sample_task2(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[0]); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[1]); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, statements[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // invoke after posting mutex
 | 
					
						
							|  |  |  |   osal_mutex_release(mutex_hdl); | 
					
						
							|  |  |  |   for(uint32_t i=0; i<10; i++) { | 
					
						
							|  |  |  |     mutex_sample_task2(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[3]); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, statements[5]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // timeout
 | 
					
						
							| 
									
										
										
										
											2018-04-10 14:31:11 +07:00
										 |  |  |   for(uint32_t i=0; i<(OSAL_TIMEOUT_NORMAL*CFG_TUSB_OS_TICKS_PER_SECOND)/1000 - 1 ; i++){ // one tick less
 | 
					
						
							| 
									
										
										
										
											2013-06-27 16:19:22 +07:00
										 |  |  |     osal_tick_tock(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   mutex_sample_task2(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, statements[5]); | 
					
						
							|  |  |  |   osal_tick_tock(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   mutex_sample_task2(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[5]); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-04-27 00:24:15 +07:00
										 |  |  | // TASK QUEUE
 | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-03-10 19:28:38 +07:00
										 |  |  | tusb_error_t sample_task_with_queue(void) | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | { | 
					
						
							|  |  |  |   uint32_t data; | 
					
						
							| 
									
										
										
										
											2013-02-01 12:39:39 +07:00
										 |  |  |   tusb_error_t error; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   OSAL_TASK_LOOP_BEGIN | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   statements[0]++; | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   osal_queue_receive(queue_hdl, &data, OSAL_TIMEOUT_WAIT_FOREVER, &error); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0x1111, data); | 
					
						
							|  |  |  |   statements[1]++; | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   osal_queue_receive(queue_hdl, &data, OSAL_TIMEOUT_WAIT_FOREVER, &error); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0x2222, data); | 
					
						
							|  |  |  |   statements[2]++; | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   osal_queue_receive(queue_hdl, &data, OSAL_TIMEOUT_WAIT_FOREVER, &error); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0x3333, data); | 
					
						
							|  |  |  |   statements[3]++; | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   osal_queue_receive(queue_hdl, &data, OSAL_TIMEOUT_NORMAL, &error); | 
					
						
							|  |  |  |   statements[4]++; | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(TUSB_ERROR_OSAL_TIMEOUT, error); | 
					
						
							| 
									
										
										
										
											2013-02-01 12:39:39 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-02 15:36:20 +07:00
										 |  |  |   OSAL_TASK_LOOP_END | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_task_with_queue(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   uint32_t i = 0; | 
					
						
							| 
									
										
										
										
											2013-04-10 01:13:31 +07:00
										 |  |  |   uint32_t item; | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   sample_task_with_queue(); | 
					
						
							|  |  |  |   // several invoke before queue is available
 | 
					
						
							|  |  |  |   for(i=0; i<10; i++) | 
					
						
							|  |  |  |     sample_task_with_queue(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[0]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-27 16:19:22 +07:00
										 |  |  |   // invoke after sending to queue
 | 
					
						
							| 
									
										
										
										
											2013-04-10 01:13:31 +07:00
										 |  |  |   item = 0x1111; | 
					
						
							|  |  |  |   osal_queue_send(queue_hdl, &item); | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  |   sample_task_with_queue(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[1]); | 
					
						
							|  |  |  |   sample_task_with_queue(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[1]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-10 01:13:31 +07:00
										 |  |  |   item = 0x2222; | 
					
						
							|  |  |  |   osal_queue_send(queue_hdl, &item); | 
					
						
							|  |  |  |   item = 0x3333; | 
					
						
							|  |  |  |   osal_queue_send(queue_hdl, &item); | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  |   sample_task_with_queue(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[2]); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-01 12:39:39 +07:00
										 |  |  |   // timeout
 | 
					
						
							| 
									
										
										
										
											2018-04-10 14:31:11 +07:00
										 |  |  |   for(uint32_t i=0; i<(OSAL_TIMEOUT_NORMAL*CFG_TUSB_OS_TICKS_PER_SECOND)/1000 - 1 ; i++) // not enough time
 | 
					
						
							| 
									
										
										
										
											2013-02-01 12:39:39 +07:00
										 |  |  |     osal_tick_tock(); | 
					
						
							|  |  |  |   sample_task_with_queue(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, statements[4]); | 
					
						
							|  |  |  |   osal_tick_tock(); | 
					
						
							|  |  |  |   sample_task_with_queue(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // reach end of task loop, back to beginning
 | 
					
						
							|  |  |  |   sample_task_with_queue(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(2, statements[0]); | 
					
						
							| 
									
										
										
										
											2013-01-30 23:29:27 +07:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2013-01-26 01:37:15 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-27 00:24:15 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // TASK DELAY
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | tusb_error_t sample_task_with_delay(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   tusb_error_t error; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OSAL_TASK_LOOP_BEGIN | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   osal_task_delay(1000); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   statements[0]++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OSAL_TASK_LOOP_END | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_task_with_delay(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   sample_task_with_delay(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, statements[0]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 14:31:11 +07:00
										 |  |  |   for(uint32_t i=0; i<CFG_TUSB_OS_TICKS_PER_SECOND*1000; i++) // not enough time
 | 
					
						
							| 
									
										
										
										
											2013-04-27 00:24:15 +07:00
										 |  |  |     osal_tick_tock(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sample_task_with_delay(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[0]); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // TASK FLOW CONTROL
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | void flow_control_error_handler(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   statements[5]++; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-24 12:20:56 +07:00
										 |  |  | tusb_error_t sample_flow_control_subtask2(void) | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  | { | 
					
						
							|  |  |  |   tusb_error_t error; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-24 12:20:56 +07:00
										 |  |  |   OSAL_SUBTASK_BEGIN | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   statements[0]++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   osal_semaphore_wait(sem_hdl, OSAL_TIMEOUT_NORMAL, &error); | 
					
						
							| 
									
										
										
										
											2013-04-24 12:20:56 +07:00
										 |  |  |   SUBTASK_ASSERT(TUSB_ERROR_NONE == error); | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  |   statements[1]++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   osal_semaphore_wait(sem_hdl, OSAL_TIMEOUT_NORMAL, &error); | 
					
						
							| 
									
										
										
										
											2013-04-24 12:20:56 +07:00
										 |  |  |   SUBTASK_ASSERT_STATUS(error); | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  |   statements[2]++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   osal_semaphore_wait(sem_hdl, OSAL_TIMEOUT_NORMAL, &error); | 
					
						
							| 
									
										
										
										
											2018-03-21 20:42:23 +07:00
										 |  |  |   SUBTASK_ASSERT_STATUS_HDLR(error, flow_control_error_handler()); | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  |   statements[3]++; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-24 12:20:56 +07:00
										 |  |  |   OSAL_SUBTASK_END | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | tusb_error_t sample_flow_control_subtask(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   OSAL_SUBTASK_BEGIN | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-24 17:53:43 +07:00
										 |  |  |   sample_flow_control_subtask2(); | 
					
						
							| 
									
										
										
										
											2013-04-24 12:20:56 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   OSAL_SUBTASK_END | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | tusb_error_t sample_task_flow_control(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   OSAL_TASK_LOOP_BEGIN | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-24 13:45:42 +07:00
										 |  |  |   sample_flow_control_subtask(); | 
					
						
							| 
									
										
										
										
											2013-04-24 12:20:56 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  |   OSAL_TASK_LOOP_END | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_task_flow_control_assert(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   sample_task_flow_control(); | 
					
						
							| 
									
										
										
										
											2018-04-10 14:31:11 +07:00
										 |  |  |   for(uint32_t i=0; i<(OSAL_TIMEOUT_NORMAL*CFG_TUSB_OS_TICKS_PER_SECOND)/1000 + 1; i++) osal_tick_tock(); | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  |   sample_task_flow_control(); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, statements[1]); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_task_flow_control_assert_status(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   for (uint8_t i=0; i<1; i++) osal_semaphore_post(sem_hdl); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sample_task_flow_control(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 14:31:11 +07:00
										 |  |  |   for(uint32_t i=0; i<(OSAL_TIMEOUT_NORMAL*CFG_TUSB_OS_TICKS_PER_SECOND)/1000 + 1; i++) osal_tick_tock(); | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  |   sample_task_flow_control(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, statements[2]); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void test_task_flow_control_assert_status_hanlder(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   for (uint8_t i=0; i<2; i++) osal_semaphore_post(sem_hdl); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sample_task_flow_control(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-10 14:31:11 +07:00
										 |  |  |   for(uint32_t i=0; i<(OSAL_TIMEOUT_NORMAL*CFG_TUSB_OS_TICKS_PER_SECOND)/1000 + 1; i++) osal_tick_tock(); | 
					
						
							| 
									
										
										
										
											2013-02-06 13:15:12 +07:00
										 |  |  |   sample_task_flow_control(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(0, statements[3]); | 
					
						
							|  |  |  |   TEST_ASSERT_EQUAL(1, statements[5]); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-04-17 22:57:11 +07:00
										 |  |  | #endif
 |