FreeRTOS C-Addons  1.1.0
C-Addon functionality to FreeRTOS
queue_simple.c
Go to the documentation of this file.
1 /****************************************************************************
2  *
3  * Copyright (c) 2017, Michael Becker (michael.f.becker@gmail.com)
4  *
5  * This file is part of the FreeRTOS Add-ons project.
6  *
7  * Source Code:
8  * https://github.com/michaelbecker/freertos-addons
9  *
10  * Project Page:
11  * http://michaelbecker.github.io/freertos-addons/
12  *
13  * On-line Documentation:
14  * http://michaelbecker.github.io/freertos-addons/docs/html/index.html
15  *
16  * Permission is hereby granted, free of charge, to any person obtaining a
17  * copy of this software and associated documentation files
18  * (the "Software"), to deal in the Software without restriction, including
19  * without limitation the rights to use, copy, modify, merge, publish,
20  * distribute, sublicense, and/or sell copies of the Software, and to
21  * permit persons to whom the Software is furnished to do so,subject to the
22  * following conditions:
23  *
24  * + The above copyright notice and this permission notice shall be included
25  * in all copies or substantial portions of the Software.
26  * + Credit is appreciated, but not required, if you find this project
27  * useful enough to include in your application, product, device, etc.
28  *
29  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
30  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
31  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
32  * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
33  * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
34  * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
35  * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
36  *
37  ***************************************************************************/
38 
39 
40 #include <stdlib.h>
41 #include "queue_simple.h"
42 
43 
44 void InitQueue(Queue_t *Queue)
45 {
46  if (Queue == NULL)
47  return;
48 
49  Queue->Count = 0;
50  DlInitHead(&Queue->Head);
51 }
52 
53 
54 void Enqueue(Queue_t *Queue, DlNode_t *Node)
55 {
56  if (Queue == NULL)
57  return;
58 
59  if (Node == NULL)
60  return;
61 
62  Queue->Count++;
63  DlAddNodeToHead(&Queue->Head, Node);
64 }
65 
66 
68 {
69  DlNode_t *Node;
70 
71  if (Queue == NULL)
72  return NULL;
73 
74  if (Queue->Count <= 0)
75  return NULL;
76 
77  Queue->Count--;
78  Node = DlRemoveNodeFromTail(&Queue->Head);
79 
80  return Node;
81 }
82 
83 
DlNode_t * Dequeue(Queue_t *Queue)
Definition: queue_simple.c:67
void DlAddNodeToHead(DlNode_t *Head, DlNode_t *Node)
Definition: dlist.c:68
DlNode_t * DlRemoveNodeFromTail(DlNode_t *Head)
Definition: dlist.c:112
void InitQueue(Queue_t *Queue)
Definition: queue_simple.c:44
void Enqueue(Queue_t *Queue, DlNode_t *Node)
Definition: queue_simple.c:54
#define DlInitHead(_head)
Definition: dlist.h:73
DlNode_t Head
Definition: queue_simple.h:58