add ring queue/message queue/mail queue, binary heap/priority queue/priority message queue/priority mail queue
1. remove the old msg queue and queue: i. msg queue is not a common and reusable/flexible component(need user to config the msg pool size and this componet can only be used by tos_queue) ii. tos_queue can only deliver the pointer message(cannot do a memory buffer deliver) 2. add ring queue(tos_ring_q) componet rinq queue can be reused by tos_chr_fifi/tos_msg_q/tos_mail_q as the foundational data container 3. add message queue(tos_msg_q) a little like the old queue mechanism, supply the capability to deliver a pointer message 4. add mail queue(tos_mail_q) supply the capability to deliver a memory buffer 5. add binary heap(tos_bin_heap) the basement componet to implement priority queue 6. add priority queue(tos_prio_q) can be reused by the priority message/mail queue as the foundational data container. 7. add priority message queue(tos_prio_msg_q) a message(pointer) deliver mechanism, supply the capability of delivering the message with priority(message with higher priority comes faster to the pender than with lower) 8. add priority mail queue(tos_prio_mail_q) a mail(memory buffer) deliver mechanism, supply the capability of delivering the mail with priority(mail with higher priority comes faster to the pender than with lower)
This commit is contained in:
@@ -383,7 +383,7 @@ void *osPoolAlloc(osPoolId pool_id)
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Allocate a memory block from a memory pool and set memory block to zero
|
||||
* @brief Allocate a memory block from a memory pool and set memory block to zero
|
||||
* @param[in] pool_id memory pool ID obtain referenced with \ref osPoolCreate.
|
||||
* @return address of the allocated memory block or NULL in case of no memory available.
|
||||
*/
|
||||
@@ -415,7 +415,7 @@ osStatus osPoolFree(osPoolId pool_id, void *block)
|
||||
#endif // Memory Pool Management available
|
||||
#endif // TOS_CFG_MMBLK_EN
|
||||
|
||||
#if TOS_CFG_QUEUE_EN > 0u
|
||||
#if TOS_CFG_MESSAGE_QUEUE_EN > 0u
|
||||
// ==== Message Queue Management Functions ====
|
||||
|
||||
#if (defined (osFeature_MessageQ) && (osFeature_MessageQ != 0)) // Message Queues available
|
||||
@@ -436,8 +436,8 @@ osMessageQId osMessageCreate(const osMessageQDef_t *queue_def, osThreadId thread
|
||||
|
||||
thread_id = thread_id; // make compiler happy
|
||||
|
||||
err = tos_queue_create((k_queue_t *)queue_def->queue);
|
||||
return err == K_ERR_NONE ? (k_queue_t *)queue_def->queue : NULL;
|
||||
err = tos_msg_q_create((k_msg_q_t *)queue_def->queue, queue_def->pool, queue_def->queue_sz);
|
||||
return err == K_ERR_NONE ? (k_msg_q_t *)queue_def->queue : NULL;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -449,7 +449,7 @@ osMessageQId osMessageCreate(const osMessageQDef_t *queue_def, osThreadId thread
|
||||
*/
|
||||
osStatus osMessagePut(osMessageQId queue_id, uint32_t info, uint32_t millisec)
|
||||
{
|
||||
return errno_knl2cmsis(tos_queue_post((k_queue_t *)queue_id, (void *)info, sizeof(uint32_t)));
|
||||
return errno_knl2cmsis(tos_msg_q_post((k_msg_q_t *)queue_id, &info));
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -464,7 +464,6 @@ osEvent osMessageGet(osMessageQId queue_id, uint32_t millisec)
|
||||
k_err_t err;
|
||||
k_tick_t timeout;
|
||||
void *msg_body = NULL;
|
||||
size_t msg_size = 0;
|
||||
|
||||
if (millisec == osWaitForever) {
|
||||
timeout = TOS_TIME_FOREVER;
|
||||
@@ -472,7 +471,7 @@ osEvent osMessageGet(osMessageQId queue_id, uint32_t millisec)
|
||||
timeout = tos_millisec2tick(millisec);
|
||||
}
|
||||
|
||||
err = tos_queue_pend((k_queue_t *)queue_id, &msg_body, &msg_size, timeout);
|
||||
err = tos_msg_q_pend((k_msg_q_t *)queue_id, &msg_body, timeout);
|
||||
if (err == K_ERR_NONE) {
|
||||
event.def.message_id = queue_id;
|
||||
event.status = errno_knl2cmsis(err);
|
||||
@@ -486,5 +485,5 @@ osEvent osMessageGet(osMessageQId queue_id, uint32_t millisec)
|
||||
}
|
||||
|
||||
#endif // Message Queues available
|
||||
#endif // TOS_CFG_QUEUE_EN
|
||||
#endif // TOS_CFG_MESSAGE_QUEUE_EN
|
||||
|
||||
|
Reference in New Issue
Block a user