RTEMS CAN/CAN FD Stack
|
This file is part of CAN/CAN FD bus common support and implements CAN FIFOs and generic hubs/ends for chip and caracter driver interface sides. More...
#include <stdatomic.h>
#include <inttypes.h>
#include <sys/queue.h>
#include <rtems.h>
#include <rtems/timespec.h>
#include <rtems/status-checks.h>
#include <rtems/thread.h>
#include <dev/can/can-frame.h>
#include <dev/can/can-filter.h>
Go to the source code of this file.
Classes | |
struct | canque_slot_t |
This structure represents one CAN message slot in the CAN FIFO queue. More... | |
struct | canque_fifo_t |
This structure represents CAN FIFO queue. It is implemented as a single linked list of slots prepared for processing. The empty slots are stored in single linked list. More... | |
struct | canque_edge_t |
This structure represents one direction connection from messages source ( inends) to message consumer ( outends) fifo ends hub. The edge contains canque_fifo_t for message fifo implementation-. More... | |
struct | canque_ends_t |
This structure represents place to connect edges to for CAN communication entity. The zero, one or more incoming and outgoing edges can be connected to this structure. More... | |
Functions | |
int | canque_fifo_flush_slots (struct canque_fifo_t *fifo) |
This function frees all ready slots from the FIFO. | |
int | canque_fifo_init_slots (struct canque_fifo_t *fifo) |
This function initializes slot chain of one CAN FIFO. | |
TAILQ_HEAD (canqueue_edges_list_t, canque_edge_t) | |
TAILQ_HEAD (canqueue_ends_list_t, canque_ends_t) | |
int | canque_get_inslot (struct canque_ends_t *qends, struct canque_edge_t **qedgep, struct canque_slot_t **slotp, int cmd) |
This function finds one outgoing edge and allocates slot from it. | |
int | canque_get_inslot4prio (struct canque_ends_t *qends, struct canque_edge_t **qedgep, struct canque_slot_t **slotp, const struct can_frame_header *header, int cmd, int prio) |
This function finds best outgoing edge and slot for given ID. | |
int | canque_test_inslot (struct canque_ends_t *qends) |
This function tests whether there is a free space in any outgoing edge. | |
int | canque_put_inslot (struct canque_ends_t *qends, struct canque_edge_t *qedge, struct canque_slot_t *slot) |
This function schedules filled slot for processing. | |
int | canque_abort_inslot (struct canque_ends_t *qends, struct canque_edge_t *qedge, struct canque_slot_t *slot) |
This function aborts preparation of the message in the slot. | |
int | canque_filter_frame2edges (struct canque_ends_t *qends, struct canque_edge_t *src_edge, struct can_frame *frame, unsigned int flags2add) |
This function sends message into all edges which accept its ID. | |
int | canque_test_outslot (struct canque_ends_t *qends, struct canque_edge_t **qedgep, struct canque_slot_t **slotp) |
This function tests and retrieves ready slot for given ends. | |
int | canque_pending_outslot_prio (struct canque_ends_t *qends, int prio_min) |
This function tests ready outslot with minimum priority. | |
int | canque_free_outslot (struct canque_ends_t *qends, struct canque_edge_t *qedge, struct canque_slot_t *slot) |
This function frees processed output slot. | |
int | canque_again_outslot (struct canque_ends_t *qends, struct canque_edge_t *qedge, struct canque_slot_t *slot) |
This function reschedules output slot to process it again later. | |
int | canque_flush (struct canque_edge_t *qedge) |
This function flushes all ready slots in the edge. | |
int | canqueue_disconnect_edge (struct canque_edge_t *qedge) |
This function disconnects edge from communication entities. | |
int | canqueue_connect_edge (struct canque_edge_t *qedge, struct canque_ends_t *inends, struct canque_ends_t *outends) |
This function connects edge between two communication entities. | |
int | canqueue_ends_init_gen (struct canque_ends_t *qends) |
This function implements subsystem independent routine to initialize ends state. | |
void | canqueue_block_inlist (struct canque_ends_t *qends) |
This function blocks slot allocation of all outgoing edges of specified ends. | |
void | canqueue_block_outlist (struct canque_ends_t *qends) |
This function blocks slot allocation of all incoming edges of specified ends. | |
int | canqueue_ends_kill_inlist (struct canque_ends_t *qends, int send_rest) |
This function sends request to die to all outgoing edges. | |
int | canqueue_ends_kill_outlist (struct canque_ends_t *qends) |
This function sends request to die to all incomming edges. | |
int | canqueue_ends_flush_inlist (struct canque_ends_t *qends) |
int | canqueue_ends_flush_outlist (struct canque_ends_t *qends) |
This function flushes all messages in outgoing edges. | |
void | canque_edge_do_dead (struct canque_edge_t *edge) |
void | __canque_edge_decref (struct canque_edge_t *edge) |
int | canque_fifo_init_kern (struct canque_fifo_t *fifo, int slotsnr, int maxdlen) |
This function initializes one CAN FIFO. | |
int | canque_fifo_done_kern (struct canque_fifo_t *fifo) |
This function frees slots allocated for CAN FIFO. | |
struct canque_edge_t * | canque_new_edge_kern (int slotsnrm, int maxdlen) |
This function allocates new edge structure. | |
int | canqueue_ends_sync_all_kern (struct canque_ends_t *qends, struct timespec *ts) |
This function waits for all ends to TX their messages. | |
int | canque_sync_wait_kern (struct canque_ends_t *qends, struct canque_edge_t *qedge, bool nowait, rtems_interval timeout) |
This function waits for all slots processing. | |
int | canqueue_ends_dispose_kern (struct canque_ends_t *qends, bool nonblock) |
This function provides finalizing of the ends structure for clients. | |
int | canqueue_kern_initialize (void) |
This function provides initialization of kernel queue side. | |
This file is part of CAN/CAN FD bus common support and implements CAN FIFOs and generic hubs/ends for chip and caracter driver interface sides.
int canque_abort_inslot | ( | struct canque_ends_t * | qends, |
struct canque_edge_t * | qedge, | ||
struct canque_slot_t * | slot | ||
) |
This function aborts preparation of the message in the slot.
Frees slot previously acquired by canque_get_inslot() or canque_get_inslot4prio() function call. Used when message copying into slot fails.
qends | Ends structure belonging to calling communication object. |
qedge | Edge the slot belongs to. |
slot | Pointer to the preprared slot. |
int canque_again_outslot | ( | struct canque_ends_t * | qends, |
struct canque_edge_t * | qedge, | ||
struct canque_slot_t * | slot | ||
) |
This function reschedules output slot to process it again later.
Function reschedules slot previously acquired by canque_test_outslot() function call for second time processing.
qends | Ends structure belonging to calling communication object. |
qedge | Edge the slot belongs to. |
slot | Pointer to the processed slot. |
int canque_fifo_done_kern | ( | struct canque_fifo_t * | fifo | ) |
This function frees slots allocated for CAN FIFO.
fifo | Pointer to the FIFO structure. |
int canque_fifo_flush_slots | ( | struct canque_fifo_t * | fifo | ) |
This function frees all ready slots from the FIFO.
The caller should be prepared to handle situations, when some slots are held by input or output side slots processing. These slots cannot be flushed or their processing interrupted.
fifo | Pointer to the FIFO structure. |
int canque_fifo_init_kern | ( | struct canque_fifo_t * | fifo, |
int | slotsnr, | ||
int | maxdlen | ||
) |
This function initializes one CAN FIFO.
fifo | Pointer to the FIFO structure. |
slotsnr | Number of requested slots. |
maxdlen | Maximum size of data in one slot/frame. |
int canque_fifo_init_slots | ( | struct canque_fifo_t * | fifo | ) |
This function initializes slot chain of one CAN FIFO.
The caller should be prepared to handle situations, when some slots are held by input or output side slots processing. These slots cannot be flushed or their processing interrupted.
fifo | Pointer to the FIFO structure. |
int canque_filter_frame2edges | ( | struct canque_ends_t * | qends, |
struct canque_edge_t * | src_edge, | ||
struct can_frame * | frame, | ||
unsigned int | flags2add | ||
) |
This function sends message into all edges which accept its ID.
Sends message to all outgoing edges connected to the given ends, which accepts message communication ID.
qends | Ends structure belonging to calling communication object |
src_edge | Optional source edge for echo detection |
frame | Pointer to CAN frame. |
flags2add | Optional additional CAN Frame flags. |
int canque_flush | ( | struct canque_edge_t * | qedge | ) |
This function flushes all ready slots in the edge.
Tries to flush all allocated slots from the edge, but there could exist some slots associated to edge which are processed by input or output side and cannot be flushed at this moment
qedge | Pointer to the edge. |
int canque_free_outslot | ( | struct canque_ends_t * | qends, |
struct canque_edge_t * | qedge, | ||
struct canque_slot_t * | slot | ||
) |
This function frees processed output slot.
Function releases processed slot previously acquired by canque_test_outslot() function call.
qends | Ends structure belonging to calling communication object. |
qedge | Edge the slot belongs to. |
slot | Pointer to the processed slot. |
int canque_get_inslot | ( | struct canque_ends_t * | qends, |
struct canque_edge_t ** | qedgep, | ||
struct canque_slot_t ** | slotp, | ||
int | cmd | ||
) |
This function finds one outgoing edge and allocates slot from it.
Function looks for the first non-blocked outgoing edge in @qends structure and tries to allocate slot from it.
qends | Ends structure belonging to calling communication object. |
qedgep | Place to store pointer to found edge. |
slotp | Place to store pointer to allocated slot. |
cmd | Command type for slot. |
int canque_get_inslot4prio | ( | struct canque_ends_t * | qends, |
struct canque_edge_t ** | qedgep, | ||
struct canque_slot_t ** | slotp, | ||
const struct can_frame_header * | header, | ||
int | cmd, | ||
int | prio | ||
) |
This function finds best outgoing edge and slot for given ID.
Function looks for the non-blocked outgoing edge accepting messages with given ID. If edge is found, slot is allocated from that edge. The edges with non-zero mask are preferred over edges open to all messages. If more edges with mask accepts given message ID, the edge with highest priority below or equal to required priority is selected.
qends | Ends structure belonging to calling communication object. |
qedgep | Place to store pointer to found edge. |
slotp | Place to store pointer to allocated slot. |
cmd | Command type for slot. |
id | Communication ID of message to send into edge. |
prio | Optional priority of message, |
struct canque_edge_t * canque_new_edge_kern | ( | int | slotsnr, |
int | maxdlen | ||
) |
This function allocates new edge structure.
slotsnr | Required number of slots in the newly allocated edge structure. |
maxdlen | Maximul data length of one CAN frame. |
int canque_pending_outslot_prio | ( | struct canque_ends_t * | qends, |
int | prio_min | ||
) |
This function tests ready outslot with minimum priority.
Function searches for ready slot in active incoming edge. The difference from canque_test_outslot function is that this function does not retreive the slot from FIFO, it just checks its existence. This can be used to determined whether there is a slot with higher priority class in the infrastruce.
qends | Ends structure belonging to calling communication object. |
prio_min | Minimum slot priority to be considered |
int canque_put_inslot | ( | struct canque_ends_t * | qends, |
struct canque_edge_t * | qedge, | ||
struct canque_slot_t * | slot | ||
) |
This function schedules filled slot for processing.
Puts slot previously acquired by canque_get_inslot() or canque_get_inslot4prio() function call into FIFO queue and activates edge processing if needed.
qends | Ends structure belonging to calling communication object. |
qedge | Edge the slot belongs to. |
slot | Pointer to the preprared slot. |
int canque_sync_wait_kern | ( | struct canque_ends_t * | qends, |
struct canque_edge_t * | qedge, | ||
bool | nowait, | ||
rtems_interval | timeout | ||
) |
This function waits for all slots processing.
qends | Ends structure belonging to calling communication object. |
qedge | Pointer to edge. |
nowait | True if semaphore should not wait |
timeout | Number of clock ticks to wait for semaphore |
int canque_test_inslot | ( | struct canque_ends_t * | qends | ) |
This function tests whether there is a free space in any outgoing edge.
Function looks for the first non-blocked outgoing edge in @qends structure with free space for slot.
qends | Ends structure belonging to calling communication object. |
int canque_test_outslot | ( | struct canque_ends_t * | qends, |
struct canque_edge_t ** | qedgep, | ||
struct canque_slot_t ** | slotp | ||
) |
This function tests and retrieves ready slot for given ends.
Function takes highest priority active incoming edge and retrieves oldest ready slot from it.
qends | Ends structure belonging to calling communication object. |
qedgep | Place to store pointer to found edge. |
slotp | Place to store pointer to received slot. |
void canqueue_block_inlist | ( | struct canque_ends_t * | qends | ) |
This function blocks slot allocation of all outgoing edges of specified ends.
qends | Pointer to ends structure. |
void canqueue_block_outlist | ( | struct canque_ends_t * | qends | ) |
This function blocks slot allocation of all incoming edges of specified ends.
qends | Pointer to ends structure. |
int canqueue_connect_edge | ( | struct canque_edge_t * | qedge, |
struct canque_ends_t * | inends, | ||
struct canque_ends_t * | outends | ||
) |
This function connects edge between two communication entities.
qedge | Pointer to edge. |
inends | Pointer to ends the input of the edge should be connected to. |
outends | Pointer to ends the output of the edge should be connected to. |
int canqueue_disconnect_edge | ( | struct canque_edge_t * | qedge | ) |
This function disconnects edge from communication entities.
qedge | Pointer to edge. |
int canqueue_ends_dispose_kern | ( | struct canque_ends_t * | qends, |
bool | nonblock | ||
) |
This function provides finalizing of the ends structure for clients.
qends | Pointer to ends structure. |
nonblock | Flag indicating that user does not want to wait for processing of all remaining messages. |
int canqueue_ends_flush_inlist | ( | struct canque_ends_t * | qends | ) |
canqueue_ends_flush_inlist - flushes all messages in incoming edges @qends: pointer to ends structure
Return Value: Negative value informs about unsuccessful result
int canqueue_ends_flush_outlist | ( | struct canque_ends_t * | qends | ) |
This function flushes all messages in outgoing edges.
qends | Pointer to ends structure. |
int canqueue_ends_init_gen | ( | struct canque_ends_t * | qends | ) |
This function implements subsystem independent routine to initialize ends state.
qends | Pointer to the end. |
int canqueue_ends_kill_inlist | ( | struct canque_ends_t * | qends, |
int | send_rest | ||
) |
This function sends request to die to all outgoing edges.
qends | Pointer to ends structure. |
send_rest | Select, whether already allocated slots should be processed by FIFO output side. |
int canqueue_ends_kill_outlist | ( | struct canque_ends_t * | qends | ) |
This function sends request to die to all incomming edges.
qends | Pointer to ends structure. |
int canqueue_ends_sync_all_kern | ( | struct canque_ends_t * | qends, |
struct timespec * | ts | ||
) |
This function waits for all ends to TX their messages.
qends | Pointer to ends structure. |
ts | Absolute time againts CLOCK_MONOTONIC that informs canque_sync_wait_kern how long to wait. |
int canqueue_kern_initialize | ( | void | ) |
This function provides initialization of kernel queue side.