Merge branch 'master' into update-host
This commit is contained in:
		| @@ -78,8 +78,9 @@ static inline bool osal_mutex_unlock(osal_mutex_t mutex_hdl); | ||||
|  | ||||
| //------------- Queue -------------// | ||||
| static inline osal_queue_t osal_queue_create(osal_queue_def_t* qdef); | ||||
| static inline bool osal_queue_receive(osal_queue_t const qhdl, void* data); | ||||
| static inline bool osal_queue_send(osal_queue_t const qhdl, void const * data, bool in_isr); | ||||
| static inline bool osal_queue_receive(osal_queue_t qhdl, void* data); | ||||
| static inline bool osal_queue_send(osal_queue_t qhdl, void const * data, bool in_isr); | ||||
| static inline bool osal_queue_empty(osal_queue_t qhdl); | ||||
|  | ||||
| #if 0  // TODO remove subtask related macros later | ||||
| // Sub Task | ||||
|   | ||||
| @@ -118,14 +118,19 @@ static inline osal_queue_t osal_queue_create(osal_queue_def_t* qdef) | ||||
|   return xQueueCreateStatic(qdef->depth, qdef->item_sz, (uint8_t*) qdef->buf, &qdef->sq); | ||||
| } | ||||
|  | ||||
| static inline bool osal_queue_receive(osal_queue_t const queue_hdl, void* data) | ||||
| static inline bool osal_queue_receive(osal_queue_t qhdl, void* data) | ||||
| { | ||||
|   return xQueueReceive(queue_hdl, data, portMAX_DELAY); | ||||
|   return xQueueReceive(qhdl, data, portMAX_DELAY); | ||||
| } | ||||
|  | ||||
| static inline bool osal_queue_send(osal_queue_t const queue_hdl, void const * data, bool in_isr) | ||||
| static inline bool osal_queue_send(osal_queue_t qhdl, void const * data, bool in_isr) | ||||
| { | ||||
|   return in_isr ? xQueueSendToBackFromISR(queue_hdl, data, NULL) : xQueueSendToBack(queue_hdl, data, OSAL_TIMEOUT_WAIT_FOREVER); | ||||
|   return in_isr ? xQueueSendToBackFromISR(qhdl, data, NULL) : xQueueSendToBack(qhdl, data, OSAL_TIMEOUT_WAIT_FOREVER); | ||||
| } | ||||
|  | ||||
| static inline bool osal_queue_empty(osal_queue_t qhdl) | ||||
| { | ||||
|   return uxQueueMessagesWaiting(qhdl) == 0; | ||||
| } | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|   | ||||
| @@ -125,7 +125,7 @@ static inline osal_queue_t osal_queue_create(osal_queue_def_t* qdef) | ||||
|   return (osal_queue_t) qdef; | ||||
| } | ||||
|  | ||||
| static inline bool osal_queue_receive(osal_queue_t const qhdl, void* data) | ||||
| static inline bool osal_queue_receive(osal_queue_t qhdl, void* data) | ||||
| { | ||||
|   struct os_event* ev; | ||||
|   ev = os_eventq_get(&qhdl->evq); | ||||
| @@ -137,7 +137,7 @@ static inline bool osal_queue_receive(osal_queue_t const qhdl, void* data) | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| static inline bool osal_queue_send(osal_queue_t const qhdl, void const * data, bool in_isr) | ||||
| static inline bool osal_queue_send(osal_queue_t qhdl, void const * data, bool in_isr) | ||||
| { | ||||
|   (void) in_isr; | ||||
|  | ||||
| @@ -161,6 +161,12 @@ static inline bool osal_queue_send(osal_queue_t const qhdl, void const * data, b | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| static inline bool osal_queue_empty(osal_queue_t qhdl) | ||||
| { | ||||
|   return STAILQ_EMPTY(&qhdl->evq.evq_list); | ||||
| } | ||||
|  | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|   | ||||
| @@ -142,7 +142,7 @@ typedef osal_queue_def_t* osal_queue_t; | ||||
|     }\ | ||||
|   } | ||||
|  | ||||
| // lock queue by disable usb isr | ||||
| // lock queue by disable USB interrupt | ||||
| static inline void _osal_q_lock(osal_queue_t qhdl) | ||||
| { | ||||
|   (void) qhdl; | ||||
| @@ -176,8 +176,7 @@ static inline osal_queue_t osal_queue_create(osal_queue_def_t* qdef) | ||||
|   return (osal_queue_t) qdef; | ||||
| } | ||||
|  | ||||
| // non blocking | ||||
| static inline bool osal_queue_receive(osal_queue_t const qhdl, void* data) | ||||
| static inline bool osal_queue_receive(osal_queue_t qhdl, void* data) | ||||
| { | ||||
|   _osal_q_lock(qhdl); | ||||
|   bool success = tu_fifo_read(&qhdl->ff, data); | ||||
| @@ -186,7 +185,7 @@ static inline bool osal_queue_receive(osal_queue_t const qhdl, void* data) | ||||
|   return success; | ||||
| } | ||||
|  | ||||
| static inline bool osal_queue_send(osal_queue_t const qhdl, void const * data, bool in_isr) | ||||
| static inline bool osal_queue_send(osal_queue_t qhdl, void const * data, bool in_isr) | ||||
| { | ||||
|   if (!in_isr) { | ||||
|     _osal_q_lock(qhdl); | ||||
| @@ -203,6 +202,13 @@ static inline bool osal_queue_send(osal_queue_t const qhdl, void const * data, b | ||||
|   return success; | ||||
| } | ||||
|  | ||||
| static inline bool osal_queue_empty(osal_queue_t qhdl) | ||||
| { | ||||
|   // Skip queue lock/unlock since this function is primarily called | ||||
|   // with interrupt disabled before going into low power mode | ||||
|   return tu_fifo_empty(&qhdl->ff); | ||||
| } | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  } | ||||
| #endif | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach