X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;ds=sidebyside;f=drivers%2Fnet%2Fnfb%2Fnfb_rx.h;h=638205d53c765428766ae3c68af4e4f65deeaf4f;hb=768d1e44dfa50a5c26d04e362d46773dde5932be;hp=cf3899b2fb7d298258d89670d98b265066db68bf;hpb=9c7fd48fee8ee1a1eaa79d584b93c18b9b9eccc8;p=dpdk.git diff --git a/drivers/net/nfb/nfb_rx.h b/drivers/net/nfb/nfb_rx.h index cf3899b2fb..638205d53c 100644 --- a/drivers/net/nfb/nfb_rx.h +++ b/drivers/net/nfb/nfb_rx.h @@ -11,10 +11,21 @@ #include #include +#include #include #define NFB_TIMESTAMP_FLAG (1 << 0) +extern uint64_t nfb_timestamp_rx_dynflag; +extern int nfb_timestamp_dynfield_offset; + +static inline rte_mbuf_timestamp_t * +nfb_timestamp_dynfield(struct rte_mbuf *mbuf) +{ + return RTE_MBUF_DYNFIELD(mbuf, + nfb_timestamp_dynfield_offset, rte_mbuf_timestamp_t *); +} + struct ndp_rx_queue { struct nfb_device *nfb; /* nfb dev structure */ struct ndp_queue *queue; /* rx queue */ @@ -83,11 +94,13 @@ nfb_eth_rx_queue_setup(struct rte_eth_dev *dev, /** * DPDK callback to release a RX queue. * - * @param dpdk_rxq - * Generic RX queue pointer. + * @param dev + * Pointer to Ethernet device structure. + * @param qid + * Receive queue index. */ void -nfb_eth_rx_queue_release(void *q); +nfb_eth_rx_queue_release(struct rte_eth_dev *dev, uint16_t qid); /** * Start traffic on Rx queue. @@ -190,16 +203,19 @@ nfb_eth_ndp_rx(void *queue, mbuf->ol_flags = 0; if (timestamping_enabled) { + rte_mbuf_timestamp_t timestamp; + /* nanoseconds */ - mbuf->timestamp = + timestamp = rte_le_to_cpu_32(*((uint32_t *) (packets[i].header + 4))); - mbuf->timestamp <<= 32; + timestamp <<= 32; /* seconds */ - mbuf->timestamp |= + timestamp |= rte_le_to_cpu_32(*((uint32_t *) (packets[i].header + 8))); - mbuf->ol_flags |= PKT_RX_TIMESTAMP; + *nfb_timestamp_dynfield(mbuf) = timestamp; + mbuf->ol_flags |= nfb_timestamp_rx_dynflag; } bufs[num_rx++] = mbuf;