20#ifndef REALM_TRANSFER_H
21#define REALM_TRANSFER_H
56 virtual bool done(
void) = 0;
101 size_t field_offset,
int ndims,
const int64_t lo[],
102 const int64_t hi[],
const int order[]) = 0;
108 bool tentative =
false) = 0;
110 bool tentative =
false) = 0;
124 template <
int N,
typename T>
136 bool tentative =
false);
138 bool tentative =
false);
171 template <
int N,
typename T>
177 const std::vector<FieldID> &_fields,
178 const std::vector<size_t> &_fld_offsets,
179 const std::vector<size_t> &_fld_sizes,
184 const std::vector<FieldID> &_fields,
185 const std::vector<size_t> &_fld_offsets,
186 const std::vector<size_t> &_fld_sizes,
190 template <
typename S>
203 template <
typename S>
220 template <
int N,
typename T>
226 const std::vector<FieldID> &_fields,
227 const std::vector<size_t> &_fld_offsets,
228 const std::vector<size_t> &_fld_sizes);
230 template <
typename S>
246 template <
typename S>
271 template <
typename S>
274 template <
int N,
typename T>
287 const std::vector<CopySrcDstField> &srcs,
288 const std::vector<CopySrcDstField> &dsts,
289 const std::vector<IndirectionInfo *> &indirects,
290 bool force_fortran_order,
size_t max_stride)
const = 0;
293 const std::vector<FieldID> &fields,
294 const std::vector<size_t> &fld_sizes,
295 std::vector<size_t> &fragments)
const = 0;
299 const std::vector<FieldID> &fields,
300 const std::vector<size_t> &fld_offsets,
301 const std::vector<size_t> &fld_sizes)
const = 0;
305 const std::vector<FieldID> &fields,
306 const std::vector<size_t> &fld_offsets,
307 const std::vector<size_t> &fld_sizes)
const = 0;
309 virtual void print(std::ostream &os)
const = 0;
360 unsigned _fld_start,
unsigned _fld_count);
362 static IO mk_fill(
unsigned _fill_start,
unsigned _fill_size,
size_t _fill_total);
382 template <
int N,
typename T>
385 const std::vector<CopySrcDstField> &_dsts,
390 template <
int N,
typename T>
393 std::vector<CopySrcDstField> &&_dsts,
398 template <
int N,
typename T,
typename SrcVec,
typename DstVec>
435 virtual void print(std::ostream &os)
const;
471 unsigned src_fld_start,
unsigned src_fld_count,
473 std::vector<TransferGraph::XDTemplate> &xd_nodes,
474 std::vector<TransferGraph::IBInfo> &ib_edges,
475 std::vector<TransferDesc::FieldInfo> &src_fields) = 0;
479 unsigned dst_fld_start,
unsigned dst_fld_count,
size_t bytes_per_element,
480 CustomSerdezID serdez_id, std::vector<TransferGraph::XDTemplate> &xd_nodes,
481 std::vector<TransferGraph::IBInfo> &ib_edges,
482 std::vector<TransferDesc::FieldInfo> &src_fields) = 0;
494 const std::vector<size_t> &fld_offsets,
const std::vector<size_t> &fld_sizes,
495 Channel *channel =
nullptr)
const = 0;
497 virtual void print(std::ostream &os)
const = 0;
505 bool _is_ranges,
bool _oor_possible,
bool _aliasing_possible,
506 size_t _subfield_offset,
const std::vector<RegionInstance> _insts,
515 unsigned indirect_idx,
unsigned src_fld_start,
516 unsigned src_fld_count,
size_t bytes_per_element,
518 std::vector<TransferGraph::XDTemplate> &xd_nodes,
519 std::vector<TransferGraph::IBInfo> &ib_edges,
520 std::vector<TransferDesc::FieldInfo> &src_fields);
524 unsigned indirect_idx,
unsigned dst_fld_start,
525 unsigned dst_fld_count,
size_t bytes_per_element,
527 std::vector<TransferGraph::XDTemplate> &xd_nodes,
528 std::vector<TransferGraph::IBInfo> &ib_edges,
529 std::vector<TransferDesc::FieldInfo> &src_fields);
555 template <
int N,
typename T,
int N2,
typename T2>
575 const std::vector<size_t> &fld_offsets,
const std::vector<size_t> &fld_sizes,
576 Channel *channel =
nullptr)
const;
578 virtual void print(std::ostream &os)
const;
602 virtual void print(std::ostream &os)
const;
614 const off_t *offsets);
621 virtual void print(std::ostream &os)
const;
634 virtual void print(std::ostream &os)
const;
651 template <
int N,
typename T>
654 const std::vector<CopySrcDstField> &,
655 const std::vector<const typename CopyIndirection<N, T>::Base *> &,
658 template <
int N,
typename T>
665#include "realm/transfer/transfer.inl"
Definition address_list.h:55
Definition indexspace.h:252
Definition indexspace.h:250
unsigned gen_t
Definition event_impl.h:87
Definition event_impl.h:49
Definition event_impl.h:198
Definition transfer.h:502
bool structured
Definition transfer.h:539
virtual XferDesFactory * create_addrsplit_factory(size_t bytes_per_element) const =0
virtual void generate_scatter_paths(Memory src_mem, TransferGraph::XDTemplate::IO src_edge, unsigned indirect_idx, unsigned dst_fld_start, unsigned dst_fld_count, size_t bytes_per_element, CustomSerdezID serdez_id, std::vector< TransferGraph::XDTemplate > &xd_nodes, std::vector< TransferGraph::IBInfo > &ib_edges, std::vector< TransferDesc::FieldInfo > &src_fields)
virtual void generate_gather_paths(const Node *nodes_info, Memory dst_mem, TransferGraph::XDTemplate::IO dst_edge, unsigned indirect_idx, unsigned src_fld_start, unsigned src_fld_count, size_t bytes_per_element, CustomSerdezID serdez_id, std::vector< TransferGraph::XDTemplate > &xd_nodes, std::vector< TransferGraph::IBInfo > &ib_edges, std::vector< TransferDesc::FieldInfo > &src_fields)
std::vector< RegionInstance > insts
Definition transfer.h:546
size_t subfield_offset
Definition transfer.h:545
FieldID field_id
Definition transfer.h:540
IndirectionInfoBase(bool _structured, FieldID _field_id, RegionInstance _inst, bool _is_ranges, bool _oor_possible, bool _aliasing_possible, size_t _subfield_offset, const std::vector< RegionInstance > _insts, Channel *_addrsplit_channel)
RegionInstance inst
Definition transfer.h:541
bool oor_possible
Definition transfer.h:543
bool aliasing_possible
Definition transfer.h:544
Channel * addrsplit_channel
Definition transfer.h:547
virtual size_t num_spaces() const =0
bool is_ranges
Definition transfer.h:542
virtual size_t address_size() const =0
virtual void populate_copy_info(ChannelCopyInfo &info) const =0
virtual size_t domain_size() const =0
Definition transfer.h:556
virtual RegionInstance get_pointer_instance(void) const
virtual void populate_copy_info(ChannelCopyInfo &info) const
IndexSpace< N, T > domain
Definition transfer.h:588
virtual void print(std::ostream &os) const
IndirectionInfoTyped(const IndexSpace< N, T > &is, const typename CopyIndirection< N, T >::template Unstructured< N2, T2 > &ind, Channel *_addr_split_channel)
virtual const std::vector< RegionInstance > * get_instances(void) const
virtual size_t domain_size() const
virtual Event request_metadata(void)
virtual TransferIterator * create_indirect_iterator(Memory addrs_mem, RegionInstance inst, const std::vector< FieldID > &fields, const std::vector< size_t > &fld_offsets, const std::vector< size_t > &fld_sizes, Channel *channel=nullptr) const
Channel * addr_split_channel
Definition transfer.h:590
virtual TransferIterator * create_address_iterator(RegionInstance peer) const
virtual size_t address_size() const
virtual XferDesFactory * create_addrsplit_factory(size_t bytes_per_element) const
std::vector< IndexSpace< N2, T2 > > spaces
Definition transfer.h:589
virtual size_t num_spaces() const
virtual FieldID get_field(void) const
Definition transfer.h:463
virtual FieldID get_field(void) const =0
virtual void generate_gather_paths(const Node *node_info, Memory dst_mem, TransferGraph::XDTemplate::IO dst_edge, unsigned indirect_idx, unsigned src_fld_start, unsigned src_fld_count, size_t bytes_per_element, CustomSerdezID serdez_id, std::vector< TransferGraph::XDTemplate > &xd_nodes, std::vector< TransferGraph::IBInfo > &ib_edges, std::vector< TransferDesc::FieldInfo > &src_fields)=0
virtual void generate_scatter_paths(Memory src_mem, TransferGraph::XDTemplate::IO src_edge, unsigned indirect_idx, unsigned dst_fld_start, unsigned dst_fld_count, size_t bytes_per_element, CustomSerdezID serdez_id, std::vector< TransferGraph::XDTemplate > &xd_nodes, std::vector< TransferGraph::IBInfo > &ib_edges, std::vector< TransferDesc::FieldInfo > &src_fields)=0
virtual Event request_metadata(void)=0
virtual const std::vector< RegionInstance > * get_instances(void) const =0
virtual RegionInstance get_pointer_instance(void) const =0
virtual TransferIterator * create_indirect_iterator(Memory addrs_mem, RegionInstance inst, const std::vector< FieldID > &fields, const std::vector< size_t > &fld_offsets, const std::vector< size_t > &fld_sizes, Channel *channel=nullptr) const =0
virtual TransferIterator * create_address_iterator(RegionInstance peer) const =0
virtual void print(std::ostream &os) const =0
virtual ~IndirectionInfo(void)
Definition transfer.h:465
Definition inst_layout.h:266
static const Memory NO_MEMORY
Definition memory.h:49
Definition operation.h:75
Definition operation.h:32
Definition profiling.h:363
Definition inst_impl.h:54
Definition serialize.h:363
Definition sparsity_impl.h:105
Definition transfer.h:431
virtual void print(std::ostream &os) const
TransferDesc * desc
Definition transfer.h:438
virtual void event_triggered(bool poisoned, TimeLimit work_until)
Event precondition
Definition transfer.h:439
virtual Event get_finish_event(void) const
DeferredAnalysis(TransferDesc *_desc)
Definition transfer.h:379
TransferDomain * domain
Definition transfer.h:445
atomic< bool > analysis_complete
Definition transfer.h:451
void cancel_analysis(Event failed_precondition)
ProfilingMeasurements::OperationMemoryUsage prof_usage
Definition transfer.h:459
size_t fill_size
Definition transfer.h:458
std::vector< FieldInfo > src_fields
Definition transfer.h:456
TransferGraph graph
Definition transfer.h:454
std::vector< IndirectionInfo * > indirects
Definition transfer.h:447
Mutex mutex
Definition transfer.h:450
bool request_analysis(TransferOperation *op)
std::vector< CopySrcDstField > dsts
Definition transfer.h:446
std::vector< CopySrcDstField > srcs
Definition transfer.h:446
DeferredAnalysis deferred_analysis
Definition transfer.h:441
ProfilingMeasurements::OperationCopyInfo prof_cpinfo
Definition transfer.h:460
std::vector< int > dim_order
Definition transfer.h:455
void check_analysis_preconditions()
std::vector< FieldInfo > dst_fields
Definition transfer.h:456
bool analysis_successful
Definition transfer.h:452
atomic< int > refcount
Definition transfer.h:425
void * fill_data
Definition transfer.h:457
TransferDesc(IndexSpace< N, T > _is, std::vector< CopySrcDstField > &&_srcs, std::vector< CopySrcDstField > &&_dsts, const std::vector< const typename CopyIndirection< N, T >::Base * > &_indirects, const ProfilingRequestSet &requests)
ProfilingRequestSet prs
Definition transfer.h:448
TransferDesc(IndexSpace< N, T > _is, const std::vector< CopySrcDstField > &_srcs, const std::vector< CopySrcDstField > &_dsts, const std::vector< const typename CopyIndirection< N, T >::Base * > &_indirects, const ProfilingRequestSet &requests)
std::vector< TransferOperation * > pending_ops
Definition transfer.h:453
Definition transfer.h:266
virtual TransferIterator * create_iterator(RegionInstance inst, RegionInstance peer, const std::vector< FieldID > &fields, const std::vector< size_t > &fld_offsets, const std::vector< size_t > &fld_sizes) const =0
virtual ~TransferDomain(void)
virtual size_t volume(void) const =0
virtual TransferDomain * clone(void) const =0
virtual Event request_metadata(void)=0
virtual void choose_dim_order(std::vector< int > &dim_order, const std::vector< CopySrcDstField > &srcs, const std::vector< CopySrcDstField > &dsts, const std::vector< IndirectionInfo * > &indirects, bool force_fortran_order, size_t max_stride) const =0
virtual TransferIterator * create_iterator(RegionInstance inst, const std::vector< int > &dim_order, const std::vector< FieldID > &fields, const std::vector< size_t > &fld_offsets, const std::vector< size_t > &fld_sizes) const =0
virtual void count_fragments(RegionInstance inst, const std::vector< int > &dim_order, const std::vector< FieldID > &fields, const std::vector< size_t > &fld_sizes, std::vector< size_t > &fragments) const =0
virtual bool empty(void) const =0
static TransferDomain * deserialize_new(S &deserializer)
static TransferDomain * construct(const IndexSpace< N, T > &is)
virtual void print(std::ostream &os) const =0
Definition transfer.h:125
Rect< N, T > cur_rect
Definition transfer.h:153
virtual Event request_metadata(void)
size_t cur_field_offset
Definition transfer.h:155
TransferIteratorBase(void)
bool have_rect
Definition transfer.h:152
virtual void cancel_step(void)
Point< N, T > cur_point
Definition transfer.h:156
virtual void confirm_step(void)
bool carry
Definition transfer.h:157
virtual size_t step(size_t max_bytes, AddressInfo &info, unsigned flags, bool tentative=false)
bool tentative_valid
Definition transfer.h:162
Point< N, T > next_point
Definition transfer.h:156
TransferIteratorBase(RegionInstanceImpl *_inst_impl, const int _dim_order[N])
FieldID cur_field_id
Definition transfer.h:154
virtual bool get_addresses(AddressList &addrlist, const InstanceLayoutPieceBase *&nonaffine)
bool is_done
Definition transfer.h:152
virtual size_t get_base_offset(void) const
size_t inst_offset
Definition transfer.h:161
size_t cur_field_size
Definition transfer.h:155
virtual size_t step_custom(size_t max_bytes, AddressInfoCustom &info, bool tentative=false)
int dim_order[N]
Definition transfer.h:163
virtual bool get_next_rect(Rect< N, T > &r, FieldID &fid, size_t &offset, size_t &fsize)=0
RegionInstanceImpl * inst_impl
Definition transfer.h:159
Definition transfer.h:172
virtual bool get_next_rect(Rect< N, T > &r, FieldID &fid, size_t &offset, size_t &fsize)
size_t field_idx
Definition transfer.h:217
IndexSpace< N, T > is
Definition transfer.h:211
TransferIteratorIndexSpace(const int _dim_order[N], const std::vector< FieldID > &_fields, const std::vector< size_t > &_fld_offsets, const std::vector< size_t > &_fld_sizes, RegionInstanceImpl *_inst_impl, const IndexSpace< N, T > &_is)
std::vector< FieldID > fields
Definition transfer.h:215
void reset_internal(void)
static Serialization::PolymorphicSerdezSubclass< TransferIterator, TransferIteratorIndexSpace< N, T > > serdez_subclass
Definition transfer.h:201
std::vector< size_t > fld_sizes
Definition transfer.h:216
static TransferIterator * deserialize_new(S &deserializer)
TransferIteratorIndexSpace(const int _dim_order[N], const std::vector< FieldID > &_fields, const std::vector< size_t > &_fld_offsets, const std::vector< size_t > &_fld_sizes, RegionInstanceImpl *_inst_impl, const Rect< N, T > &_bounds, SparsityMapImpl< N, T > *_sparsity_impl)
virtual ~TransferIteratorIndexSpace(void)
SparsityMapImpl< N, T > * sparsity_impl
Definition transfer.h:212
bool iter_init_deferred
Definition transfer.h:214
TransferIteratorIndexSpace(void)
std::vector< size_t > fld_offsets
Definition transfer.h:216
IndexSpaceIterator< N, T > iter
Definition transfer.h:213
bool serialize(S &serializer) const
virtual Event request_metadata(void)
Definition transfer.h:221
Memory addrs_mem
Definition transfer.h:254
int indirect_port_idx
Definition transfer.h:263
virtual bool get_next_rect(Rect< N, T > &r, FieldID &fid, size_t &offset, size_t &fsize)
bool can_merge
Definition transfer.h:256
std::vector< size_t > fld_offsets
Definition transfer.h:261
TransferIteratorIndirect(void)
intptr_t addrs_mem_base
Definition transfer.h:255
TransferIteratorIndirect(Memory _addrs_mem, RegionInstanceImpl *_inst_impl, const std::vector< FieldID > &_fields, const std::vector< size_t > &_fld_offsets, const std::vector< size_t > &_fld_sizes)
virtual void set_indirect_input_port(XferDes *xd, int port_idx, TransferIterator *inner_iter)
bool serialize(S &serializer) const
XferDes * indirect_xd
Definition transfer.h:262
static constexpr size_t MAX_POINTS
Definition transfer.h:257
std::vector< size_t > fld_sizes
Definition transfer.h:261
virtual Event request_metadata(void)
size_t num_points
Definition transfer.h:259
Point< N, T > points[MAX_POINTS]
Definition transfer.h:258
size_t point_pos
Definition transfer.h:259
virtual ~TransferIteratorIndirect(void)
TransferIterator * addrs_in
Definition transfer.h:253
static TransferIterator * deserialize_new(S &deserializer)
static Serialization::PolymorphicSerdezSubclass< TransferIterator, TransferIteratorIndirect< N, T > > serdez_subclass
Definition transfer.h:244
std::vector< FieldID > fields
Definition transfer.h:260
virtual ~AddressInfoCustom()
Definition transfer.h:91
virtual int set_rect(const RegionInstanceImpl *inst, const InstanceLayoutPieceBase *piece, size_t field_size, size_t field_offset, int ndims, const int64_t lo[], const int64_t hi[], const int order[])=0
virtual size_t get_address_size(void) const
virtual void reset(void)=0
virtual ~TransferIterator(void)
virtual bool done(void)=0
virtual size_t step_custom(size_t max_bytes, AddressInfoCustom &info, bool tentative=false)=0
virtual size_t get_base_offset(void) const
virtual size_t step(size_t max_bytes, AddressInfo &info, unsigned flags, bool tentative=false)=0
@ SRC_LINES_OK
Definition transfer.h:64
@ SRC_PARTIAL_OK
Definition transfer.h:63
@ SRC_PLANES_OK
Definition transfer.h:65
@ SRC_FLAGMASK
Definition transfer.h:66
@ PARTIAL_OK
Definition transfer.h:73
@ LINES_OK
Definition transfer.h:74
@ PLANES_OK
Definition transfer.h:75
@ DST_FLAGMASK
Definition transfer.h:71
@ DST_LINES_OK
Definition transfer.h:69
@ DST_PARTIAL_OK
Definition transfer.h:68
@ DST_PLANES_OK
Definition transfer.h:70
virtual Event request_metadata(void)
virtual bool get_addresses(AddressList &addrlist, const InstanceLayoutPieceBase *&nonaffine)=0
static TransferIterator * deserialize_new(S &deserializer)
virtual void cancel_step(void)=0
virtual void confirm_step(void)=0
virtual void set_indirect_input_port(XferDes *xd, int port_idx, TransferIterator *inner_iter)
Definition transfer.h:630
TransferOperation * op
Definition transfer.h:637
Event precondition
Definition transfer.h:638
virtual Event get_finish_event(void) const
virtual void event_triggered(bool poisoned, TimeLimit work_until)
virtual void print(std::ostream &os) const
DeferredStart(TransferOperation *_op)
Definition transfer.h:617
XDLifetimeTracker(TransferOperation *_op, XferDesID _xd_id)
XferDesID xd_id
Definition transfer.h:624
virtual void print(std::ostream &os) const
virtual void request_cancellation(void)
Definition transfer.h:594
std::vector< off_t > ib_offsets
Definition transfer.h:646
Event precondition
Definition transfer.h:643
TransferOperation(TransferDesc &_desc, Event _precondition, GenEventImpl *_finish_event, EventImpl::gen_t _finish_gen, int priority)
atomic< unsigned > ib_responses_needed
Definition transfer.h:647
DeferredStart deferred_start
Definition transfer.h:640
TransferDesc & desc
Definition transfer.h:642
std::vector< XDLifetimeTracker * > xd_trackers
Definition transfer.h:645
void notify_ib_allocations(unsigned count, unsigned first_index, const off_t *offsets)
virtual bool mark_ready(void)
void notify_xd_completion(XferDesID xd_id)
virtual void mark_completed(void)
virtual void print(std::ostream &os) const
virtual bool mark_started(void)
void start_or_defer(void)
std::vector< XferDesID > xd_ids
Definition transfer.h:644
void notify_ib_allocation(unsigned ib_index, off_t ib_offset)
int priority
Definition transfer.h:648
Definition activemsg.h:38
Event(*)(const IndexSpace< N, T > &, const std::vector< CopySrcDstField > &, const std::vector< CopySrcDstField > &, const std::vector< const typename CopyIndirection< N, T >::Base * > &, const Realm::ProfilingRequestSet &, Event, int) CopyImplFn
Definition transfer.h:656
realm_field_id_t FieldID
Definition instance.h:45
int NodeID
Definition nodeset.h:40
int CustomSerdezID
Definition custom_serdez.h:148
unsigned long long XferDesID
Definition channel.h:57
std::ostream & operator<<(std::ostream &os, const DenseRectangleList< N, T > &drl)
Definition transfer.h:659
static CopyImplFn< N, T > impl
Definition transfer.h:660
Definition indexspace.h:1249
Definition indexspace.h:323
Definition runtime_impl.h:88
Definition profiling.h:188
Definition profiling.h:180
Definition transfer.h:418
size_t size
Definition transfer.h:420
size_t offset
Definition transfer.h:420
CustomSerdezID serdez_id
Definition transfer.h:421
FieldID id
Definition transfer.h:419
Definition transfer.h:370
size_t size
Definition transfer.h:372
Memory memory
Definition transfer.h:371
Definition transfer.h:335
unsigned fill_size
Definition transfer.h:353
RegionInstance inst
Definition transfer.h:339
unsigned fld_start
Definition transfer.h:340
unsigned port
Definition transfer.h:345
unsigned ind_idx
Definition transfer.h:344
unsigned fill_start
Definition transfer.h:352
struct Realm::TransferGraph::XDTemplate::IO::@36::@40 fill
IOType iotype
Definition transfer.h:336
unsigned fld_count
Definition transfer.h:341
struct Realm::TransferGraph::XDTemplate::IO::@36::@39 indirect
unsigned edge
Definition transfer.h:350
size_t fill_total
Definition transfer.h:354
Definition transfer.h:318
Channel * channel
Definition transfer.h:326
static IO mk_fill(unsigned _fill_start, unsigned _fill_size, size_t _fill_total)
void set_simple(Channel *channel, int in_edge, int out_edge)
int scatter_control_input
Definition transfer.h:324
static IO mk_edge(unsigned _edge)
int gather_control_input
Definition transfer.h:323
XferDesRedopInfo redop
Definition transfer.h:325
XferDesFactory * factory
Definition transfer.h:322
static IO mk_inst(RegionInstance _inst, unsigned _fld_start, unsigned _fld_count)
std::vector< IO > inputs
Definition transfer.h:364
std::vector< IO > outputs
Definition transfer.h:365
static IO mk_indirect(unsigned _ind_idx, unsigned _port, RegionInstance _inst, unsigned _fld_start, unsigned _fld_count)
NodeID target_node
Definition transfer.h:320
IOType
Definition transfer.h:329
@ IO_INDIRECT_INST
Definition transfer.h:331
@ IO_FILL_DATA
Definition transfer.h:333
@ IO_EDGE
Definition transfer.h:332
@ IO_INST
Definition transfer.h:330
Definition transfer.h:317
std::vector< IBInfo > ib_edges
Definition transfer.h:375
std::vector< XDTemplate > xd_nodes
Definition transfer.h:374
std::vector< unsigned > ib_alloc_order
Definition transfer.h:376
size_t num_planes
Definition transfer.h:83
size_t line_stride
Definition transfer.h:82
size_t bytes_per_chunk
Definition transfer.h:80
size_t base_offset
Definition transfer.h:79
size_t num_lines
Definition transfer.h:81
size_t plane_stride
Definition transfer.h:84