Слияние кода завершено, страница обновится автоматически
/*!
* \file fifo.h
*
* \brief FIFO buffer implementation
*
* \copyright Revised BSD License, see section \ref LICENSE.
*
* \code
* ______ _
* / _____) _ | |
* ( (____ _____ ____ _| |_ _____ ____| |__
* \____ \| ___ | (_ _) ___ |/ ___) _ \
* _____) ) ____| | | || |_| ____( (___| | | |
* (______/|_____)_|_|_| \__)_____)\____)_| |_|
* (C)2013-2017 Semtech
*
* \endcode
*
* \author Miguel Luis ( Semtech )
*
* \author Gregory Cristian ( Semtech )
*/
#include "fifo.h"
static uint16_t FifoNext( Fifo_t *fifo, uint16_t index )
{
return ( index + 1 ) % fifo->Size;
}
void FifoInit( Fifo_t *fifo, uint8_t *buffer, uint16_t size )
{
fifo->Begin = 0;
fifo->End = 0;
fifo->Data = buffer;
fifo->Size = size;
}
void FifoPush( Fifo_t *fifo, uint8_t data )
{
fifo->End = FifoNext( fifo, fifo->End );
fifo->Data[fifo->End] = data;
}
uint8_t FifoPop( Fifo_t *fifo )
{
uint8_t data = fifo->Data[FifoNext( fifo, fifo->Begin )];
fifo->Begin = FifoNext( fifo, fifo->Begin );
return data;
}
void FifoFlush( Fifo_t *fifo )
{
fifo->Begin = 0;
fifo->End = 0;
}
bool IsFifoEmpty( Fifo_t *fifo )
{
return ( fifo->Begin == fifo->End );
}
bool IsFifoFull( Fifo_t *fifo )
{
return ( FifoNext( fifo, fifo->End ) == fifo->Begin );
}
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Комментарий ( 0 )