vtophys: add function to dynamically allocate maps

Change-Id: I335a8712416576fecdde96cfb47baf83ea4f15e5
Signed-off-by: Daniel Verkamp <daniel.verkamp@intel.com>
This commit is contained in:
Daniel Verkamp 2017-03-01 14:43:41 -07:00
parent b98eb28d85
commit 4055a502ea

View File

@ -98,7 +98,27 @@ struct spdk_mem_map {
uint64_t default_translation; uint64_t default_translation;
}; };
static struct spdk_mem_map g_vtophys_map = {{}, PTHREAD_MUTEX_INITIALIZER, SPDK_VTOPHYS_ERROR}; static struct spdk_mem_map *g_vtophys_map;
static struct spdk_mem_map *
spdk_mem_map_alloc(uint64_t default_translation)
{
struct spdk_mem_map *map;
map = calloc(1, sizeof(*map));
if (map == NULL) {
return NULL;
}
if (pthread_mutex_init(&map->mutex, NULL)) {
free(map);
return NULL;
}
map->default_translation = default_translation;
return map;
}
static struct map_1gb * static struct map_1gb *
spdk_mem_map_get_map_1gb(struct spdk_mem_map *map, uint64_t vfn_2mb) spdk_mem_map_get_map_1gb(struct spdk_mem_map *map, uint64_t vfn_2mb)
@ -313,13 +333,13 @@ _spdk_vtophys_register_one(uint64_t vfn_2mb, uint64_t paddr)
return; return;
} }
spdk_mem_map_register(&g_vtophys_map, vfn_2mb << SHIFT_2MB, 2 * 1024 * 1024, paddr); spdk_mem_map_register(g_vtophys_map, vfn_2mb << SHIFT_2MB, 2 * 1024 * 1024, paddr);
} }
static void static void
_spdk_vtophys_unregister_one(uint64_t vfn_2mb) _spdk_vtophys_unregister_one(uint64_t vfn_2mb)
{ {
spdk_mem_map_unregister(&g_vtophys_map, vfn_2mb << SHIFT_2MB, 2 * 1024 * 1024); spdk_mem_map_unregister(g_vtophys_map, vfn_2mb << SHIFT_2MB, 2 * 1024 * 1024);
} }
void void
@ -398,6 +418,12 @@ spdk_vtophys_register_dpdk_mem(void)
struct rte_mem_config *mcfg; struct rte_mem_config *mcfg;
size_t seg_idx; size_t seg_idx;
g_vtophys_map = spdk_mem_map_alloc(SPDK_VTOPHYS_ERROR);
if (g_vtophys_map == NULL) {
fprintf(stderr, "vtophys map allocation failed\n");
abort();
}
mcfg = rte_eal_get_configuration()->mem_config; mcfg = rte_eal_get_configuration()->mem_config;
for (seg_idx = 0; seg_idx < RTE_MAX_MEMSEG; seg_idx++) { for (seg_idx = 0; seg_idx < RTE_MAX_MEMSEG; seg_idx++) {
@ -418,7 +444,7 @@ spdk_vtophys(void *buf)
vaddr = (uint64_t)buf; vaddr = (uint64_t)buf;
paddr_2mb = spdk_mem_map_translate(&g_vtophys_map, vaddr); paddr_2mb = spdk_mem_map_translate(g_vtophys_map, vaddr);
/* /*
* SPDK_VTOPHYS_ERROR has all bits set, so if the lookup returned SPDK_VTOPHYS_ERROR, * SPDK_VTOPHYS_ERROR has all bits set, so if the lookup returned SPDK_VTOPHYS_ERROR,