/* * Copyright (C) 2017-2020 Intel Corporation * * SPDX-License-Identifier: MIT * */ #pragma once #include "shared/source/gmm_helper/gmm_lib.h" #include "External/Common/GmmPageTableMgr.h" #include #include namespace NEO { class Gmm; class GmmClientContext; class LinearStream; class GmmPageTableMngr { public: MOCKABLE_VIRTUAL ~GmmPageTableMngr(); static GmmPageTableMngr *create(GmmClientContext *clientContext, unsigned int translationTableFlags, GMM_TRANSLATIONTABLE_CALLBACKS *translationTableCb); MOCKABLE_VIRTUAL void setCsrHandle(void *csrHandle); bool updateAuxTable(uint64_t gpuVa, Gmm *gmm, bool map); bool initPageTableManagerRegisters(void *csrHandle); protected: GmmPageTableMngr() = default; MOCKABLE_VIRTUAL GMM_STATUS updateAuxTable(const GMM_DDI_UPDATEAUXTABLE *ddiUpdateAuxTable) { return pageTableManager->UpdateAuxTable(ddiUpdateAuxTable); } MOCKABLE_VIRTUAL GMM_STATUS initContextAuxTableRegister(HANDLE initialBBHandle, GMM_ENGINE_TYPE engineType) { return pageTableManager->InitContextAuxTableRegister(initialBBHandle, engineType); } GmmPageTableMngr(GmmClientContext *clientContext, unsigned int translationTableFlags, GMM_TRANSLATIONTABLE_CALLBACKS *translationTableCb); GMM_CLIENT_CONTEXT *clientContext = nullptr; GMM_PAGETABLE_MGR *pageTableManager = nullptr; }; } // namespace NEO