f-stack/dpdk/lib/librte_eal/linuxapp/kni/kni_fifo.h

95 lines
2.3 KiB
C
Raw Normal View History

/*-
* GPL LICENSE SUMMARY
*
* Copyright(c) 2010-2014 Intel Corporation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
* The full GNU General Public License is included in this distribution
* in the file called LICENSE.GPL.
*
* Contact Information:
* Intel Corporation
2017-04-21 10:43:26 +00:00
*/
#ifndef _KNI_FIFO_H_
#define _KNI_FIFO_H_
#include <exec-env/rte_kni_common.h>
/**
* Adds num elements into the fifo. Return the number actually written
*/
static inline uint32_t
kni_fifo_put(struct rte_kni_fifo *fifo, void **data, uint32_t num)
2017-04-21 10:43:26 +00:00
{
uint32_t i = 0;
uint32_t fifo_write = fifo->write;
uint32_t fifo_read = fifo->read;
uint32_t new_write = fifo_write;
2017-04-21 10:43:26 +00:00
for (i = 0; i < num; i++) {
new_write = (new_write + 1) & (fifo->len - 1);
if (new_write == fifo_read)
break;
fifo->buffer[fifo_write] = data[i];
fifo_write = new_write;
}
fifo->write = fifo_write;
2017-04-21 10:43:26 +00:00
return i;
}
/**
* Get up to num elements from the fifo. Return the number actully read
*/
static inline uint32_t
kni_fifo_get(struct rte_kni_fifo *fifo, void **data, uint32_t num)
2017-04-21 10:43:26 +00:00
{
uint32_t i = 0;
uint32_t new_read = fifo->read;
uint32_t fifo_write = fifo->write;
2017-04-21 10:43:26 +00:00
for (i = 0; i < num; i++) {
if (new_read == fifo_write)
break;
data[i] = fifo->buffer[new_read];
new_read = (new_read + 1) & (fifo->len - 1);
}
fifo->read = new_read;
2017-04-21 10:43:26 +00:00
return i;
}
/**
* Get the num of elements in the fifo
*/
static inline uint32_t
2017-04-21 10:43:26 +00:00
kni_fifo_count(struct rte_kni_fifo *fifo)
{
return (fifo->len + fifo->write - fifo->read) & (fifo->len - 1);
2017-04-21 10:43:26 +00:00
}
/**
* Get the num of available elements in the fifo
*/
static inline uint32_t
2017-04-21 10:43:26 +00:00
kni_fifo_free_count(struct rte_kni_fifo *fifo)
{
return (fifo->read - fifo->write - 1) & (fifo->len - 1);
2017-04-21 10:43:26 +00:00
}
#endif /* _KNI_FIFO_H_ */