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:
@@ -8,9 +8,10 @@ k_err_t test_err = K_ERR_NONE;
|
||||
|
||||
test_context_t test_context = TEST_CONTEXT_NONE;
|
||||
|
||||
void *test_msg_addr = K_NULL;
|
||||
void *test_msg = K_NULL;
|
||||
|
||||
size_t test_msg_size = 0;
|
||||
test_mail_t test_mail;
|
||||
size_t test_mail_size = 0;
|
||||
|
||||
k_event_flag_t test_event_match = 0;
|
||||
|
||||
@@ -26,14 +27,25 @@ void test_event_set(k_event_flag_t event_match)
|
||||
|
||||
void test_msg_reset(void)
|
||||
{
|
||||
test_msg_addr = K_NULL;
|
||||
test_msg_size = 0;
|
||||
test_msg = K_NULL;
|
||||
}
|
||||
|
||||
void test_msg_set(void *msg_addr, size_t msg_size)
|
||||
void test_msg_set(void *msg)
|
||||
{
|
||||
test_msg_addr = msg_addr;
|
||||
test_msg_size = msg_size;
|
||||
test_msg = msg;
|
||||
}
|
||||
|
||||
void test_mail_reset(void)
|
||||
{
|
||||
test_mail.a = 0;
|
||||
test_mail.b = K_NULL;
|
||||
test_mail.c = 'X';
|
||||
}
|
||||
|
||||
void test_mail_set(void *mail, size_t mail_size)
|
||||
{
|
||||
memcpy(&test_mail, mail, sizeof(test_mail_t));
|
||||
test_mail_size = mail_size;
|
||||
}
|
||||
|
||||
void test_err_reset(void)
|
||||
|
Reference in New Issue
Block a user