|  | Paparazzi UAS v7.0_unstable
    Paparazzi is a free software Unmanned Aircraft System. | 
#include "modules/loggers/sdlog_chibios/msg_queue.h"#include "modules/tlsf/tlsf_malloc.h"#include <string.h> Include dependency graph for msg_queue.c:
 Include dependency graph for msg_queue.c:Go to the source code of this file.
| Data Structures | |
| union | MsgPtrLen | 
| struct | MsgPtrLen.__unnamed296__ | 
| Macros | |
| #define | MSGQ_HEAP HEAP_CCM | 
| Variables | |
| static const char * | _strerror [] | 
| union MsgPtrLen | 
Definition at line 33 of file msg_queue.c.
 Collaboration diagram for MsgPtrLen:
 Collaboration diagram for MsgPtrLen:| Data Fields | ||
|---|---|---|
| struct MsgPtrLen.__unnamed296__ | __unnamed__ | |
| msg_t | msg_ptr_len | |
| struct MsgPtrLen.__unnamed296__ | 
Definition at line 34 of file msg_queue.c.
| Data Fields | ||
|---|---|---|
| uint16_t | len | |
| uint16_t | ptrOfst | |
Definition at line 30 of file msg_queue.c.
| int32_t msgqueue_copy_send | ( | MsgQueue * | que, | 
| const void * | msg, | ||
| const uint16_t | msgLen, | ||
| const MsgQueueUrgency | urgency | ||
| ) | 
send a buffer NOT previously allocated
buffer is copied before beeing sent, buffer is still valid after this function returns. Less effective that zero copy alternatives which has been to be preferably used Non blocking, if queue is full, report error and immediately return
| [in] | que | pointer to opaque MsgQueue object | 
| [in] | msg | pointer to buffer | 
| [in] | msgLen | length of buffer (the same param that has been given to msgqueue_malloc_before_send) | 
| [in] | urgency | regular=queued at end of fifo or out_of_band queued at start of fifo | 
Definition at line 127 of file msg_queue.c.
References foo, msg, and msgqueue_copy_send_timeout().
 Here is the call graph for this function:
 Here is the call graph for this function:| int32_t msgqueue_copy_send_timeout | ( | MsgQueue * | que, | 
| const void * | msg, | ||
| const uint16_t | msgLen, | ||
| const MsgQueueUrgency | urgency, | ||
| const systime_t | timout | ||
| ) | 
send a buffer NOT previously allocated
buffer is copied before beeing sent, buffer is still valid after this function returns. Less effective that zero copy alternatives which has been to be preferably used
| [in] | que | pointer to opaque MsgQueue object | 
| [in] | msg | pointer to buffer | 
| [in] | msgLen | length of buffer (the same param that has been given to msgqueue_malloc_before_send) | 
| [in] | urgency | regular=queued at end of fifo or out_of_band queued at start of fifo | 
| [in] | timout | : time to wait for MailBox avaibility (can be TIME_INFINITE or TIME_IMMEDIATE) | 
Definition at line 114 of file msg_queue.c.
References foo, msg, MSGQ_HEAP, MsgQueue_MAILBOX_FULL, msgqueue_send_timeout(), and tlsf_malloc_r().
Referenced by msgqueue_copy_send().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| void msgqueue_init | ( | MsgQueue * | que, | 
| tlsf_memory_heap_t * | heap, | ||
| msg_t * | mb_buf, | ||
| const cnt_t | mb_size | ||
| ) | 
initialise MsgQueue
init sdQueue objet, tie memory pool buffer, tie mailbox buffer initialize mailbox
| [out] | que | opaque object to be initialized | 
| [in] | heap | reference to the tlsf heap object (needed if module should free memory) | 
| [in] | mb_buff | internal buffer used by MailBox (see Chibios Doc) | 
| [in] | mb_size | size of previous buffer (length of MailBox queue) | 
Definition at line 42 of file msg_queue.c.
References foo.
Referenced by sdLogInit().
 Here is the caller graph for this function:
 Here is the caller graph for this function:test if queue is empty
| [in] | que | pointer to opaque MsgQueue object | 
Definition at line 59 of file msg_queue.c.
References foo.
test if queue is full
| [in] | que | pointer to opaque MsgQueue object | 
Definition at line 50 of file msg_queue.c.
References foo.
wait then receive message
this is zero copy api, blocking call usage : struct MyStruct *msg msgqueue_pop (&que, void (void **) &msg); use msg->myField etc etc tlsf_free(MSGQ_HEAP, msg);
| [in] | que | pointer to opaque MsgQueue object | 
| [out] | msgPtr | pointer to pointer to buffer | 
Definition at line 134 of file msg_queue.c.
References foo, and msgqueue_pop_timeout().
 Here is the call graph for this function:
 Here is the call graph for this function:receive message specifying timeout
this is zero copy api, blocking call usage : struct MyStruct *msg msgqueue_pop (&que, void (void **) &msg); use msg->myField etc etc msgqueue_free_after_pop (&que, msg);
| [in] | que | pointer to opaque MsgQueue object | 
| [out] | msgPtr | pointer to pointer to buffer | 
| [in] | timout | : time to wait for MailBox avaibility (can be TIME_INFINITE or TIME_IMMEDIATE) | 
Definition at line 139 of file msg_queue.c.
References foo, MSGQ_HEAP, MsgQueue_MAILBOX_TIMEOUT, status, and tlsf_get_heap_addr().
Referenced by msgqueue_pop().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| int32_t msgqueue_send | ( | MsgQueue * | que, | 
| void * | msg, | ||
| const uint16_t | msgLen, | ||
| const MsgQueueUrgency | urgency | ||
| ) | 
send a buffer previously allocated by msgqueue_malloc_before_send
deallocation is done by the caching thread which actually write data to sd card from the sender point of view, ptr should be considered invalid after beeing sent. Even if msgqueue_send fail, deallocation is done Non blocking, if queue is full, report error and immediately return usage : msg = tlsf_malloc(MSGQ_HEAP, msg, msgLen); msgqueue_send (que, msg, msgLen, urgency);
| [in] | que | pointer to opaque MsgQueue object | 
| [in] | msg | pointer to buffer given by msgqueue_malloc_before_send | 
| [in] | msgLen | length of buffer (the same param that has been given to msgqueue_malloc_before_send) | 
| [in] | urgency | regular=queued at end of fifo or out_of_band queued at start of fifo | 
Definition at line 69 of file msg_queue.c.
References foo, msg, and msgqueue_send_timeout().
 Here is the call graph for this function:
 Here is the call graph for this function:| int32_t msgqueue_send_timeout | ( | MsgQueue * | que, | 
| void * | msg, | ||
| const uint16_t | msgLen, | ||
| const MsgQueueUrgency | urgency, | ||
| const systime_t | timout | ||
| ) | 
send a buffer previously allocated by msgqueue_malloc_before_send
deallocation is done by the caching thread which actually write data to sd card from the sender point of view, ptr should be considered invalid after beeing sent. Even if msgqueue_send fail, deallocation is done usage : msg = tlsf_malloc(MSGQ_HEAP, msg, msgLen); msgqueue_send (que, msg, msgLen, urgency);
| [in] | que | pointer to opaque MsgQueue object | 
| [in] | msg | pointer to buffer given by msgqueue_malloc_before_send | 
| [in] | msgLen | length of buffer (the same param that has been given to msgqueue_malloc_before_send) | 
| [in] | urgency | regular=queued at end of fifo or out_of_band queued at start of fifo | 
| [in] | timout | : time to wait for MailBox avaibility (can be TIME_INFINITE or TIME_IMMEDIATE) | 
Definition at line 76 of file msg_queue.c.
References foo, msg, MSGQ_HEAP, MsgQueue_INVALID_PTR, MsgQueue_MAILBOX_FULL, MsgQueue_REGULAR, tlsf_free_r(), and tlsf_get_heap_addr().
Referenced by msgqueue_copy_send_timeout(), and msgqueue_send().
 Here is the call graph for this function:
 Here is the call graph for this function: Here is the caller graph for this function:
 Here is the caller graph for this function:| const char * msgqueue_strerror | ( | const MsgQueueStatus | errno | ) | 
debug api
give ascii string corresponding to the given errno
| [in] | errno | : staus | 
Definition at line 168 of file msg_queue.c.
References _strerror, foo, and MsgQueue_MAILBOX_FULL.
Definition at line 159 of file msg_queue.c.
Referenced by msgqueue_strerror().