2015-12-03 21:30:38 +00:00
|
|
|
#ifndef __IOAT_IMPL_H__
|
|
|
|
#define __IOAT_IMPL_H__
|
|
|
|
|
|
|
|
#include <pthread.h>
|
|
|
|
#include <stdio.h>
|
2016-02-03 19:57:51 +00:00
|
|
|
#include <stdbool.h>
|
2016-08-12 00:47:00 +00:00
|
|
|
#include <string.h>
|
2015-12-03 21:30:38 +00:00
|
|
|
#include <rte_config.h>
|
2016-02-16 17:46:37 +00:00
|
|
|
#include <rte_malloc.h>
|
2015-12-03 21:30:38 +00:00
|
|
|
#include <rte_atomic.h>
|
|
|
|
#include <rte_cycles.h>
|
|
|
|
|
2016-08-08 20:55:27 +00:00
|
|
|
#include "spdk/assert.h"
|
2016-02-03 22:00:39 +00:00
|
|
|
#include "spdk/pci.h"
|
2016-08-10 17:21:45 +00:00
|
|
|
#include "spdk/env.h"
|
2016-02-03 19:57:51 +00:00
|
|
|
|
2016-02-03 21:36:26 +00:00
|
|
|
#include <rte_pci.h>
|
|
|
|
|
2015-12-03 21:30:38 +00:00
|
|
|
/**
|
|
|
|
* \file
|
|
|
|
*
|
|
|
|
* This file describes the functions required to integrate
|
|
|
|
* the userspace IOAT driver for a specific implementation. This
|
|
|
|
* implementation is specific for DPDK. Users would revise it as
|
|
|
|
* necessary for their own particular environment if not using it
|
|
|
|
* within the SPDK framework.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocate a pinned, physically contiguous memory buffer with the
|
|
|
|
* given size and alignment.
|
|
|
|
*/
|
|
|
|
static inline void *
|
|
|
|
ioat_zmalloc(const char *tag, size_t size, unsigned align, uint64_t *phys_addr)
|
|
|
|
{
|
2016-08-12 00:47:00 +00:00
|
|
|
void *buf = rte_malloc(tag, size, align);
|
|
|
|
|
|
|
|
if (buf) {
|
|
|
|
memset(buf, 0, size);
|
|
|
|
*phys_addr = rte_malloc_virt2phy(buf);
|
|
|
|
}
|
2015-12-03 21:30:38 +00:00
|
|
|
return buf;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Free a memory buffer previously allocated with ioat_zmalloc.
|
|
|
|
*/
|
|
|
|
#define ioat_free(buf) rte_free(buf)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the physical address for the specified virtual address.
|
|
|
|
*/
|
2016-02-08 21:17:04 +00:00
|
|
|
#define ioat_vtophys(buf) spdk_vtophys(buf)
|
2015-12-03 21:30:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Delay us.
|
|
|
|
*/
|
|
|
|
#define ioat_delay_us(us) rte_delay_us(us)
|
|
|
|
|
|
|
|
#endif /* __IOAT_IMPL_H__ */
|