]> git.cryptolib.org Git - avr-crypto-lib.git/blobdiff - test_src/circularbytebuffer.h
new skipjack test
[avr-crypto-lib.git] / test_src / circularbytebuffer.h
index d1e40e4c8dca70663925e8ff597af4cf82a7120f..9f2900328dfde17a497c214d17288db58473e0dd 100644 (file)
 /**
  * \file     circularbytebuffer.h
  * \email    daniel.otte@rub.de
- * \author   Daniel Otte 
+ * \author   Daniel Otte
  * \date     2009-07-24
  * \license  GPLv3 or later
- * \ingroup  circularbytebuffer
+ * \addtogroup  circularbytebuffer
  * \brief    declaration for circular byte buffer
  */
+/*@{*/
 #ifndef CIRCULARBYTEBUFFER_H_
 #define CIRCULARBYTEBUFFER_H_
 
 #include <stdint.h>
 #include <stdlib.h>
 #include "config.h"
+ /**
+  * \brief type holding the managment information for the buffer
+  *
+  * A variable of this type may hold all the information to control the buffer
+  */
  typedef struct {
-        uint8_t buffer_size;
-        uint8_t fillcount;
-        uint8_t* buffer;
-        uint8_t* head;
-        uint8_t* tail;
-        uint8_t* top;
+        uint8_t buffer_size; /**< holds the amount of bytes which may be stored in the buffer */
+        uint8_t fillcount; /**< holds the amount of bytes actually stored in the buffer */
+        uint8_t* buffer; /**< pointer to the actual  buffer */
+        uint8_t* head; /**< pointer to the head of the buffer */
+        uint8_t* tail; /**< pointer to the tail of the buffer */
+        uint8_t* top; /**< pointer to the last free address in the buffer */
 } circularbytebuffer_t;
 
 
 #if CIRCULARBYTEBUFFER_NO_MALLOC==0
+/** \brief buffer initialisation with automatic allocation
+ *
+ * This function initializes the given buffer context and allocates memory for
+ * it by calling malloc.
+ * \param buffersize size of the buffer to allocate
+ * \param cb buffer context to be initialized
+ */
 uint8_t circularbytebuffer_init(uint8_t buffersize, circularbytebuffer_t* cb);
 #endif
 #if CIRCULARBYTEBUFFER_NO_INIT2==0
+/** \brief buffer initialisation without automatic allocation
+ *
+ * This function initializes the given buffer context and uses the given buffer
+ * for storage, so no malloc is needed.
+ * \param buffersize size of the buffer
+ * \param cb buffer context to be initialized
+ * \param buffer buffer for the storage of data (you are responisble for allocation and freeing)
+ */
 void    circularbytebuffer_init2(uint8_t buffersize, circularbytebuffer_t* cb, void* buffer);
 #endif
+/** \brief
+ *
+ *
+ */
 uint16_t circularbytebuffer_get_lifo(circularbytebuffer_t* cb);
 uint16_t circularbytebuffer_get_fifo(circularbytebuffer_t* cb);
 uint8_t circularbytebuffer_append(uint8_t, circularbytebuffer_t* cb);
@@ -56,4 +79,5 @@ uint8_t circularbytebuffer_push(uint8_t, circularbytebuffer_t* cb);
 uint8_t circularbytebuffer_cnt(circularbytebuffer_t* cb);
 void circularbytebuffer_free(circularbytebuffer_t* cb);
 
+/*@}*/
 #endif /* CIRCULARBYTEBUFFER_H_ */