libs
platform_specific_components
avr
libcanard
avr-can-lib
src
can_buffer.c
Go to the documentation of this file.
1
// -----------------------------------------------------------------------------
2
/*
3
* Copyright (c) 2007 Fabian Greif, Roboterclub Aachen e.V.
4
* All rights reserved.
5
*
6
* Redistribution and use in source and binary forms, with or without
7
* modification, are permitted provided that the following conditions
8
* are met:
9
* 1. Redistributions of source code must retain the above copyright
10
* notice, this list of conditions and the following disclaimer.
11
* 2. Redistributions in binary form must reproduce the above copyright
12
* notice, this list of conditions and the following disclaimer in the
13
* documentation and/or other materials provided with the distribution.
14
*
15
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
19
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25
* SUCH DAMAGE.
26
*
27
* $Id: can_buffer.c 6837 2008-11-16 19:05:15Z fabian $
28
*/
29
// -----------------------------------------------------------------------------
30
31
#include "
can_private.h
"
32
#include "
can_buffer.h
"
33
#include "
utils.h
"
34
35
#if CAN_RX_BUFFER_SIZE > 0 || CAN_TX_BUFFER_SIZE > 0
36
37
// -----------------------------------------------------------------------------
38
void
can_buffer_init
(
can_buffer_t
*buf,
uint8_t
size,
can_t
*list)
39
{
40
ENTER_CRITICAL_SECTION
;
41
buf->
size
= size;
42
buf->
buf
= list;
43
44
buf->
head
= 0;
45
buf->
tail
= 0;
46
buf->
used
= 0;
47
LEAVE_CRITICAL_SECTION
;
48
}
49
50
// -----------------------------------------------------------------------------
51
bool
can_buffer_empty
(
can_buffer_t
*buf)
52
{
53
uint8_t
used;
54
55
ENTER_CRITICAL_SECTION
;
56
used = buf->
used
;
57
LEAVE_CRITICAL_SECTION
;
58
59
if
(used == 0)
60
return
true
;
61
else
62
return
false
;
63
}
64
65
// -----------------------------------------------------------------------------
66
bool
can_buffer_full
(
can_buffer_t
*buf)
67
{
68
uint8_t
used;
69
uint8_t
size;
70
71
ENTER_CRITICAL_SECTION
;
72
used = buf->
used
;
73
size = buf->
size
;
74
LEAVE_CRITICAL_SECTION
;
75
76
if
(used >= size)
77
return
true
;
78
else
79
return
false
;
80
}
81
82
// -----------------------------------------------------------------------------
83
can_t
*
can_buffer_get_enqueue_ptr
(
can_buffer_t
*buf)
84
{
85
if
(
can_buffer_full
( buf ))
86
return
NULL
;
87
88
return
&buf->
buf
[buf->
head
];
89
}
90
91
// -----------------------------------------------------------------------------
92
void
can_buffer_enqueue
(
can_buffer_t
*buf)
93
{
94
ENTER_CRITICAL_SECTION
;
95
buf->
used
++;
96
if
(++buf->
head
>= buf->
size
)
97
buf->
head
= 0;
98
LEAVE_CRITICAL_SECTION
;
99
}
100
101
// -----------------------------------------------------------------------------
102
can_t
*
can_buffer_get_dequeue_ptr
(
can_buffer_t
*buf)
103
{
104
if
(
can_buffer_empty
( buf ))
105
return
NULL
;
106
107
return
&buf->
buf
[buf->
tail
];
108
}
109
110
// -----------------------------------------------------------------------------
111
void
can_buffer_dequeue
(
can_buffer_t
*buf)
112
{
113
ENTER_CRITICAL_SECTION
;
114
buf->
used
--;
115
if
(++buf->
tail
>= buf->
size
)
116
buf->
tail
= 0;
117
LEAVE_CRITICAL_SECTION
;
118
}
119
120
#endif
ENTER_CRITICAL_SECTION
#define ENTER_CRITICAL_SECTION
Definition:
utils.h:126
can_buffer_t::buf
can_t * buf
Definition:
can_buffer.h:40
can_t
Datenstruktur zum Aufnehmen von CAN Nachrichten.
Definition:
can.h:177
can_buffer_t::size
uint8_t size
Definition:
can_buffer.h:41
can_buffer_dequeue
void can_buffer_dequeue(can_buffer_t *buf)
can_buffer_get_enqueue_ptr
can_t * can_buffer_get_enqueue_ptr(can_buffer_t *buf)
can_buffer_empty
bool can_buffer_empty(can_buffer_t *buf)
utils.h
can_buffer.h
can_buffer_get_dequeue_ptr
can_t * can_buffer_get_dequeue_ptr(can_buffer_t *buf)
uavcan::uint8_t
std::uint8_t uint8_t
Definition:
std.hpp:24
can_private.h
can_buffer_enqueue
void can_buffer_enqueue(can_buffer_t *buf)
can_buffer_t
Definition:
can_buffer.h:39
can_buffer_t::tail
uint8_t tail
Definition:
can_buffer.h:45
can_buffer_init
void can_buffer_init(can_buffer_t *buf, uint8_t size, can_t *list)
NULL
#define NULL
Nullzeiger.
Definition:
utils.h:64
LEAVE_CRITICAL_SECTION
#define LEAVE_CRITICAL_SECTION
Definition:
utils.h:127
can_buffer_t::head
uint8_t head
Definition:
can_buffer.h:44
can_buffer_t::used
uint8_t used
Definition:
can_buffer.h:43
can_buffer_full
bool can_buffer_full(can_buffer_t *buf)
uavcan_communicator
Author(s):
autogenerated on Fri Dec 13 2024 03:10:02