170 MPI_Group c_domain_group;
257cs_halo_create_from_rank_neighbors
259 const cs_rank_neighbors_t *rn,
262 const int elt_rank_idx[],
264 const int16_t elt_tr_id[],
287cs_halo_create_from_rank_neighbors
289 const cs_rank_neighbors_t *rn,
292 const int elt_rank_idx[],
458#if defined(HAVE_ACCEL)
483cs_halo_sync_pack_d(
const cs_halo_t *halo,
561#if defined(HAVE_ACCEL)
778#if defined(__cplusplus)
809template <
int Str
ide,
typename T>
840template <
int Str
ide,
typename T>
973template<
typename T,
int N>
979 [[maybe_unused]]
bool on_device,
983 static_assert(N == 1 || N == 2,
984 "Only possible for arrays of dim 1 or 2.");
991 T *val = span.
data();
993 int Stride = (N == 1) ? 1 : span.
extent(1);
995#if defined(HAVE_ACCEL)
997 cs_halo_sync_pack_d(halo,
1019template<
typename T,
int N>
1024 [[maybe_unused]]
bool on_device,
1031template<
typename T,
int N>
1041 cs_halo_sync<T, N>(halo, sync_mode, on_device, span);
1044template<
typename T,
int N>
1059template<
typename T,
int N>
1065 [[maybe_unused]]
bool on_device,
1069 cs_halo_sync<T, N>(halo, sync_mode, on_device, array.
view());
1072template<
typename T,
int N>
1077 [[maybe_unused]]
bool on_device,
1084template<
typename T,
int N>
1094 cs_halo_sync<T, N>(halo, sync_mode, on_device, array.
view());
1097template<
typename T,
int N>
Definition: cs_array.h:1111
CS_F_HOST_DEVICE mdspan< T, N, L > view()
Get span view of array, same dimensions as array.
Definition: cs_array.h:1544
CS_F_HOST_DEVICE T * data()
Getter to data array.
Definition: cs_array.h:2263
Definition: cs_mdspan.h:69
CS_F_HOST_DEVICE cs_lnum_t extent(int i)
Getter for extent along a given dimension.
Definition: cs_mdspan.h:454
CS_F_HOST_DEVICE T * data()
Getter for data raw pointer.
Definition: cs_mdspan.h:490
const size_t cs_datatype_size[]
Definition: cs_defs.cpp:133
cs_datatype_t
Definition: cs_defs.h:315
#define BEGIN_C_DECLS
Definition: cs_defs.h:554
double cs_real_t
Floating-point value.
Definition: cs_defs.h:357
#define END_C_DECLS
Definition: cs_defs.h:555
int cs_lnum_t
local mesh entity id
Definition: cs_defs.h:350
bool cs_halo_get_use_barrier(void)
Definition: cs_halo.cpp:2400
void cs_halo_sync_pack(const cs_halo_t *halo, cs_halo_type_t sync_mode, cs_datatype_t data_type, int stride, void *val, void *send_buf, cs_halo_state_t *hs)
Pack halo data to send into dense buffer.
Definition: cs_halo.cpp:1727
cs_halo_state_t * cs_halo_state_create(void)
Create a halo state structure.
Definition: cs_halo.cpp:1347
cs_halo_comm_mode_t
Definition: cs_halo.h:67
@ CS_HALO_COMM_P2P
Definition: cs_halo.h:69
@ CS_HALO_COMM_RMA_GET
Definition: cs_halo.h:70
void cs_halo_state_destroy(cs_halo_state_t **halo_state)
Destroy a halo state structure.
Definition: cs_halo.cpp:1396
void cs_halo_sync_start(const cs_halo_t *halo, void *val, cs_halo_state_t *hs)
Launch update array of values in case of parallelism or periodicity.
Definition: cs_halo.cpp:1945
cs_halo_comm_mode_t cs_halo_get_comm_mode(void)
Get default communication mode for halo exchange.
Definition: cs_halo.cpp:2428
void cs_halo_sync(const cs_halo_t *halo, cs_halo_type_t sync_mode, cs_datatype_t data_type, int stride, void *val)
Update array of values in case of parallelism or periodicity.
Definition: cs_halo.cpp:2228
void * cs_halo_get_default_buffer(size_t size)
Return pointer to working send buffer used by default halo state.
Definition: cs_halo.cpp:2496
void cs_halo_set_comm_mode(cs_halo_comm_mode_t mode)
Set default communication mode for halo exchange.
Definition: cs_halo.cpp:2442
cs_alloc_mode_t cs_halo_get_buffer_alloc_mode(void)
Get default host/device allocation mode for message packing arrays.
Definition: cs_halo.cpp:2457
static size_t cs_halo_pack_size(const cs_halo_t *halo, cs_datatype_t data_type, int stride)
Compute required size for packing send data into dense buffer.
Definition: cs_halo.h:361
void cs_halo_renumber_cells(cs_halo_t *halo, const cs_lnum_t new_cell_id[])
Definition: cs_halo.cpp:1445
cs_halo_t * cs_halo_create_from_ref(const cs_halo_t *ref)
Create a halo structure, given a reference halo.
Definition: cs_halo.cpp:856
void cs_halo_dump(const cs_halo_t *halo, int print_level)
Definition: cs_halo.cpp:2523
cs_halo_t * cs_halo_create(const cs_interface_set_t *ifs)
Create a halo structure given an interface set.
Definition: cs_halo.cpp:600
void cs_halo_sync_wait(const cs_halo_t *halo, void *val, cs_halo_state_t *hs)
Wait for completion of update array of values in case of parallelism or periodicity.
Definition: cs_halo.cpp:2118
void cs_halo_set_use_barrier(bool use_barrier)
Definition: cs_halo.cpp:2414
cs_halo_type_t
Definition: cs_halo.h:57
@ CS_HALO_N_TYPES
Definition: cs_halo.h:61
@ CS_HALO_STANDARD
Definition: cs_halo.h:59
@ CS_HALO_EXTENDED
Definition: cs_halo.h:60
void * cs_halo_sync_pack_init_state(const cs_halo_t *halo, cs_halo_type_t sync_mode, cs_datatype_t data_type, int stride, void *send_buf, cs_halo_state_t *hs)
Initialize halo state prior to packing halo data to send.
Definition: cs_halo.cpp:1631
void cs_halo_create_complete(cs_halo_t *halo)
Ready halo for use.
Definition: cs_halo.cpp:745
void cs_halo_sync_untyped(const cs_halo_t *halo, cs_halo_type_t sync_mode, size_t size, void *val)
Definition: cs_halo.cpp:2316
cs_halo_state_t * cs_halo_state_get_default(void)
Get pointer to default halo state structure.
Definition: cs_halo.cpp:1431
void cs_halo_set_buffer_alloc_mode(cs_alloc_mode_t mode)
Set default host/device allocation mode for message packing arrays.
Definition: cs_halo.cpp:2471
void cs_halo_sync_var(const cs_halo_t *halo, cs_halo_type_t sync_mode, cs_real_t var[])
Definition: cs_halo.cpp:2360
void cs_halo_sync_num(const cs_halo_t *halo, cs_halo_type_t sync_mode, cs_lnum_t num[])
Definition: cs_halo.cpp:2338
void cs_halo_sync_r(const cs_halo_t *halo, cs_halo_type_t sync_mode, bool on_device, T val[][3])
Update ghost cell values of a spatial vector field, including rotational periodicity if present.
Definition: cs_halo.cpp:2860
void cs_halo_renumber_ghost_cells(cs_halo_t *halo, const cs_lnum_t old_cell_id[])
Definition: cs_halo.cpp:1469
void cs_halo_sync_var_strided(const cs_halo_t *halo, cs_halo_type_t sync_mode, cs_real_t var[], int stride)
Definition: cs_halo.cpp:2383
void cs_halo_destroy(cs_halo_t **halo)
Definition: cs_halo.cpp:1298
struct _cs_halo_state_t cs_halo_state_t
Definition: cs_halo.h:179
struct _cs_interface_set_t cs_interface_set_t
Definition: cs_interface.h:61
static bool cs_mem_is_device_ptr(const void *ptr)
Check if a pointer is a device (or shared) pointer.
Definition: cs_mem.h:764
cs_alloc_mode_t
Definition: cs_mem.h:50
struct _fvm_periodicity_t fvm_periodicity_t
Definition: fvm_periodicity.h:67
int n_transforms
Definition: cs_halo.h:81
cs_lnum_t * index
Definition: cs_halo.h:125
cs_lnum_t * send_list
Definition: cs_halo.h:99
cs_lnum_t * send_index
Definition: cs_halo.h:102
int n_rotations
Definition: cs_halo.h:88
cs_lnum_t * std_send_blocks
Definition: cs_halo.h:116
cs_lnum_t n_local_elts
Definition: cs_halo.h:91
cs_lnum_t n_std_send_blocks
Definition: cs_halo.h:114
int n_c_domains
Definition: cs_halo.h:80
int * c_domain_rank
Definition: cs_halo.h:83
cs_lnum_t * perio_lst
Definition: cs_halo.h:130
cs_lnum_t std_send_block_size
Definition: cs_halo.h:113
cs_lnum_t * send_perio_lst
Definition: cs_halo.h:107
const fvm_periodicity_t * periodicity
Definition: cs_halo.h:85
cs_lnum_t n_send_elts[2]
Definition: cs_halo.h:95