|
|
|
/*
|
|
|
|
LUFA Library
|
|
|
|
Copyright (C) Dean Camera, 2010.
|
|
|
|
|
|
|
|
dean [at] fourwalledcubicle [dot] com
|
|
|
|
www.fourwalledcubicle.com
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
Copyright 2010 Dean Camera (dean [at] fourwalledcubicle [dot] com)
|
|
|
|
|
|
|
|
Permission to use, copy, modify, distribute, and sell this
|
|
|
|
software and its documentation for any purpose is hereby granted
|
|
|
|
without fee, provided that the above copyright notice appear in
|
|
|
|
all copies and that both that the copyright notice and this
|
|
|
|
permission notice and warranty disclaimer appear in supporting
|
|
|
|
documentation, and that the name of the author not be used in
|
|
|
|
advertising or publicity pertaining to distribution of the
|
|
|
|
software without specific, written prior permission.
|
|
|
|
|
|
|
|
The author disclaim all warranties with regard to this
|
|
|
|
software, including all implied warranties of merchantability
|
|
|
|
and fitness. In no event shall the author be liable for any
|
|
|
|
special, indirect or consequential damages or any damages
|
|
|
|
whatsoever resulting from loss of use, data or profits, whether
|
|
|
|
in an action of contract, negligence or other tortious action,
|
|
|
|
arising out of or in connection with the use or performance of
|
|
|
|
this software.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Buffer Configuration: */
|
|
|
|
/* Buffer length - select static size of created ring buffers: */
|
|
|
|
#define BUFF_STATICSIZE 255 // Set to the static ring buffer size for all ring buffers (place size after define)
|
|
|
|
|
|
|
|
/* Volatile mode - uncomment to make buffers volatile, for use in ISRs, etc: */
|
|
|
|
#define BUFF_VOLATILE // Uncomment to cause all ring buffers to become volatile (and atomic if multi-byte) in access
|
|
|
|
|
|
|
|
/* Drop mode - select behaviour when Buffer_StoreElement called on a full buffer: */
|
|
|
|
#define BUFF_DROPOLD // Uncomment to cause full ring buffers to drop the oldest character to make space when full
|
|
|
|
// #define BUFF_DROPNEW // Uncomment to cause full ring buffers to drop the new character when full
|
|
|
|
// #define BUFF_NODROPCHECK // Uncomment to ignore full ring buffer checks - checking left to user!
|
|
|
|
|
|
|
|
/* Underflow behaviour - select behaviour when Buffer_GetElement is called with an empty ring buffer: */
|
|
|
|
//#define BUFF_EMPTYRETURNSZERO // Uncomment to return 0 when an empty ring buffer is read
|
|
|
|
#define BUFF_NOEMPTYCHECK // Uncomment to disable checking of empty ring buffers - checking left to user!
|
|
|
|
|
|
|
|
/* Buffer storage type - set the datatype for the stored data */
|
|
|
|
#define BUFF_DATATYPE uint8_t // Change to the data type that is going to be stored into the buffer
|
|
|
|
|
|
|
|
/* Peek routine - uncomment to include the peek routine (fetches next byte without removing it from the buffer */
|
|
|
|
//#define BUFF_USEPEEK
|
|
|
|
|
|
|
|
#ifndef _RINGBUFF_H_
|
|
|
|
#define _RINGBUFF_H_
|
|
|
|
|
|
|
|
/* Includes: */
|
|
|
|
#include <avr/io.h>
|
|
|
|
#include <avr/interrupt.h>
|
|
|
|
#include <util/atomic.h>
|
|
|
|
#include <limits.h>
|
|
|
|
|
|
|
|
#include <LUFA/Common/Common.h>
|
|
|
|
|
|
|
|
/* Defines and checks: */
|
|
|
|
#if defined(BUFF_STATICSIZE)
|
|
|
|
#define BUFF_LENGTH BUFF_STATICSIZE
|
|
|
|
#else
|
|
|
|
#error No buffer length specified!
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !(defined(BUFF_DROPOLD) || defined(BUFF_DROPNEW) || defined(BUFF_NODROPCHECK))
|
|
|
|
#error No buffer drop mode specified.
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(BUFF_DATATYPE)
|
|
|
|
#error Ringbuffer storage data type not specified.
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(BUFF_VOLATILE)
|
|
|
|
#define BUFF_MODE volatile
|
|
|
|
#define BUFF_ATOMIC_BLOCK ATOMIC_BLOCK(ATOMIC_RESTORESTATE)
|
|
|
|
#else
|
|
|
|
#define BUFF_MODE
|
|
|
|
#define BUFF_ATOMIC_BLOCK
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if (BUFF_STATICSIZE > LONG_MAX)
|
|
|
|
#define RingBuff_Elements_t uint64_t
|
|
|
|
#elif (BUFF_STATICSIZE > INT_MAX)
|
|
|
|
#define RingBuff_Elements_t uint32_t
|
|
|
|
#elif (BUFF_STATICSIZE > CHAR_MAX)
|
|
|
|
#define RingBuff_Elements_t uint16_t
|
|
|
|
#else
|
|
|
|
#define RingBuff_Elements_t uint8_t
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Type Defines: */
|
|
|
|
typedef BUFF_DATATYPE RingBuff_Data_t;
|
|
|
|
|
|
|
|
typedef BUFF_MODE struct
|
|
|
|
{
|
|
|
|
RingBuff_Data_t Buffer[BUFF_LENGTH];
|
|
|
|
RingBuff_Data_t* InPtr;
|
|
|
|
RingBuff_Data_t* OutPtr;
|
|
|
|
RingBuff_Elements_t Elements;
|
|
|
|
} RingBuff_t;
|
|
|
|
|
|
|
|
/* Function Prototypes: */
|
|
|
|
void Buffer_Initialize(RingBuff_t* const Buff);
|
|
|
|
void Buffer_StoreElement(RingBuff_t* const Buffer, RingBuff_Data_t Data);
|
|
|
|
RingBuff_Data_t Buffer_GetElement(RingBuff_t* const Buffer);
|
|
|
|
#if defined(BUFF_USEPEEK)
|
|
|
|
RingBuff_Data_t Buffer_PeekElement(const RingBuff_t* const Buffer);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|