13d8e8822SJeremy L Thompson // Copyright (c) 2017-2022, Lawrence Livermore National Security, LLC and other CEED contributors. 23d8e8822SJeremy L Thompson // All Rights Reserved. See the top-level LICENSE and NOTICE files for details. 384a01de5SJeremy L Thompson // 43d8e8822SJeremy L Thompson // SPDX-License-Identifier: BSD-2-Clause 584a01de5SJeremy L Thompson // 63d8e8822SJeremy L Thompson // This file is part of CEED: http://github.com/ceed 784a01de5SJeremy L Thompson 8ec3da8bcSJed Brown #include <ceed/backend.h> 9*2b730f8bSJeremy L Thompson #include <ceed/ceed.h> 103d576824SJeremy L Thompson #include <stdbool.h> 113d576824SJeremy L Thompson #include <string.h> 12*2b730f8bSJeremy L Thompson 1384a01de5SJeremy L Thompson #include "ceed-avx.h" 1484a01de5SJeremy L Thompson 15f10650afSjeremylt //------------------------------------------------------------------------------ 16f10650afSjeremylt // Backend Init 17f10650afSjeremylt //------------------------------------------------------------------------------ 1884a01de5SJeremy L Thompson static int CeedInit_Avx(const char *resource, Ceed ceed) { 19*2b730f8bSJeremy L Thompson if (strcmp(resource, "/cpu/self") && strcmp(resource, "/cpu/self/avx/serial")) { 20c042f62fSJeremy L Thompson // LCOV_EXCL_START 21*2b730f8bSJeremy L Thompson return CeedError(ceed, CEED_ERROR_BACKEND, "AVX backend cannot use resource: %s", resource); 22c042f62fSJeremy L Thompson // LCOV_EXCL_STOP 23*2b730f8bSJeremy L Thompson } 24*2b730f8bSJeremy L Thompson CeedCallBackend(CeedSetDeterministic(ceed, true)); 2584a01de5SJeremy L Thompson 265f67fadeSJeremy L Thompson // Create reference CEED that implementation will be dispatched 2784a01de5SJeremy L Thompson // through unless overridden 28d1d35e2fSjeremylt Ceed ceed_ref; 29*2b730f8bSJeremy L Thompson CeedCallBackend(CeedInit("/cpu/self/opt/serial", &ceed_ref)); 30*2b730f8bSJeremy L Thompson CeedCallBackend(CeedSetDelegate(ceed, ceed_ref)); 3184a01de5SJeremy L Thompson 3280a9ef05SNatalie Beams if (CEED_SCALAR_TYPE == CEED_SCALAR_FP64) { 33*2b730f8bSJeremy L Thompson CeedCallBackend(CeedSetBackendFunction(ceed, "Ceed", ceed, "TensorContractCreate", CeedTensorContractCreate_f64_Avx)); 3480a9ef05SNatalie Beams } else { 35*2b730f8bSJeremy L Thompson CeedCallBackend(CeedSetBackendFunction(ceed, "Ceed", ceed, "TensorContractCreate", CeedTensorContractCreate_f32_Avx)); 3680a9ef05SNatalie Beams } 3780a9ef05SNatalie Beams 38e15f9bd0SJeremy L Thompson return CEED_ERROR_SUCCESS; 3984a01de5SJeremy L Thompson } 4084a01de5SJeremy L Thompson 41f10650afSjeremylt //------------------------------------------------------------------------------ 42f10650afSjeremylt // Backend Register 43f10650afSjeremylt //------------------------------------------------------------------------------ 44*2b730f8bSJeremy L Thompson CEED_INTERN int CeedRegister_Avx_Serial(void) { return CeedRegister("/cpu/self/avx/serial", CeedInit_Avx, 35); } 45f10650afSjeremylt //------------------------------------------------------------------------------ 46