xref: /libCEED/rust/libceed-sys/c-src/backends/memcheck/ceed-memcheck.h (revision 9937a20e594bfb4e867db08aa6f5f4a7e0ba1b8e)
15aed82e4SJeremy L Thompson // Copyright (c) 2017-2024, 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.
3fc7cf9a0Sjeremylt //
43d8e8822SJeremy L Thompson // SPDX-License-Identifier: BSD-2-Clause
5fc7cf9a0Sjeremylt //
63d8e8822SJeremy L Thompson // This file is part of CEED:  http://github.com/ceed
7509d4af6SJeremy L Thompson #pragma once
83d576824SJeremy L Thompson 
949aac155SJeremy L Thompson #include <ceed.h>
10ec3da8bcSJed Brown #include <ceed/backend.h>
11fc7cf9a0Sjeremylt 
12fc7cf9a0Sjeremylt typedef struct {
13*9937a20eSJeremy L Thompson   // Internal array buffer
14*9937a20eSJeremy L Thompson   int         allocated_block_id;
159798701eSJeremy L Thompson   CeedScalar *array_allocated;
16*9937a20eSJeremy L Thompson   // Owned external array
17*9937a20eSJeremy L Thompson   int         owned_block_id;
189798701eSJeremy L Thompson   CeedScalar *array_owned;
19*9937a20eSJeremy L Thompson   // Borrowed external array
20*9937a20eSJeremy L Thompson   int         borrowed_block_id;
219798701eSJeremy L Thompson   CeedScalar *array_borrowed;
22*9937a20eSJeremy L Thompson   // Externally viewable read-only array
23*9937a20eSJeremy L Thompson   int         read_only_block_id;
249798701eSJeremy L Thompson   CeedScalar *array_read_only_copy;
25*9937a20eSJeremy L Thompson   // Externally viewable writable array
26*9937a20eSJeremy L Thompson   bool        is_write_only_access;
27*9937a20eSJeremy L Thompson   int         writable_block_id;
281a3e18b3SJeremy L Thompson   CeedScalar *array_writable_copy;
299798701eSJeremy L Thompson } CeedVector_Memcheck;
309798701eSJeremy L Thompson 
319798701eSJeremy L Thompson typedef struct {
329e82028bSJeremy L Thompson   const CeedInt  *offsets;
339e82028bSJeremy L Thompson   CeedInt        *offsets_allocated;
349e82028bSJeremy L Thompson   const bool     *orients; /* Orientation, if it exists, is true when the dof must be flipped */
359e82028bSJeremy L Thompson   bool           *orients_allocated;
369e82028bSJeremy L Thompson   const CeedInt8 *curl_orients; /* Tridiagonal matrix (row-major) for a general transformation during restriction */
379e82028bSJeremy L Thompson   CeedInt8       *curl_orients_allocated;
389e82028bSJeremy L Thompson   int (*Apply)(CeedElemRestriction, CeedInt, CeedInt, CeedInt, CeedInt, CeedInt, CeedTransposeMode, bool, bool, CeedVector, CeedVector,
399e82028bSJeremy L Thompson                CeedRequest *);
409e82028bSJeremy L Thompson } CeedElemRestriction_Memcheck;
419e82028bSJeremy L Thompson 
429e82028bSJeremy L Thompson typedef struct {
43fc7cf9a0Sjeremylt   const CeedScalar **inputs;
44fc7cf9a0Sjeremylt   CeedScalar       **outputs;
45d1d35e2fSjeremylt   bool               setup_done;
46fc7cf9a0Sjeremylt } CeedQFunction_Memcheck;
47fc7cf9a0Sjeremylt 
480f58c348SJeremy L Thompson typedef struct {
490f58c348SJeremy L Thompson   int   mem_block_id;
500f58c348SJeremy L Thompson   void *data;
510f58c348SJeremy L Thompson   void *data_allocated;
520f58c348SJeremy L Thompson   void *data_owned;
538e457467SJeremy L Thompson   void *data_borrowed;
548e457467SJeremy L Thompson   void *data_read_only_copy;
550f58c348SJeremy L Thompson } CeedQFunctionContext_Memcheck;
560f58c348SJeremy L Thompson 
579798701eSJeremy L Thompson CEED_INTERN int CeedVectorCreate_Memcheck(CeedSize n, CeedVector vec);
589798701eSJeremy L Thompson 
599e82028bSJeremy L Thompson CEED_INTERN int CeedElemRestrictionCreate_Memcheck(CeedMemType mem_type, CeedCopyMode copy_mode, const CeedInt *offsets, const bool *orients,
609e82028bSJeremy L Thompson                                                    const CeedInt8 *curl_orients, CeedElemRestriction r);
619e82028bSJeremy L Thompson 
62fc7cf9a0Sjeremylt CEED_INTERN int CeedQFunctionCreate_Memcheck(CeedQFunction qf);
633d576824SJeremy L Thompson 
640f58c348SJeremy L Thompson CEED_INTERN int CeedQFunctionContextCreate_Memcheck(CeedQFunctionContext ctx);
65