Blame test/Allocator.hpp

Packit Service 7f3b24
// SPDX-License-Identifier: BSD-2-Clause
Packit Service 7f3b24
/* Copyright (C) 2017 - 2020 Intel Corporation. */
Packit 345191
#pragma once
Packit 345191
Packit 345191
#include <stdio.h>
Packit 345191
#include <assert.h>
Packit 345191
#include <map>
Packit 345191
#include <iterator>
Packit 345191
Packit 345191
class Allocator
Packit 345191
{
Packit 345191
public:
Packit 345191
Packit 345191
    virtual void *malloc(size_t size) = 0;
Packit 345191
    virtual void *calloc(size_t num, size_t size) = 0;
Packit 345191
    virtual void *realloc(void *ptr, size_t size) = 0;
Packit 345191
    virtual int memalign(void **ptr, size_t alignment, size_t size) = 0;
Packit 345191
    virtual void free(void *ptr) = 0;
Packit 345191
Packit 345191
    /* get_numa_policy() returns MPOL_INTERLEAVE, MPOL_BIND, MPOL_PREFERRED
Packit 345191
     or -1 when the allocator is not providing NUMA policy */
Packit 345191
    virtual int get_numa_policy() = 0;
Packit 345191
    virtual bool is_high_bandwidth() = 0;
Packit 345191
    virtual size_t get_page_size() = 0;
Packit 345191
Packit 345191
    virtual ~Allocator(void) {}
Packit 345191
};
Packit 345191
Packit 345191
class MemkindAllocator : public Allocator
Packit 345191
{
Packit 345191
public:
Packit 345191
Packit 345191
    MemkindAllocator(memkind_memtype_t memtype, memkind_policy_t policy,
Packit 345191
                     memkind_bits_t flags) :
Packit 345191
        memtype(memtype),
Packit 345191
        flags(flags)
Packit 345191
    {
Packit 345191
        int ret = memkind_create_kind(memtype, policy, flags, &kind);
Packit 345191
        assert(ret == MEMKIND_SUCCESS);
Packit 345191
        assert(kind != NULL);
Packit 345191
    }
Packit 345191
Packit 345191
    MemkindAllocator(memkind_t kind) : kind(kind)
Packit 345191
    {
Packit 345191
        assert(kind != NULL);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual void *malloc(size_t size)
Packit 345191
    {
Packit 345191
        return memkind_malloc(kind, size);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual void *calloc(size_t num, size_t size)
Packit 345191
    {
Packit 345191
        return memkind_calloc(kind, num, size);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual void *realloc(void *ptr, size_t size)
Packit 345191
    {
Packit 345191
        return memkind_realloc(kind, ptr, size);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual int memalign(void **ptr, size_t alignment, size_t size)
Packit 345191
    {
Packit 345191
        return memkind_posix_memalign(kind, ptr, alignment, size);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual void free(void *ptr)
Packit 345191
    {
Packit 345191
        memkind_free(kind, ptr);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual int get_numa_policy()
Packit 345191
    {
Packit 345191
        static std::map<memkind_t, int> kind_policy = {
Packit 345191
            std::make_pair(MEMKIND_HBW_INTERLEAVE, MPOL_INTERLEAVE),
Packit 345191
            std::make_pair(MEMKIND_INTERLEAVE, MPOL_INTERLEAVE),
Packit 345191
            std::make_pair(MEMKIND_HBW_PREFERRED, MPOL_PREFERRED),
Packit 345191
            std::make_pair(MEMKIND_HBW_PREFERRED_HUGETLB, MPOL_PREFERRED),
Packit 345191
            std::make_pair(MEMKIND_HBW, MPOL_BIND),
Packit 345191
            std::make_pair(MEMKIND_HBW_HUGETLB, MPOL_BIND),
Packit 345191
            std::make_pair(MEMKIND_REGULAR, MPOL_BIND),
Packit 345191
            std::make_pair(MEMKIND_DEFAULT, MPOL_DEFAULT),
Packit 345191
            std::make_pair(MEMKIND_HUGETLB, MPOL_DEFAULT),
Packit 345191
            std::make_pair(MEMKIND_HBW_ALL_HUGETLB, MPOL_BIND),
Packit 345191
            std::make_pair(MEMKIND_HBW_ALL, MPOL_BIND)
Packit 345191
        };
Packit 345191
        auto it = kind_policy.find(kind);
Packit 345191
Packit 345191
        if(it != std::end(kind_policy)) {
Packit 345191
            return it->second;
Packit 345191
        }
Packit 345191
        return -1;
Packit 345191
    }
Packit 345191
Packit 345191
    virtual bool is_high_bandwidth()
Packit 345191
    {
Packit 345191
        return  memtype == MEMKIND_MEMTYPE_HIGH_BANDWIDTH ||
Packit 345191
                kind == MEMKIND_HBW ||
Packit 345191
                kind == MEMKIND_HBW_HUGETLB ||
Packit 345191
                kind == MEMKIND_HBW_PREFERRED ||
Packit 345191
                kind == MEMKIND_HBW_INTERLEAVE;
Packit 345191
    }
Packit 345191
Packit 345191
    virtual size_t get_page_size()
Packit 345191
    {
Packit 345191
        if (kind == MEMKIND_HUGETLB ||
Packit 345191
            kind == MEMKIND_HBW_HUGETLB ||
Packit 345191
            kind == MEMKIND_HBW_PREFERRED_HUGETLB ||
Packit 345191
            (flags & MEMKIND_MASK_PAGE_SIZE_2MB)) {
Packit 345191
            return 2*MB;
Packit 345191
        }
Packit 345191
        return 4*KB;
Packit 345191
    }
Packit 345191
Packit 345191
    virtual ~MemkindAllocator()
Packit 345191
    {
Packit 345191
        int ret = memkind_destroy_kind(kind);
Packit 345191
        assert(ret == MEMKIND_SUCCESS);
Packit 345191
        kind = NULL;
Packit 345191
    }
Packit 345191
Packit 345191
private:
Packit 345191
    memkind_t kind = NULL;
Packit 345191
    memkind_memtype_t memtype = memkind_memtype_t();
Packit 345191
    memkind_bits_t flags = memkind_bits_t();
Packit 345191
};
Packit 345191
Packit 345191
class HbwmallocAllocator : public Allocator
Packit 345191
{
Packit 345191
public:
Packit 345191
Packit 345191
    HbwmallocAllocator(hbw_policy_t hbw_policy)
Packit 345191
    {
Packit 345191
        hbw_set_policy(hbw_policy);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual void *malloc(size_t size)
Packit 345191
    {
Packit 345191
        return hbw_malloc(size);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual void *calloc(size_t num, size_t size)
Packit 345191
    {
Packit 345191
        return hbw_calloc(num, size);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual void *realloc(void *ptr, size_t size)
Packit 345191
    {
Packit 345191
        return hbw_realloc(ptr, size);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual void set_memalign_page_size(hbw_pagesize_t psize)
Packit 345191
    {
Packit 345191
        page_size = psize;
Packit 345191
    }
Packit 345191
Packit 345191
    virtual int memalign(void **ptr, size_t alignment, size_t size)
Packit 345191
    {
Packit 345191
        if (page_size == HBW_PAGESIZE_4KB) {
Packit 345191
            return hbw_posix_memalign(ptr, alignment, size);
Packit 345191
        } else {
Packit 345191
            return hbw_posix_memalign_psize(ptr, alignment, size, page_size);
Packit 345191
        }
Packit 345191
    }
Packit 345191
Packit 345191
    virtual void free(void *ptr)
Packit 345191
    {
Packit 345191
        hbw_free(ptr);
Packit 345191
    }
Packit 345191
Packit 345191
    virtual int get_numa_policy()
Packit 345191
    {
Packit 345191
        if (hbw_get_policy() == HBW_POLICY_INTERLEAVE) {
Packit 345191
            return MPOL_INTERLEAVE;
Packit 345191
        } else if (hbw_get_policy() == HBW_POLICY_PREFERRED) {
Packit 345191
            return MPOL_PREFERRED;
Packit 345191
        } else if (hbw_get_policy() == HBW_POLICY_BIND ||
Packit 345191
                   hbw_get_policy() == HBW_POLICY_BIND_ALL) {
Packit 345191
            return MPOL_BIND;
Packit 345191
        }
Packit 345191
        return -1;
Packit 345191
    }
Packit 345191
Packit 345191
    virtual bool is_high_bandwidth()
Packit 345191
    {
Packit 345191
        return  hbw_check_available() == 0;
Packit 345191
    }
Packit 345191
Packit 345191
    virtual size_t get_page_size()
Packit 345191
    {
Packit 345191
        if (page_size == HBW_PAGESIZE_2MB) {
Packit 345191
            return 2*MB;
Packit 345191
        }
Packit 345191
        return 4*KB;
Packit 345191
    }
Packit 345191
Packit 345191
private:
Packit 345191
    hbw_pagesize_t page_size = HBW_PAGESIZE_4KB;
Packit 345191
};
Packit 345191